Compare commits
31 Commits
feature/re
...
4906d867d0
Author | SHA1 | Date | |
---|---|---|---|
4906d867d0 | |||
930d1b14b1 | |||
02fe81d919 | |||
849874cec6 | |||
da1e716dde | |||
d2a3d5de6f | |||
f5204b496f | |||
3eb8b3da81 | |||
405ce258f2 | |||
1138c97865 | |||
8b214aab3d | |||
6a2b5da00b | |||
5c9bcfdac2 | |||
05b2278154 | |||
8976f24186 | |||
2de8d7d597 | |||
29daef3b46 | |||
98fb6dada1 | |||
81f0cf33aa | |||
4d25ef7719 | |||
eecdc5661d | |||
f36e7be2d8 | |||
a273f83873 | |||
0ae43a314a | |||
df27ad2041 | |||
06671174b2 | |||
036b720f2e | |||
b6bfc2409c | |||
28eaf580b4 | |||
fa41212e77 | |||
d1e2d77a29 |
1
.github/workflows/unittests.yaml
vendored
1
.github/workflows/unittests.yaml
vendored
@ -4,6 +4,7 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
|
- feature/refactor
|
||||||
pull_request: {}
|
pull_request: {}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
|
46
Dockerfile
46
Dockerfile
@ -1,33 +1,29 @@
|
|||||||
# ======= #
|
FROM centos/python-36-centos7
|
||||||
# Builder #
|
|
||||||
# ======= #
|
|
||||||
FROM python:3.11-slim as builder
|
|
||||||
COPY / /semver
|
|
||||||
RUN pip wheel --no-cache-dir --wheel-dir /wheels /semver
|
|
||||||
|
|
||||||
# ======== #
|
USER root
|
||||||
# Finalize #
|
|
||||||
# ======== #
|
|
||||||
FROM python:3.11-slim
|
|
||||||
|
|
||||||
# Update and install git
|
#Perform updates
|
||||||
RUN apt-get update && apt-get install -y git
|
RUN pip install --upgrade pip
|
||||||
|
RUN yum update -y
|
||||||
|
RUN yum -y remove git
|
||||||
|
RUN yum -y install https://packages.endpoint.com/rhel/7/os/x86_64/endpoint-repo-1.7-1.x86_64.rpm
|
||||||
|
RUN yum -y install git
|
||||||
|
|
||||||
# Create user
|
#Setup semver
|
||||||
RUN mkdir /semver && \
|
ADD / /semver
|
||||||
groupadd -g 10001 semver && \
|
WORKDIR /semver
|
||||||
useradd -u 10000 -g semver -d /semver semver \
|
RUN python setup.py sdist
|
||||||
&& chown -R semver:semver /semver
|
RUN pip install dist/semver-*.tar.gz
|
||||||
|
|
||||||
# Prep workspace
|
# Prep workspace
|
||||||
RUN mkdir /workspace && \
|
RUN mkdir /workspace
|
||||||
chown -R semver:semver /workspace
|
WORKDIR /workspace
|
||||||
VOLUME /workspace
|
VOLUME /workspace
|
||||||
|
|
||||||
# Setup semver
|
#Permissions
|
||||||
COPY --from=builder /wheels /semver/wheels
|
RUN useradd -d /semverUser semverUser
|
||||||
RUN pip install --no-cache /semver/wheels/*
|
RUN chown -R semverUser:semverUser /workspace
|
||||||
|
|
||||||
USER semver:semver
|
CMD [ "semver" ]
|
||||||
WORKDIR /workspace
|
|
||||||
ENTRYPOINT [ "semver" ]
|
USER semverUser
|
||||||
|
@ -27,19 +27,19 @@ def main():
|
|||||||
"""Main entry point for the application"""
|
"""Main entry point for the application"""
|
||||||
parser = argparse.ArgumentParser(description="Bump Semantic Version.")
|
parser = argparse.ArgumentParser(description="Bump Semantic Version.")
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-n", "--no-push", help="do not try to push", action="store_false", dest="push"
|
"-n", "--no-push", help="Do not try to push", action="store_false", dest="push"
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-g",
|
"-g",
|
||||||
"--global-user",
|
"--global-user",
|
||||||
help="set git user at a global level",
|
help="Set git user at a global level, helps in jenkins",
|
||||||
action="store_true",
|
action="store_true",
|
||||||
dest="global_user",
|
dest="global_user",
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-D",
|
"-D",
|
||||||
"--debug",
|
"--debug",
|
||||||
help="sets logging level to DEBUG",
|
help="Sets logging level to DEBUG",
|
||||||
action="store_true",
|
action="store_true",
|
||||||
dest="debug",
|
dest="debug",
|
||||||
default=False,
|
default=False,
|
||||||
|
@ -11,14 +11,14 @@ def main():
|
|||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-d",
|
"-d",
|
||||||
"--dot",
|
"--dot",
|
||||||
help="switch out / for . to be used in docker tag",
|
help="Switch out / for . to be used in docker tag",
|
||||||
action="store_true",
|
action="store_true",
|
||||||
dest="dot",
|
dest="dot",
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-D",
|
"-D",
|
||||||
"--debug",
|
"--debug",
|
||||||
help="sets logging level to DEBUG",
|
help="Sets logging level to DEBUG",
|
||||||
action="store_true",
|
action="store_true",
|
||||||
dest="debug",
|
dest="debug",
|
||||||
default=False,
|
default=False,
|
||||||
@ -26,12 +26,12 @@ def main():
|
|||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-f",
|
"-f",
|
||||||
"--format",
|
"--format",
|
||||||
help="format for pre-release version syntax",
|
help="Format for pre-release version syntax",
|
||||||
choices=["npm", "maven", "docker"],
|
choices=["npm", "maven", "docker"],
|
||||||
default=None,
|
default=None,
|
||||||
)
|
)
|
||||||
parser.add_argument(
|
parser.add_argument(
|
||||||
"-b", "--build-number", help="build number, used in pre-releases", default=0
|
"-b", "--build-number", help="Build number, used in pre-releases", default=0
|
||||||
)
|
)
|
||||||
|
|
||||||
args = parser.parse_args()
|
args = parser.parse_args()
|
||||||
|
49
semver/scm/perforce.py
Normal file
49
semver/scm/perforce.py
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
import subprocess
|
||||||
|
from typing import Union, List
|
||||||
|
|
||||||
|
import toml
|
||||||
|
|
||||||
|
from semver.scm import SCM
|
||||||
|
from semver.logger import logger
|
||||||
|
|
||||||
|
|
||||||
|
class Perforce(SCM):
|
||||||
|
def __init__(self) -> None:
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
|
def get_tag_version(self) -> str:
|
||||||
|
"""
|
||||||
|
Get the latest tagged version from Perforce labels
|
||||||
|
:return: The latest tagged version
|
||||||
|
"""
|
||||||
|
config: dict = toml.load("./.bumpversion.cfg")
|
||||||
|
|
||||||
|
tag_expression: str = config["bumpversion"]["tag_name"].replace(
|
||||||
|
"{new_version}", "[0-9]*.[0-9]*.[0-9]*"
|
||||||
|
)
|
||||||
|
|
||||||
|
logger.debug("Tag expression: " + str(tag_expression))
|
||||||
|
|
||||||
|
# Default version is `0.0.0` or what is found in
|
||||||
|
version = self.get_file_version(config)
|
||||||
|
|
||||||
|
# If a version is found in Perforce labels, use that the latest labeled version
|
||||||
|
labeled_versions: Union[List[str], None] = None
|
||||||
|
try:
|
||||||
|
proc = subprocess.run(
|
||||||
|
["p4", "labels", "-e", tag_expression, "-m1"],
|
||||||
|
capture_output=True,
|
||||||
|
text=True,
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
labeled_versions = proc.stdout.rstrip().split("\n")
|
||||||
|
except subprocess.CalledProcessError as e:
|
||||||
|
raise RuntimeError(
|
||||||
|
f"Error getting latest labeled Perforce version: {str(e.stderr).rstrip()}"
|
||||||
|
)
|
||||||
|
|
||||||
|
if len(labeled_versions) > 0 and labeled_versions[-1] != "":
|
||||||
|
version = labeled_versions[-1]
|
||||||
|
|
||||||
|
logger.debug("Label Version: " + str(version))
|
||||||
|
return version
|
Reference in New Issue
Block a user