Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
f82156d2f1
|
|||
7f7c75e983
|
|||
ce41933381
|
|||
6f105a6a12
|
|||
7abbecd28c
|
|||
0331672f92
|
|||
051cbfecfb
|
|||
495ff5c51e
|
|||
0df2400892
|
|||
47621f90c0
|
@ -4,18 +4,18 @@ stages:
|
||||
|
||||
build:
|
||||
stage: check
|
||||
image: registry.gitlab.com/wolutator/base-build-env:latest
|
||||
image: registry.hottis.de/dockerized/base-build-env:latest
|
||||
tags:
|
||||
- hottis
|
||||
- linux
|
||||
- docker
|
||||
script:
|
||||
- for I in *.py; do python -m py_compile $I; done
|
||||
- for I in *.py; do python -m pycodestyle --max-line-length=120 $I; done
|
||||
- for I in *.py; do python -m pycodestyle --ignore=E501 $I; done
|
||||
|
||||
release:
|
||||
stage: release
|
||||
image: registry.gitlab.com/wolutator/base-build-env
|
||||
image: registry.hottis.de/dockerized/base-build-env:latest
|
||||
tags:
|
||||
- hottis
|
||||
- linux
|
||||
@ -23,7 +23,7 @@ release:
|
||||
only:
|
||||
- release
|
||||
script:
|
||||
- zip GitlabReleaseTool.zip gitlabreleaseuploader.py deleterelease.py
|
||||
- zip GitlabReleaseTool.zip gitlabreleaseuploader.py deleterelease.py checksemver.py
|
||||
- python gitlabreleaseuploader.py -p $PRIVATE_TOKEN -i $CI_PROJECT_ID -u $CI_PROJECT_URL -I $CI_SERVER_URL
|
||||
-f GitlabReleaseTool.zip -F info.json -T $CI_COMMIT_REF_NAME
|
||||
|
||||
|
80
checksemver.py
Normal file
80
checksemver.py
Normal file
@ -0,0 +1,80 @@
|
||||
#!/usr/bin/python
|
||||
|
||||
import re
|
||||
import argparse
|
||||
import sys
|
||||
|
||||
parser = argparse.ArgumentParser(description='Semantic Version Validator')
|
||||
parser.add_argument('--versionToValidate', '-V',
|
||||
help='The version to validate against the semantic versioning rules',
|
||||
required=True)
|
||||
parser.add_argument('--messageToValidate', '-M',
|
||||
help='A message to validate, means: it must not be empty',
|
||||
default='',
|
||||
required=False)
|
||||
parser.add_argument('--validateMessage', '-m',
|
||||
help='Consider -M',
|
||||
required=False,
|
||||
action='store_true',
|
||||
default=False)
|
||||
parser.add_argument('--printExports', '-e',
|
||||
help='Print exports',
|
||||
action='store_true',
|
||||
default=False,
|
||||
required=False)
|
||||
parser.add_argument('--exportFormat', '-f',
|
||||
help='Print exports in >bash< or >powershell< format, to be used in '
|
||||
'backticks or with Invoke-Expression',
|
||||
default='bash',
|
||||
required=False)
|
||||
parser.add_argument('--verbose', '-v',
|
||||
help='Verbose output, overrides -q',
|
||||
required=False,
|
||||
action='store_true',
|
||||
default=False)
|
||||
args = parser.parse_args()
|
||||
|
||||
verbose = args.verbose
|
||||
versionToValidate = args.versionToValidate
|
||||
messageToValidate = args.messageToValidate
|
||||
validateMessage = args.validateMessage
|
||||
printExports = args.printExports
|
||||
exportFormat = args.exportFormat
|
||||
|
||||
r = re.compile(r'^(?P<major>0|[1-9]\d*)\.(?P<minor>0|[1-9]\d*)\.(?P<patch>0|[1-9]\d*)(?:-(?P<prerelease>(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+(?P<buildmetadata>[0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$')
|
||||
|
||||
if verbose:
|
||||
print("Version to validate: {}".format(versionToValidate))
|
||||
|
||||
m = r.match(versionToValidate)
|
||||
|
||||
if m:
|
||||
if verbose:
|
||||
for i in r.groupindex:
|
||||
print("Found: {}: {}".format(i, m.group(i)))
|
||||
if validateMessage:
|
||||
if verbose:
|
||||
print("Checking message {}".format(messageToValidate))
|
||||
if messageToValidate == '':
|
||||
if verbose:
|
||||
print("Message shall be validate and is invalid")
|
||||
sys.exit(1)
|
||||
else:
|
||||
if printExports:
|
||||
if exportFormat == "bash":
|
||||
print("export MESSAGE={}".format(messageToValidate))
|
||||
elif exportFormat == "powershell":
|
||||
print("set MESSAGE {}".format(messageToValidate))
|
||||
|
||||
if printExports:
|
||||
for i in r.groupindex:
|
||||
if exportFormat == "bash":
|
||||
print("export {}={}".format(i.upper(), '' if m.group(i) is None else m.group(i)))
|
||||
elif exportFormat == "powershell":
|
||||
print("set {} {}".format(i.upper(), '""' if m.group(i) is None else m.group(i)))
|
||||
|
||||
sys.exit(0)
|
||||
else:
|
||||
if verbose:
|
||||
print("Version is invalid")
|
||||
sys.exit(1)
|
@ -1,7 +1,7 @@
|
||||
{
|
||||
"releaseTag": "v1.10d",
|
||||
"releaseTag": "v1.11",
|
||||
"createReleaseTag": "true",
|
||||
"releaseName": "re-add insecure, second fix",
|
||||
"description": "re-add insecure option to deleterelease script, second fix"
|
||||
"releaseName": "semantic version validator added",
|
||||
"description": "semantic version validator added"
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user