add option not to create a release

This commit is contained in:
Wolfgang Hottgenroth 2021-01-08 13:22:15 +01:00
parent 41ba33d5a7
commit fee7aaaedb
Signed by: wn
GPG Key ID: 6C1E5E531E0D5D7F

View File

@ -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,16 +167,14 @@ if createReleaseTag:
# --- create release # --- create release
if createRelease:
createReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId) createReleaseUrl = "%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 = { payloadCreateRelease = {
"name": releaseName, "name": releaseName,
"tag_name": releaseTag, "tag_name": releaseTag,
"description": releaseDescription, "description": releaseDescription
"assets": {
"links": assets
}
} }
createReleaseResult = requests.post(createReleaseUrl, headers=headers, createReleaseResult = requests.post(createReleaseUrl, headers=headers,
@ -175,3 +190,30 @@ if verbose:
print(createReleaseResult) print(createReleaseResult)
print(createReleaseResult.text) print(createReleaseResult.text)
print('Release successfully created') print('Release successfully created')
attachAssetsToReleaseUrl = "%s/api/v4/projects/%s/releases" % (instanceUrl, projectId)
headers = {"PRIVATE-TOKEN": privateToken, "Content-Type": "application/json"}
payloadAttachAssetsToRelease = {
"name": releaseName,
"tag_name": releaseTag,
"assets": {
"links": assets
}
}
attachAssetsToReleaseResult = requests.put(attachAssetsToReleaseUrl, headers=headers,
data=json.dumps(payloadAttachAssetsToRelease),
verify=caBundle)
if attachAssetsToReleaseResult.status_code != 201:
print(attachAssetsToReleaseResult)
print(attachAssetsToReleaseResult.text)
raise Exception('Unable to assets to release')
if verbose:
print(attachAssetsToReleaseResult)
print(attachAssetsToReleaseResult.text)
print('Assets attached to release successfully')