From 5c6fd2a5b279f73beacdc57db27be4ac05f66706 Mon Sep 17 00:00:00 2001 From: Andreas Maier Date: Thu, 13 Jun 2024 12:26:53 +0200 Subject: [PATCH] Added GitHub Actions workflows for test,publish,notify, Adjusted versions Details: * Added the test,publish,notify workflows * Adjusted some dependent package versions. * Increased zhmcclient to 1.16.1 to get correct stomp-py package name. * Increased jsonschema to 3.1.0 to match the new minimum of zhmcclient. Signed-off-by: Andreas Maier --- .github/workflows/notify.yml | 35 ++++ .github/workflows/publish.yml | 185 +++++++++++++++++++ .github/workflows/test.yml | 217 +++++++++++++++++++++++ done/.dummy | 0 minimum-constraints-develop.txt | 58 +++--- minimum-constraints.txt | 13 +- requirements-base.txt | 3 +- requirements-develop.txt | 42 ++--- requirements.txt | 8 +- zhmc_log_forwarder/zhmc_log_forwarder.py | 9 +- 10 files changed, 497 insertions(+), 73 deletions(-) create mode 100644 .github/workflows/notify.yml create mode 100644 .github/workflows/publish.yml create mode 100644 .github/workflows/test.yml create mode 100644 done/.dummy diff --git a/.github/workflows/notify.yml b/.github/workflows/notify.yml new file mode 100644 index 0000000..3cbf46c --- /dev/null +++ b/.github/workflows/notify.yml @@ -0,0 +1,35 @@ +# This GitHub workflow will send a notification to Slack when a scheduled test +# workflow completes. + +# There needs to be a GitHub secret named "SLACK_HOOK" that is set to the +# incoming webhook URL for Slack. That webhook is tied to a Slack channel, so +# this workflow does not select the channel and relies on that default. +# Instructions to set up Slack for incoming webhooks are here: +# https://api.slack.com/messaging/webhooks. + +name: notify + +on: + workflow_run: + workflows: + - test + types: + - completed + +jobs: + + notify: + runs-on: ubuntu-latest + if: ${{ github.event.workflow_run.event == 'schedule' }} + steps: + + - name: Post status to Slack + run: | + run_id=$(echo "${{ github.event.workflow_run.url }}" | rev | cut -d '/' -f 1 | rev) + run_url="https://github.com/${{ github.repository }}/actions/runs/$run_id" + branch="${{ github.event.workflow_run.head_branch }}" + branch_url="https://github.com/${{ github.repository }}/commits/$branch" + repo_url="https://github.com/${{ github.repository }}/actions/workflows/test.yml" + emoji=$(if [[ "${{ github.event.workflow_run.conclusion }}" == "success" ]]; then echo ":white_check_mark:"; else echo ":x:"; fi) + json="{ \"text\": \"$emoji <$repo_url|${{ github.repository }}>: Scheduled run <$run_url|$run_id> on branch <$branch_url|$branch>: ${{ github.event.workflow_run.conclusion }}\" }" + curl -s -d "payload=$json" ${{ secrets.SLACK_HOOK }} diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml new file mode 100644 index 0000000..d6d0e2d --- /dev/null +++ b/.github/workflows/publish.yml @@ -0,0 +1,185 @@ +# This GitHub workflow will publish the package to Pypi and create a new stable branch when releasing the master branch. +# For more information see: +# https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions +# https://packaging.python.org/en/latest/guides/publishing-package-distribution-releases-using-github-actions-ci-cd-workflows/ + +name: publish + +on: + push: # When pushing a tag + tags: + - "*" + +jobs: + publish: + name: Build and publish to PyPI + if: startsWith(github.ref, 'refs/tags') + runs-on: ubuntu-latest + steps: + + #-------- Info gathering and checks + - name: Set pushed tag + id: set-tag + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + const result = "${{ github.ref }}".match("refs/tags/(.*)$")[1] + console.log(result) + return result + - name: Check validity of pushed tag + run: | + if [[ ${{ steps.set-tag.outputs.result }} =~ ^[0-9]+\.[0-9]+\.[0-9]+$ ]]; then + echo "Pushed tag '${{ steps.set-tag.outputs.result }}' is valid"; + else + echo "Pushed tag '${{ steps.set-tag.outputs.result }}' is invalid (must be 'M.N.U')"; + false; + fi + - name: Determine whether releasing the master branch + id: set-is-master-branch + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + const resp = await github.rest.git.getRef({ + owner: context.repo.owner, + repo: context.repo.repo, + ref: "heads/master", + }) + const result = (resp.data.object.sha == "${{ github.sha }}") + console.log(result) + return result + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Determine name of stable branch for pushed tag + id: set-stable-branch + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + const result = "stable_"+"${{ steps.set-tag.outputs.result }}".match("([0-9]+\.[0-9]+)\.")[1] + console.log(result) + return result + - name: Determine whether releasing stable branch for pushed tag + id: set-is-stable-branch + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + var resp + try { + resp = await github.rest.git.getRef({ + owner: context.repo.owner, + repo: context.repo.repo, + ref: "heads/${{ steps.set-stable-branch.outputs.result }}", + }) + } + catch(err) { + console.log("false (stable branch does not exist: "+err+")") + return false + } + const result = (resp.data.object.sha == "${{ github.sha }}") + console.log(result) + return result + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Check released commit to be master branch or stable branch for pushed tag + run: | + if [[ ${{ steps.set-is-master-branch.outputs.result }} == 'false' && ${{ steps.set-is-stable-branch.outputs.result }} == 'false' ]]; then + echo "Released commit is not 'master' or '${{ steps.set-stable-branch.outputs.result }}' branch"; + false; + fi + - name: Set update version + id: set-update-version + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + const result = "${{ steps.set-tag.outputs.result }}".match("[0-9]+\.[0-9]+\.([0-9]+)")[1] + console.log(result) + return result + - name: Check update version to be 0 when releasing master branch + if: ${{ steps.set-is-master-branch.outputs.result == 'true' }} + run: | + if [[ ${{ steps.set-update-version.outputs.result }} != '0' ]]; then + echo "Update version '${{ steps.set-update-version.outputs.result }}' in tag '${{ steps.set-tag.outputs.result }}' is invalid (must be 0 when releasing master branch)"; + false; + fi + - name: Check update version to be non-0 when releasing stable branch for pushed tag + if: ${{ steps.set-is-stable-branch.outputs.result == 'true' }} + run: | + if [[ ${{ steps.set-update-version.outputs.result }} == '0' ]]; then + echo "Update version '${{ steps.set-update-version.outputs.result }}' in tag '${{ steps.set-tag.outputs.result }}' is invalid (must be non-0 when releasing stable branch for pushed tag)"; + false; + fi + + #-------- Setup of work environment + - name: Checkout repo + uses: actions/checkout@v2 + with: + fetch-depth: 0 + - name: Set up Python 3.10 + uses: actions/setup-python@v5 + with: + python-version: "3.10" + - name: Development setup + run: | + make develop + + #-------- Publishing of package + - name: Build the distribution + run: | + make build + - name: Display the distribution directory + run: | + ls -l dist + # - name: Publish distribution to TestPyPI + # uses: pypa/gh-action-pypi-publish@release/v1 + # with: + # packages_dir: dist + # password: ${{ secrets.TEST_PYPI_API_TOKEN }} + # repository_url: https://test.pypi.org/legacy/ + - name: Publish distribution to PyPI + if: startsWith(github.ref, 'refs/tags') + uses: pypa/gh-action-pypi-publish@release/v1 + with: + packages_dir: dist + password: ${{ secrets.PYPI_API_TOKEN }} + + #-------- Creation of Github release + - name: Determine whether release on Github exists for the pushed tag + id: set-release-exists + uses: octokit/request-action@v2.x + with: + route: GET /repos/${{ github.repository }}/releases/tags/${{ steps.set-tag.outputs.result }} + continue-on-error: true + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Create release on Github for the pushed tag if it does not exist + if: ${{ steps.set-release-exists.outputs.status == 404 }} + uses: octokit/request-action@v2.x + with: + route: POST /repos/${{ github.repository }}/releases + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + INPUT_TAG_NAME: ${{ steps.set-tag.outputs.result }} + INPUT_NAME: "Release ${{ steps.set-tag.outputs.result }}" + INPUT_BODY: "Change log https://zhmc-log-forwarder.readthedocs.io/en/${{ steps.set-tag.outputs.result }}/changes.html" + + #-------- Creation of stable branch + # Note: This requires that in the branch protection rules for stable_*, + # the "Restrict pushes that create matching branches" checkmark is + # not set. + - name: Create new stable branch when releasing master branch + if: steps.set-is-master-branch.outputs.result == 'true' + uses: actions/github-script@v7 + with: + script: | + github.rest.git.createRef({ + owner: context.repo.owner, + repo: context.repo.repo, + ref: "refs/heads/${{ steps.set-stable-branch.outputs.result }}", + sha: "${{ github.sha }}", + }) + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml new file mode 100644 index 0000000..11a8c01 --- /dev/null +++ b/.github/workflows/test.yml @@ -0,0 +1,217 @@ +# This GitHub workflow will setup and run various kinds of tests with a variety of Python versions +# For more information see: https://help.github.com/actions/language-and-framework-guides/using-python-with-github-actions + +name: test + +on: + schedule: + # The schedule event always (and only) runs on the master branch. + - # cron (in UTC): minute hour day_of_month month day_of_week + cron: '00 22 * * SAT' + pull_request: # When creating a PR targeting these branches + branches: + - master + - stable_* + push: # When merging a PR targeting these branches (direct push is disabled) + branches: + - master + - stable_* + +jobs: + + set_matrix: + runs-on: ubuntu-latest + outputs: + matrix: ${{ steps.select_matrix.outputs.matrix }} + steps: + - name: "Select matrix" + id: select_matrix + # Select full matrix when scheduled or when releasing, and normal matrix + # otherwise. The matrix is defined as a JSON string. + # This technique documented in: + # https://stackoverflow.com/questions/65384420/how-to-make-a-github-action-matrix-element-conditional + # TODO: Find a way to define this with less escapes. + run: | + if [[ "${{ github.event_name }}" == "schedule" || "${{ github.head_ref }}" =~ ^release_ ]]; then \ + echo "matrix={ \ + \"os\": [ \"ubuntu-latest\", \"macos-latest\", \"windows-latest\" ], \ + \"python-version\": [ \"3.8\", \"3.9\", \"3.10\", \"3.11\", \"3.12\" ], \ + \"package_level\": [ \"minimum\", \"latest\" ] \ + }" >> $GITHUB_OUTPUT; \ + else \ + echo "matrix={ \ + \"os\": [ \"ubuntu-latest\", \"macos-latest\", \"windows-latest\" ], \ + \"python-version\": [ \"3.12\" ], \ + \"package_level\": [ \"minimum\", \"latest\" ], \ + \"include\": [ \ + { \ + \"os\": \"ubuntu-latest\", \ + \"python-version\": \"3.8\", \ + \"package_level\": \"minimum\" \ + }, \ + { \ + \"os\": \"ubuntu-latest\", \ + \"python-version\": \"3.9\", \ + \"package_level\": \"latest\" \ + }, \ + { \ + \"os\": \"macos-latest\", \ + \"python-version\": \"3.9\", \ + \"package_level\": \"minimum\" \ + }, \ + { \ + \"os\": \"windows-latest\", \ + \"python-version\": \"3.8\", \ + \"package_level\": \"latest\" \ + } \ + ] \ + }" >> $GITHUB_OUTPUT; \ + fi + - name: Show matrix in JSON + run: echo '${{ steps.select_matrix.outputs.matrix }}' + + test: + needs: set_matrix + strategy: + fail-fast: false + max-parallel: 20 + matrix: ${{ fromJson(needs.set_matrix.outputs.matrix) }} + runs-on: ${{ matrix.os }} + container: ${{ matrix.container }} + env: + PIP_DISABLE_PIP_VERSION_CHECK: 1 + PIP_NO_PYTHON_VERSION_WARNING: 1 + steps: + - name: Set run type (normal, scheduled, release) + id: set-run-type + uses: actions/github-script@v7 + with: + result-encoding: string + script: | + var result + if ("${{ github.event_name }}" == "schedule") { + result = "scheduled" + } else if ("${{ github.head_ref }}".match(/^release_/)) { + result = "release" + } else { + result = "normal" + } + console.log(result) + return result + - name: Checkout repo + uses: actions/checkout@v4 + with: + fetch-depth: 0 + # - name: Make sure this change adds or changes at least one change fragment file (unless start PR) + # if: ${{ ! startsWith(github.head_ref, 'start_') }} + # run: | + # bash -c "! git diff --exit-code origin/${{ github.base_ref }} changes/*.rst >/dev/null || (echo 'Please add or modify a change fragment file in the changes directory - for details read the Making a change section in the docs'; exit 1)" + - name: Set up Python ${{ matrix.python-version }} + uses: actions/setup-python@v5 + with: + python-version: ${{ matrix.python-version }} + - name: Display initial Python packages + run: | + echo "Installed Python packages:" + pip list + # - name: Display platform and env vars + # env: + # PACKAGE_LEVEL: ${{ matrix.package_level }} + # RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + # run: | + # make platform env + - name: Install the package and its dependents + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make install + - name: Show installed package versions + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + echo "Installed Python packages:" + pip list + - name: Development setup + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make develop + - name: Show installed package versions + run: | + echo "Installed Python packages:" + pip list + - name: Show package dependency tree + run: | + echo "Package dependency tree of installed Python packages:" + python -m pipdeptree --all + - name: Run build + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make build + # - name: Run builddoc + # env: + # PACKAGE_LEVEL: ${{ matrix.package_level }} + # RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + # run: | + # make builddoc + - name: Run check + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make check + - name: Run pylint + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make pylint + - name: Run unit test + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make test + - name: Send coverage result to coveralls.io + shell: bash -l {0} + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + COVERALLS_PARALLEL: true + COVERALLS_FLAG_NAME: "${{ matrix.os }},${{ matrix.python-version }},${{ matrix.package_level }}" + COVERALLS_SERVICE_NAME: github + COVERALLS_SERVICE_JOB_ID: "${{ github.run_id }}" + COVERALLS_SERVICE_NUMBER: "${{ github.workflow }}-${{ github.run_number }}" + run: | + coveralls + - name: Run check_reqs + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make check_reqs + - name: Run safety + env: + PACKAGE_LEVEL: ${{ matrix.package_level }} + RUN_TYPE: ${{ steps.set-run-type.outputs.result }} + run: | + make safety + + test_finish: + needs: test + runs-on: ubuntu-latest + container: python:3-slim + steps: + - name: Install coveralls + run: | + pip3 install --upgrade coveralls + - name: Send coverage finish to coveralls.io + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + COVERALLS_SERVICE_NUMBER: "${{ github.workflow }}-${{ github.run_number }}" + run: | + coveralls --finish diff --git a/done/.dummy b/done/.dummy new file mode 100644 index 0000000..e69de29 diff --git a/minimum-constraints-develop.txt b/minimum-constraints-develop.txt index 738ba72..a1a2898 100644 --- a/minimum-constraints-develop.txt +++ b/minimum-constraints-develop.txt @@ -11,10 +11,7 @@ # Must be consistent with requirements-base.txt. pip==23.3 - -setuptools==65.5.1; python_version <= '3.11' -setuptools==66.1.0; python_version >= '3.12' - +setuptools==66.1.0 wheel==0.38.1 @@ -23,16 +20,17 @@ wheel==0.38.1 # Must be consistent with requirements-develop.txt. # Builder for the distribution archives (no imports, invoked via build script): -build==0.5.0 -virtualenv==20.15.0; python_version <= '3.11' -virtualenv==20.23.0; python_version >= '3.12' +build==1.0.0 +virtualenv==20.23.0 +pyproject-hooks==1.1.0 # Tests (imports into testcases): -pytest==3.0.5 +pytest==6.2.5 mock==2.0.0 requests-mock==1.2.0 -testfixtures==4.13.3 +testfixtures==6.9.0 yamlordereddictloader==0.4.0 +# importlib-metadata is in Python>=3.8 (for versions, see https://pypi.org/project/importlib-metadata/) importlib-metadata==4.8.3 # Coverage reporting (no imports, invoked via coveralls script): @@ -61,29 +59,20 @@ autodocsumm==0.2.12 Babel==2.9.1 # PyLint (no imports, invoked via pylint script): -pylint==2.13.0; python_version <= '3.10' -pylint==2.15.0; python_version >= '3.11' -astroid==2.11.0; python_version <= '3.10' -astroid==2.12.4; python_version >= '3.11' +pylint==2.15.0 +astroid==2.12.4 lazy-object-proxy==1.4.3 -wrapt==1.12; python_version <= '3.10' -wrapt==1.14; python_version >= '3.11' -platformdirs==2.2.0; python_version <= '3.11' -platformdirs==3.2.0; python_version >= '3.12' +wrapt==1.14 +platformdirs==3.2.0 isort==4.3.8 tomlkit==0.10.1 -dill==0.2; python_version <= '3.10' -dill==0.3.6; python_version >= '3.11' +dill==0.3.6 # Flake8 and dependents (no imports, invoked via flake8 script): -flake8==3.8.0; python_version <= '3.9' -flake8==5.0.0; python_version >= '3.10' -mccabe==0.6.0; python_version <= '3.9' -mccabe==0.7.0; python_version >= '3.10' -pycodestyle==2.6.0; python_version <= '3.9' -pycodestyle==2.9.0; python_version >= '3.10' -pyflakes==2.2.0; python_version <= '3.9' -pyflakes==2.5.0; python_version >= '3.10' +flake8==6.1.0 +mccabe==0.7.0 +pycodestyle==2.11.0 +pyflakes==3.1.0 entrypoints==0.3.0 # Safety tool @@ -106,7 +95,7 @@ readme-renderer==23.0 pywin32-ctypes==0.2.0; sys_platform=="win32" # Package dependency management tools (not used by any make rules) -pipdeptree==2.2.0 +pipdeptree==2.16.0 pip-check-reqs==2.4.3; python_version <= '3.11' pip-check-reqs==2.5.1; python_version >= '3.12' @@ -128,19 +117,20 @@ backports.functools-lru-cache==1.3 backports.shutil-get-terminal-size==1.0.0 backports.ssl-match-hostname==3.5.0.1 gitdb2==2.0.0 -imagesize==0.7.1 +imagesize==1.3.0 Jinja2==3.1.3 keyring==18.0.0 -MarkupSafe==0.23 -pkginfo==1.4.1 +MarkupSafe==2.0 +pkginfo==1.4.2 py==1.11.0 -python-dateutil==2.6.0 -requests-toolbelt==0.7.0 +requests-toolbelt==0.8.0 rfc3986==1.4.0 rich==12.0.0 smmap2==2.0.1 -snowballstemmer==1.2.1 +snowballstemmer==2.0.0 +toml==0.10.2 tomli==2.0.1 +tqdm==4.66.4 typing==3.6.1 typing-extensions==4.7.1 urllib3==1.26.18 diff --git a/minimum-constraints.txt b/minimum-constraints.txt index f8d06b2..0e3c344 100644 --- a/minimum-constraints.txt +++ b/minimum-constraints.txt @@ -6,13 +6,13 @@ # Direct dependencies for installation. # Must be consistent with requirements.txt. -zhmcclient==1.16.0 +zhmcclient==1.16.1 -attrs==17.4.0 +attrs==22.2.0 PyYAML==5.3.1 -python-dateutil==2.7.5 +python-dateutil==2.8.2 requests==2.31.0 -jsonschema==3.1.3 +jsonschema==3.1.0 # ------------------------------------------------------------------------------ @@ -35,17 +35,14 @@ docopt==0.6.2 # idna>3 requires using requests >=2.26.0 idna==3.7 immutable-views==0.6.0 -importlib-metadata==6.7.0 importlib-resources==5.12.0 nocasedict==2.0.3 -pip==24.0 pkgutil_resolve_name==1.3.10 pyrsistent==0.19.3 pytz==2024.1 six==1.16.0 -stomp-py==8.1.2 +stomp.py==8.1.2 typing_extensions==4.7.1 -urllib3==2.0.7 websocket-client==1.6.1 yamlloader==1.4.1 zipp==3.15.0 diff --git a/requirements-base.txt b/requirements-base.txt index 36a0376..3bf016d 100644 --- a/requirements-base.txt +++ b/requirements-base.txt @@ -15,7 +15,6 @@ # pip>=21.0 is needed for the cryptography package on Windows on GitHub Actions. pip>=23.3 -setuptools>=65.5.1; python_version <= '3.11' -setuptools>=66.1.0; python_version >= '3.12' +setuptools>=66.1.0 wheel>=0.38.1 diff --git a/requirements-develop.txt b/requirements-develop.txt index d9fb95d..00066ec 100644 --- a/requirements-develop.txt +++ b/requirements-develop.txt @@ -7,13 +7,18 @@ # Must be consistent with minimum-constraints-develop.txt. # Builder for the distribution archives (no imports, invoked via build script): -build>=0.5.0 +build>=1.0.0 # build requires virtualenv.cli_run which was added in virtualenv 20.1 -virtualenv>=20.15.0; python_version <= '3.11' -virtualenv>=20.23.0; python_version >= '3.12' +virtualenv>=20.23.0 +pyproject-hooks>=1.1.0 # Tests (imports into testcases): -pytest>=3.0.5 # MIT +pytest>=6.2.5 +mock>=2.0.0 +requests-mock>=1.2.0 +testfixtures>=6.9.0 +yamlordereddictloader>=0.4.0 +# flake8 up to 6.0.0 has not yet adjusted to the removed interfaces of importlib-metadata 5.0 importlib-metadata>=4.8.3,<5 # Coverage reporting (no imports, invoked via coveralls script): @@ -50,35 +55,26 @@ Babel>=2.9.1 # PyLint (no imports, invoked via pylint script) # Pylint requires astroid -pylint>=2.13.0; python_version <= '3.10' -pylint>=2.15.0; python_version >= '3.11' -astroid>=2.11.0; python_version <= '3.10' -astroid>=2.12.4; python_version >= '3.11' +pylint>=2.15.0 +astroid>=2.12.4 # lazy-object-proxy is used by astroid lazy-object-proxy>=1.4.3 -wrapt>=1.11.2; python_version <= '3.10' -wrapt>=1.14; python_version >= '3.11' -platformdirs>=2.2.0; python_version <= '3.11' -platformdirs>=3.2.0; python_version >= '3.12' +wrapt>=1.14 +platformdirs>=3.2.0 # isort 4.2.8 fixes a pylint issue with false positive on import order of ssl on Windows # isort 4.3.8 fixes an issue with py310 and works on py310 (Note that isort 5.10.0 has official support for py310) isort>=4.3.8 # Pylint 2.14 uses tomlkit>=0.10.1 and requires py>=3.7 tomlkit>=0.10.1 # dill is used by pylint >=2.13 -dill>=0.2; python_version <= '3.10' -dill>=0.3.6; python_version >= '3.11' +dill>=0.3.6 # Flake8 and dependents (no imports, invoked via flake8 script): # flake8 4.0.0 fixes an AttributeError on Python 3.10. -flake8>=3.8.0; python_version <= '3.9' -flake8>=5.0.0; python_version >= '3.10' -mccabe>=0.6.0; python_version <= '3.9' -mccabe>=0.7.0; python_version >= '3.10' -pycodestyle>=2.6.0; python_version <= '3.9' -pycodestyle>=2.9.0; python_version >= '3.10' -pyflakes>=2.2.0; python_version <= '3.9' -pyflakes>=2.5.0; python_version >= '3.10' +flake8>=6.1.0 +mccabe>=0.7.0 +pycodestyle>=2.11.0 +pyflakes>=3.1.0 entrypoints>=0.3.0 # Safety tool @@ -103,7 +99,7 @@ readme-renderer>=23.0 pywin32-ctypes>=0.2.0; sys_platform=="win32" # Package dependency management tools (not used by any make rules) -pipdeptree>=2.2.0 +pipdeptree>=2.16.0 # pip-check-reqs 2.3.2 is needed to have proper support for pip<21.3. # pip-check-reqs 2.4.0 requires Python>=3.8. # pip-check-reqs 2.4.3 fixes a speed issue on Python 3.11 and requires pip>=21.2.4 diff --git a/requirements.txt b/requirements.txt index d203cd0..2eef4af 100644 --- a/requirements.txt +++ b/requirements.txt @@ -9,14 +9,14 @@ # Direct dependencies for installation. # Must be consistent with minimum-constraints.txt. -zhmcclient>=1.16.0 +zhmcclient>=1.16.1 # zhmcclient @ git+https://github.com/zhmcclient/python-zhmcclient.git@master -attrs>=17.4.0 +attrs>=22.2.0 PyYAML>=5.3.1 -python-dateutil>=2.7.5 +python-dateutil>=2.8.2 requests>=2.31.0 -jsonschema>=3.1.3 +jsonschema>=3.1.0 # ------------------------------------------------------------------------------ diff --git a/zhmc_log_forwarder/zhmc_log_forwarder.py b/zhmc_log_forwarder/zhmc_log_forwarder.py index 48496fd..3d650a9 100755 --- a/zhmc_log_forwarder/zhmc_log_forwarder.py +++ b/zhmc_log_forwarder/zhmc_log_forwarder.py @@ -684,8 +684,7 @@ def set_defaults(validator, properties, instance, schema): instance.setdefault(prop, subschema["default"]) # pylint: disable=use-yield-from - yield from validate_properties( - validator, properties, instance, schema) + yield from validate_properties(validator, properties, instance, schema) return jsonschema.validators.extend( validator_class, {"properties": set_defaults}) @@ -911,6 +910,7 @@ def load_message_file(self, filepath): class HelpConfigFileAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-config-file. """ @@ -1057,6 +1057,7 @@ def __call__(self, parser, namespace, values, option_string=None): class HelpLogMessageFileAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-log-message-file. """ @@ -1112,6 +1113,7 @@ def __call__(self, parser, namespace, values, option_string=None): class HelpFormatAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-format. """ @@ -1132,6 +1134,7 @@ def __call__(self, parser, namespace, values, option_string=None): class HelpFormatLineAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-format-line. """ @@ -1191,6 +1194,7 @@ def __call__(self, parser, namespace, values, option_string=None): class HelpFormatCADFAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-format-cadf. """ @@ -1284,6 +1288,7 @@ def __call__(self, parser, namespace, values, option_string=None): class HelpTimeFormatAction(argparse.Action): + # pylint: disable=too-few-public-methods """ Argparse class providing help text for --help-time-format. """