add option not to create a release
This commit is contained in:
parent
41ba33d5a7
commit
fee7aaaedb
@ -20,6 +20,11 @@ parser.add_argument('--file', '-f',
|
|||||||
parser.add_argument('--releaseName', '-n',
|
parser.add_argument('--releaseName', '-n',
|
||||||
help='Name of the release', required=False,
|
help='Name of the release', required=False,
|
||||||
default='')
|
default='')
|
||||||
|
parser.add_argument('--createRelease', '-C',
|
||||||
|
help='Shall the release be created here',
|
||||||
|
required=False,
|
||||||
|
action='store_true',
|
||||||
|
default=False)
|
||||||
parser.add_argument('--releaseTag', '-t',
|
parser.add_argument('--releaseTag', '-t',
|
||||||
help='Tag of the release in the repo',
|
help='Tag of the release in the repo',
|
||||||
required=False,
|
required=False,
|
||||||
@ -29,7 +34,7 @@ parser.add_argument('--releaseTagTarget', '-T',
|
|||||||
required=False,
|
required=False,
|
||||||
default='')
|
default='')
|
||||||
parser.add_argument('--createReleaseTag', '-c',
|
parser.add_argument('--createReleaseTag', '-c',
|
||||||
help='Shall the release be created here',
|
help='Shall the release tag be created here',
|
||||||
required=False,
|
required=False,
|
||||||
action='store_true',
|
action='store_true',
|
||||||
default=False)
|
default=False)
|
||||||
@ -47,6 +52,11 @@ parser.add_argument('--instanceUrl', '-I',
|
|||||||
parser.add_argument('--caBundle', '-B',
|
parser.add_argument('--caBundle', '-B',
|
||||||
help='File with the CA certificates to trust', required=False,
|
help='File with the CA certificates to trust', required=False,
|
||||||
default='/etc/ssl/certs/ca-certificates.crt')
|
default='/etc/ssl/certs/ca-certificates.crt')
|
||||||
|
parser.add_argument('--insecure',
|
||||||
|
help='insecure ssl connect',
|
||||||
|
required=False,
|
||||||
|
action='store_true',
|
||||||
|
default=False)
|
||||||
parser.add_argument('--verbose', '-v',
|
parser.add_argument('--verbose', '-v',
|
||||||
help='verbose output',
|
help='verbose output',
|
||||||
required=False,
|
required=False,
|
||||||
@ -59,6 +69,7 @@ projectId = args.projectId
|
|||||||
projectUrl = args.projectUrl
|
projectUrl = args.projectUrl
|
||||||
filesToUpload = args.file
|
filesToUpload = args.file
|
||||||
releaseName = args.releaseName
|
releaseName = args.releaseName
|
||||||
|
createRelease = args.createRelease
|
||||||
releaseTag = args.releaseTag
|
releaseTag = args.releaseTag
|
||||||
releaseTagTarget = args.releaseTagTarget
|
releaseTagTarget = args.releaseTagTarget
|
||||||
releaseDescription = args.description
|
releaseDescription = args.description
|
||||||
@ -67,14 +78,18 @@ createReleaseTag = args.createReleaseTag
|
|||||||
releaseInfoFilename = args.releaseInfoFile
|
releaseInfoFilename = args.releaseInfoFile
|
||||||
caBundle = args.caBundle
|
caBundle = args.caBundle
|
||||||
verbose = args.verbose
|
verbose = args.verbose
|
||||||
releaseInfo = {}
|
insecure = args.insecure
|
||||||
|
|
||||||
|
releaseInfo = {}
|
||||||
if (releaseInfoFilename):
|
if (releaseInfoFilename):
|
||||||
with open(releaseInfoFilename, 'r') as releaseInfoFile:
|
with open(releaseInfoFilename, 'r') as releaseInfoFile:
|
||||||
releaseInfo = releaseInfoFile.read()
|
releaseInfo = releaseInfoFile.read()
|
||||||
releaseInfo = json.loads(releaseInfo)
|
releaseInfo = json.loads(releaseInfo)
|
||||||
if 'releaseName' in releaseInfo:
|
if 'releaseName' in releaseInfo:
|
||||||
releaseName = releaseInfo['releaseName']
|
releaseName = releaseInfo['releaseName']
|
||||||
|
if 'createRelease' in releaseInfo:
|
||||||
|
createRelease = (releaseInfo['createRelease'] in
|
||||||
|
('true', 'True'))
|
||||||
if 'releaseTag' in releaseInfo:
|
if 'releaseTag' in releaseInfo:
|
||||||
releaseTag = releaseInfo['releaseTag']
|
releaseTag = releaseInfo['releaseTag']
|
||||||
if 'releaseTagTarget' in releaseInfo:
|
if 'releaseTagTarget' in releaseInfo:
|
||||||
@ -89,11 +104,13 @@ if releaseName == '':
|
|||||||
raise Exception('No release name given')
|
raise Exception('No release name given')
|
||||||
if releaseTag == '':
|
if releaseTag == '':
|
||||||
raise Exception('No release tag given')
|
raise Exception('No release tag given')
|
||||||
if releaseTagTarget == '':
|
if (releaseTagTarget == '') and createReleaseTag:
|
||||||
raise Exception('No release tag target given')
|
raise Exception('No release tag target given but creation of tag requested')
|
||||||
if releaseDescription == '':
|
if releaseDescription == '':
|
||||||
raise Exception('No release description given')
|
raise Exception('No release description given')
|
||||||
|
|
||||||
|
if insecure:
|
||||||
|
caBundle = (False)
|
||||||
|
|
||||||
# --- upload the file
|
# --- upload the file
|
||||||
uploadUrl = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId)
|
uploadUrl = "%s/api/v4/projects/%s/uploads" % (instanceUrl, projectId)
|
||||||
@ -150,28 +167,53 @@ if createReleaseTag:
|
|||||||
|
|
||||||
|
|
||||||
# --- create release
|
# --- create release
|
||||||
createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
|
if createRelease:
|
||||||
|
createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
|
||||||
|
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
|
||||||
|
|
||||||
|
payloadCreateRelease = {
|
||||||
|
"name": releaseName,
|
||||||
|
"tag_name": releaseTag,
|
||||||
|
"description": releaseDescription
|
||||||
|
}
|
||||||
|
|
||||||
|
createReleaseResult = requests.post(createReleaseUrl, headers=headers,
|
||||||
|
data=json.dumps(payloadCreateRelease),
|
||||||
|
verify=caBundle)
|
||||||
|
|
||||||
|
if createReleaseResult.status_code != 201:
|
||||||
|
print(createReleaseResult)
|
||||||
|
print(createReleaseResult.text)
|
||||||
|
raise Exception('Unable to create release')
|
||||||
|
|
||||||
|
if verbose:
|
||||||
|
print(createReleaseResult)
|
||||||
|
print(createReleaseResult.text)
|
||||||
|
print('Release successfully created')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
attachAssetsToReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
|
||||||
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
|
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
|
||||||
|
|
||||||
payloadCreateRelease = {
|
payloadAttachAssetsToRelease = {
|
||||||
"name": releaseName,
|
"name": releaseName,
|
||||||
"tag_name": releaseTag,
|
"tag_name": releaseTag,
|
||||||
"description": releaseDescription,
|
|
||||||
"assets": {
|
"assets": {
|
||||||
"links": assets
|
"links": assets
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createReleaseResult = requests.post(createReleaseUrl, headers=headers,
|
attachAssetsToReleaseResult = requests.put(attachAssetsToReleaseUrl, headers=headers,
|
||||||
data=json.dumps(payloadCreateRelease),
|
data=json.dumps(payloadAttachAssetsToRelease),
|
||||||
verify=caBundle)
|
verify=caBundle)
|
||||||
|
|
||||||
if createReleaseResult.status_code != 201:
|
if attachAssetsToReleaseResult.status_code != 201:
|
||||||
print(createReleaseResult)
|
print(attachAssetsToReleaseResult)
|
||||||
print(createReleaseResult.text)
|
print(attachAssetsToReleaseResult.text)
|
||||||
raise Exception('Unable to create release')
|
raise Exception('Unable to assets to release')
|
||||||
|
|
||||||
if verbose:
|
if verbose:
|
||||||
print(createReleaseResult)
|
print(attachAssetsToReleaseResult)
|
||||||
print(createReleaseResult.text)
|
print(attachAssetsToReleaseResult.text)
|
||||||
print('Release successfully created')
|
print('Assets attached to release successfully')
|
||||||
|
Reference in New Issue
Block a user