From 11a4ff35fcc3902de566481c623ac06fd481b611 Mon Sep 17 00:00:00 2001 From: Joseph Manley Date: Fri, 20 Nov 2020 11:39:40 -0500 Subject: [PATCH 1/4] Remove searching file for regex --- vars/runAutoSemver.groovy | 1 - 1 file changed, 1 deletion(-) diff --git a/vars/runAutoSemver.groovy b/vars/runAutoSemver.groovy index 2f8f825..726be84 100644 --- a/vars/runAutoSemver.groovy +++ b/vars/runAutoSemver.groovy @@ -40,7 +40,6 @@ def call(dockerImage = "rightbrainnetworks/auto-semver:latest", debug = false) { break } - env.SEMVER_NEW_VERSION = sh(script: "grep -Po '${regex}' .bumpversion.cfg", returnStdout: true).trim() env.SEMVER_RESOLVED_VERSION = getVersion("-d ${args}") env.VERSION = env.SEMVER_RESOLVED_VERSION From f3bc97206a03a91f1674226e3f430f65953906db Mon Sep 17 00:00:00 2001 From: Joseph Manley Date: Sun, 22 Nov 2020 23:15:47 -0500 Subject: [PATCH 2/4] Bugfix intenum Fix creds attempt documented workaround Set system prop Use privileged container to work around Jenkins bug Remove property set --- Jenkinsfile | 7 ++++--- semver/__init__.py | 26 +++++++++++++++----------- vars/runAutoSemver.groovy | 1 + 3 files changed, 20 insertions(+), 14 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index cbbd435..10aee15 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -1,4 +1,4 @@ -library('pipeline-library') +library('pipeline-library@bugfix/durable-task-workaround') pipeline { options { timestamps() } @@ -18,7 +18,7 @@ pipeline { stage('Self Version') { steps { withCredentials([usernamePassword(credentialsId: env.DOCKER_CREDENTIALS, usernameVariable: 'DOCKER_USERNAME', passwordVariable: 'DOCKER_PASSWORD')]) { - sh("docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD}") + sh("docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD") } runAutoSemver("rightbrainnetworks/auto-semver:${SELF_SEMVER_TAG}") } @@ -59,6 +59,7 @@ pipeline { agent { docker { image "rightbrainnetworks/auto-semver:${env.VERSION}" + args "--privileged" } } steps @@ -85,7 +86,7 @@ pipeline { // Authenticate & push to DockerHub withCredentials([usernamePassword(credentialsId: env.DOCKER_CREDENTIALS, usernameVariable: 'DOCKER_USERNAME', passwordVariable: 'DOCKER_PASSWORD')]) { sh(""" - docker login -u ${DOCKER_USERNAME} -p ${DOCKER_PASSWORD} + docker login -u $DOCKER_USERNAME -p $DOCKER_PASSWORD docker push rightbrainnetworks/auto-semver:${env.VERSION} """) } diff --git a/semver/__init__.py b/semver/__init__.py index da6a610..45a943a 100644 --- a/semver/__init__.py +++ b/semver/__init__.py @@ -1,6 +1,8 @@ import argparse import re import subprocess +import sys +import traceback from enum import IntEnum from semver.utils import get_tag_version from semver.logger import logging, logger, console_logger @@ -111,7 +113,7 @@ class SemVer(object): config_file = file.read() # version repo - logger.debug("Running bumpversion of type: " + self.version_type) + logger.debug("Running bumpversion of type: " + str(self.version_type.name)) bump_version(get_tag_version(), self.version_type) return self @@ -146,20 +148,22 @@ class SemVer(object): return self def main(): + parser = argparse.ArgumentParser(description='Bump Semantic Version.') + parser.add_argument('-n','--no-push', help='Do not try to push', action='store_false', dest='push') + parser.add_argument('-g','--global-user', help='Set git user at a global level, helps in jenkins', action='store_true', dest='global_user') + parser.add_argument('-D', '--debug', help='Sets logging level to DEBUG', action='store_true', dest='debug', default=False) + args = parser.parse_args() + + + if args.debug: + console_logger.setLevel(logging.DEBUG) try: - parser = argparse.ArgumentParser(description='Bump Semantic Version.') - parser.add_argument('-n','--no-push', help='Do not try to push', action='store_false', dest='push') - parser.add_argument('-g','--global-user', help='Set git user at a global level, helps in jenkins', action='store_true', dest='global_user') - parser.add_argument('-D', '--debug', help='Sets logging level to DEBUG', action='store_true', dest='debug', default=False) - args = parser.parse_args() - - - if args.debug: - console_logger.setLevel(logging.DEBUG) - SemVer(global_user=args.global_user).run(push=args.push) except Exception as e: logger.error(e) + if args.debug: + tb = sys.exc_info()[2] + traceback.print_tb(tb) if e == NO_MERGE_FOUND: exit(1) elif e == NOT_MAIN_BRANCH: diff --git a/vars/runAutoSemver.groovy b/vars/runAutoSemver.groovy index 726be84..2f8f825 100644 --- a/vars/runAutoSemver.groovy +++ b/vars/runAutoSemver.groovy @@ -40,6 +40,7 @@ def call(dockerImage = "rightbrainnetworks/auto-semver:latest", debug = false) { break } + env.SEMVER_NEW_VERSION = sh(script: "grep -Po '${regex}' .bumpversion.cfg", returnStdout: true).trim() env.SEMVER_RESOLVED_VERSION = getVersion("-d ${args}") env.VERSION = env.SEMVER_RESOLVED_VERSION From 8ba581e7028a53ad5c2c7b7f86229886f57c927c Mon Sep 17 00:00:00 2001 From: Joseph Manley Date: Mon, 23 Nov 2020 02:21:14 -0500 Subject: [PATCH 3/4] Add test for GitLab merge with message in quotes --- semver/tests.py | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/semver/tests.py b/semver/tests.py index 6383cd0..63025fa 100644 --- a/semver/tests.py +++ b/semver/tests.py @@ -158,6 +158,13 @@ class TestGetCommitMessageRegex(unittest.TestCase): def test_non_merge_message(self): matches = GET_COMMIT_MESSAGE.search("Example unrelated commit message that should get 0 matches") self.assertEqual(matches, None) + def test_gitlab_merge_with_double_quotes(self): + matches = GET_COMMIT_MESSAGE.search("Merge branch 'branch' into 'master'\n\n\"Message in quotes!\"") + if matches: + self.assertEqual(matches.group(4), "master") + self.assertEqual(matches.group(2), "branch") + else: + self.assertTrue(False) class TestVersionBumping(unittest.TestCase): def test_patch_bump(self): From dfbbfe6181e2012c7a846c6c7212449b306d4ad0 Mon Sep 17 00:00:00 2001 From: Joseph Manley Date: Mon, 23 Nov 2020 02:43:30 -0500 Subject: [PATCH 4/4] Convert line endings and remove backslashes --- semver/__init__.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/semver/__init__.py b/semver/__init__.py index 45a943a..e0075ee 100644 --- a/semver/__init__.py +++ b/semver/__init__.py @@ -61,7 +61,7 @@ class SemVer(object): message = str(p.stdout.read()) branch = b.stdout.read().decode('utf-8').rstrip() logger.info('Main branch is ' + branch) - matches = GET_COMMIT_MESSAGE.search(message) + matches = GET_COMMIT_MESSAGE.search(message.replace('\\n','\n').replace('\\','')) if matches: if str(matches.group(4)) == branch: self.merged_branch = matches.group(2)