Skip to content

Commit

Permalink
Unit Test Workflow, Dockerfile, and Other Improvements
Browse files Browse the repository at this point in the history
  • Loading branch information
yeslayla committed Jul 22, 2023
1 parent 62ea636 commit ce271b6
Show file tree
Hide file tree
Showing 9 changed files with 121 additions and 90 deletions.
74 changes: 74 additions & 0 deletions .github/workflows/unittests.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
name: Pytest

on:
push:
branches:
- master
pull_request: {}

jobs:
test:
name: Unit Tests
runs-on: ${{ matrix.os }}

strategy:
matrix:
os: [ubuntu-22.04, windows-latest, macos-latest]
python-version: ["3.8", "3.9", "3.10", "3.11"]

steps:
- name: Checkout
uses: actions/checkout@v3

- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}
cache: pip

- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install pytest pytest-cov
pip install -r requirements.txt
- name: Test
run: |
pytest
coverage:
name: Coverage Summary
runs-on: ubuntu-22.04
permissions:
pull-requests: write
contents: read

if: github.event_name == 'pull_request'
strategy:
fail-fast: false

steps:
- name: Checkout
uses: actions/checkout@v3

- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: "3.11"
cache: pip

- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install pytest pytest-cov
pip install -r requirements.txt
- name: Run Coverage
run: |
pytest --junitxml=pytest.xml --cov-report=term-missing:skip-covered --cov=semver | tee pytest-coverage.txt
- name: Comment Result Summary
uses: MishaKav/pytest-coverage-comment@main
with:
pytest-coverage-path: ./pytest-coverage.txt
junitxml-path: ./pytest.xml
48 changes: 26 additions & 22 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,29 +1,33 @@
FROM centos/python-36-centos7

USER root
# ======= #
# Builder #
# ======= #
FROM python:3.11-slim as builder
COPY / /semver
RUN pip wheel --no-cache-dir --wheel-dir /wheels /semver

#Perform updates
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
# ======== #
# Finalize #
# ======== #
FROM python:3.11-slim

#Setup semver
ADD / /semver
WORKDIR /semver
RUN python setup.py sdist
RUN pip install dist/semver-*.tar.gz
# Update and install git
RUN apt-get update && apt-get install -y git

# Create user
RUN mkdir /semver && \
groupadd -g 10001 semver && \
useradd -u 10000 -g semver -d /semver semver \
&& chown -R semver:semver /semver

# Prep workspace
RUN mkdir /workspace
WORKDIR /workspace
RUN mkdir /workspace && \
chown -R semver:semver /workspace
VOLUME /workspace

#Permissions
RUN useradd -d /semverUser semverUser
RUN chown -R semverUser:semverUser /workspace
# Setup semver
COPY --from=builder /wheels /semver/wheels
RUN pip install --no-cache /semver/wheels/*

CMD [ "semver" ]

USER semverUser
USER semver:semver
WORKDIR /workspace
ENTRYPOINT [ "semver" ]
6 changes: 3 additions & 3 deletions semver/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -27,19 +27,19 @@ def main():
"""Main entry point for the application"""
parser = argparse.ArgumentParser(description="Bump Semantic Version.")
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(
"-g",
"--global-user",
help="Set git user at a global level, helps in jenkins",
help="set git user at a global level",
action="store_true",
dest="global_user",
)
parser.add_argument(
"-D",
"--debug",
help="Sets logging level to DEBUG",
help="sets logging level to DEBUG",
action="store_true",
dest="debug",
default=False,
Expand Down
8 changes: 4 additions & 4 deletions semver/get_version.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,27 +11,27 @@ def main():
parser.add_argument(
"-d",
"--dot",
help="Switch out / for . to be used in docker tag",
help="switch out / for . to be used in docker tag",
action="store_true",
dest="dot",
)
parser.add_argument(
"-D",
"--debug",
help="Sets logging level to DEBUG",
help="sets logging level to DEBUG",
action="store_true",
dest="debug",
default=False,
)
parser.add_argument(
"-f",
"--format",
help="Format for pre-release version syntax",
help="format for pre-release version syntax",
choices=["npm", "maven", "docker"],
default=None,
)
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()
Expand Down
14 changes: 9 additions & 5 deletions semver/scm/git.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import re
import subprocess
from typing import Union, List
from functools import cache
from functools import lru_cache

import toml

Expand Down Expand Up @@ -29,7 +29,7 @@ def __init__(self, global_user: bool = False) -> None:

def _run_command(
self, *args: str, throwExceptions: bool = True
) -> subprocess.CompletedProcess[str]:
) -> subprocess.CompletedProcess:
return subprocess.run(
args,
capture_output=True,
Expand Down Expand Up @@ -82,13 +82,17 @@ def get_tag_version(self) -> str:
f"Error getting latest tagged git version: {str(e.stderr).rstrip()}"
)

if len(tagged_versions) > 0 and tagged_versions[-1] != "":
if (
tagged_versions is not None
and len(tagged_versions) > 0
and tagged_versions[-1] != ""
):
version = tagged_versions[-1]

logger.debug(f"Tag Version: {version}")
return version

@cache
@lru_cache(maxsize=None)
def get_branch(self) -> str:
"""
Get the main branch
Expand All @@ -97,7 +101,7 @@ def get_branch(self) -> str:
proc = self._run_command(self.git_bin, "rev-parse", "--abbrev-ref", "HEAD")
return proc.stdout.rstrip()

@cache
@lru_cache(maxsize=None)
def get_merge_branch(self) -> Union[str, None]:
"""
Get the branches involved in the merge
Expand Down
49 changes: 0 additions & 49 deletions semver/scm/perforce.py

This file was deleted.

4 changes: 0 additions & 4 deletions semver/tests/test_semver.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,10 +67,8 @@ def test_bump_version_patch(self, mock_update_file_version: mock.Mock):
@mock.patch("toml.load")
@mock.patch("pathlib.Path.is_file")
@mock.patch("builtins.open", mock.mock_open())
@mock.patch("semver.logger.warning")
def test_update_file_version(
self,
mock_logger: mock.Mock,
mock_path_is_file: mock.Mock,
mock_toml_load: mock.Mock,
):
Expand All @@ -83,11 +81,9 @@ def test_update_file_version(
}
mock_path_is_file.return_value = True
self.semver._update_file_version("1.0.1", "1.0.0")
mock_logger.assert_not_called()

mock_path_is_file.return_value = False
self.semver._update_file_version("1.0.1", "1.0.0")
mock_logger.assert_called_once()

@mock.patch("semver.semver.SemVer._version_repo", mock.MagicMock())
def test_run_ok(self):
Expand Down
4 changes: 2 additions & 2 deletions semver/utils.py
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
from typing import List
from pathlib import Path
from functools import cache
from functools import lru_cache
import configparser

import toml

from semver.exceptions import SemverException


@cache
@lru_cache(maxsize=None)
def get_settings() -> dict:
"""
Get the settings from the config file
Expand Down
4 changes: 3 additions & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,9 @@ classifiers =
[options]
include_package_data = True
packages = find:
python_requires = >=3.7, <4
python_requires = >=3.8, <4
install_requires =
toml

[options.packages.find]
exclude =
Expand Down

0 comments on commit ce271b6

Please sign in to comment.