diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index da7f8802..37c7e048 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -3,10 +3,10 @@ name: Python CI on: push: branches: - - master + - master pull_request: branches: - - '**' + - '**' jobs: run_tests: @@ -15,10 +15,9 @@ jobs: strategy: matrix: os: - - ubuntu-20.04 - python-version: - - 3.8 - toxenv: [ py38 ] + - ubuntu-20.04 + python-version: ['3.8', '3.11'] + toxenv: [py38] steps: - uses: actions/checkout@v1 - name: setup python @@ -31,7 +30,7 @@ jobs: - name: Install dependencies run: | - pip install pip==19.0.3 + pip install pip==24.0 pip install -r requirements/ci.txt - name: Run Tests diff --git a/requirements/base.txt b/requirements/base.txt index 9412d7ba..1dfa54a1 100644 --- a/requirements/base.txt +++ b/requirements/base.txt @@ -4,53 +4,47 @@ # # make upgrade # -certifi==2023.7.22 +certifi==2024.2.2 # via requests cffi==1.16.0 # via # cryptography # pynacl -charset-normalizer==3.3.1 +charset-normalizer==3.3.2 # via requests click==8.1.7 # via -r requirements/base.in -cryptography==41.0.4 +cryptography==42.0.5 # via pyjwt deprecated==1.2.14 # via pygithub gitdb==4.0.11 # via gitpython -gitpython==3.1.40 +gitpython==3.1.43 # via -r requirements/base.in -idna==3.4 +idna==3.7 # via requests -packaging==23.2 +packaging==24.0 # via -r requirements/base.in -pycparser==2.21 +pycparser==2.22 # via cffi -pygithub==2.1.1 +pygithub==2.3.0 # via -r requirements/base.in pyjwt[crypto]==2.8.0 - # via - # pygithub - # pyjwt -pynacl==1.5.0 # via pygithub -python-dateutil==2.8.2 +pynacl==1.5.0 # via pygithub requests==2.31.0 # via # -r requirements/base.in # pygithub -six==1.16.0 - # via python-dateutil smmap==5.0.1 # via gitdb -typing-extensions==4.8.0 +typing-extensions==4.11.0 # via pygithub -urllib3==2.0.7 +urllib3==2.2.1 # via # pygithub # requests -wrapt==1.15.0 +wrapt==1.16.0 # via deprecated diff --git a/requirements/ci.txt b/requirements/ci.txt index 267f554b..641296fb 100644 --- a/requirements/ci.txt +++ b/requirements/ci.txt @@ -4,27 +4,35 @@ # # make upgrade # -distlib==0.3.7 +cachetools==5.3.3 + # via tox +chardet==5.2.0 + # via tox +colorama==0.4.6 + # via tox +distlib==0.3.8 # via virtualenv -filelock==3.12.4 +filelock==3.13.4 # via # tox # virtualenv -packaging==23.2 - # via tox -platformdirs==3.11.0 - # via virtualenv -pluggy==1.3.0 - # via tox -py==1.11.0 +packaging==24.0 + # via + # pyproject-api + # tox +platformdirs==4.2.0 + # via + # tox + # virtualenv +pluggy==1.4.0 # via tox -six==1.16.0 +pyproject-api==1.6.1 # via tox tomli==2.0.1 - # via tox -tox==3.28.0 # via - # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt - # -r requirements/ci.in -virtualenv==20.24.5 + # pyproject-api + # tox +tox==4.14.2 + # via -r requirements/ci.in +virtualenv==20.25.1 # via tox diff --git a/requirements/dev.txt b/requirements/dev.txt index 949da6ce..e1fd3b40 100644 --- a/requirements/dev.txt +++ b/requirements/dev.txt @@ -4,16 +4,20 @@ # # make upgrade # -astroid==3.0.1 +astroid==3.1.0 # via # -r requirements/testing.txt # pylint # pylint-celery -build==1.0.3 +build==1.2.1 # via # -r requirements/pip-tools.txt # pip-tools -certifi==2023.7.22 +cachetools==5.3.3 + # via + # -r requirements/ci.txt + # tox +certifi==2024.2.2 # via # -r requirements/testing.txt # requests @@ -22,7 +26,11 @@ cffi==1.16.0 # -r requirements/testing.txt # cryptography # pynacl -charset-normalizer==3.3.1 +chardet==5.2.0 + # via + # -r requirements/ci.txt + # tox +charset-normalizer==3.3.2 # via # -r requirements/testing.txt # requests @@ -38,16 +46,19 @@ click-log==0.4.0 # via # -r requirements/testing.txt # edx-lint -code-annotations==1.5.0 +code-annotations==1.8.0 # via # -r requirements/testing.txt # edx-lint -coverage[toml]==7.3.2 +colorama==0.4.6 + # via + # -r requirements/ci.txt + # tox +coverage[toml]==7.4.4 # via # -r requirements/testing.txt - # coverage # pytest-cov -cryptography==41.0.4 +cryptography==42.0.5 # via # -r requirements/testing.txt # pyjwt @@ -55,21 +66,21 @@ deprecated==1.2.14 # via # -r requirements/testing.txt # pygithub -dill==0.3.7 +dill==0.3.8 # via # -r requirements/testing.txt # pylint -distlib==0.3.7 +distlib==0.3.8 # via # -r requirements/ci.txt # virtualenv -edx-lint==5.3.4 +edx-lint==5.3.6 # via -r requirements/testing.txt -exceptiongroup==1.1.3 +exceptiongroup==1.2.0 # via # -r requirements/testing.txt # pytest -filelock==3.12.4 +filelock==3.13.4 # via # -r requirements/ci.txt # tox @@ -78,29 +89,30 @@ gitdb==4.0.11 # via # -r requirements/testing.txt # gitpython -gitpython==3.1.40 +gitpython==3.1.43 # via -r requirements/testing.txt -idna==3.4 +idna==3.7 # via # -r requirements/testing.txt # requests -importlib-metadata==6.8.0 +importlib-metadata==6.11.0 # via + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/pip-tools.txt # build iniconfig==2.0.0 # via # -r requirements/testing.txt # pytest -isort==5.12.0 +isort==5.13.2 # via # -r requirements/testing.txt # pylint -jinja2==3.1.2 +jinja2==3.1.3 # via # -r requirements/testing.txt # code-annotations -markupsafe==2.1.3 +markupsafe==2.1.5 # via # -r requirements/testing.txt # jinja2 @@ -110,50 +122,47 @@ mccabe==0.7.0 # pylint mock==5.1.0 # via -r requirements/testing.txt -packaging==23.2 +packaging==24.0 # via # -r requirements/ci.txt # -r requirements/pip-tools.txt # -r requirements/testing.txt # build + # pyproject-api # pytest # tox -pbr==5.11.1 +pbr==6.0.0 # via # -r requirements/testing.txt # stevedore -pip-tools==7.3.0 +pip-tools==7.4.1 # via -r requirements/pip-tools.txt -platformdirs==3.11.0 +platformdirs==4.2.0 # via # -r requirements/ci.txt # -r requirements/testing.txt # pylint + # tox # virtualenv -pluggy==1.3.0 +pluggy==1.4.0 # via # -r requirements/ci.txt # -r requirements/testing.txt # pytest # tox -py==1.11.0 - # via - # -r requirements/ci.txt - # tox pycodestyle==2.11.1 # via -r requirements/testing.txt -pycparser==2.21 +pycparser==2.22 # via # -r requirements/testing.txt # cffi -pygithub==2.1.1 +pygithub==2.3.0 # via -r requirements/testing.txt pyjwt[crypto]==2.8.0 # via # -r requirements/testing.txt # pygithub - # pyjwt -pylint==3.0.2 +pylint==3.1.0 # via # -r requirements/testing.txt # edx-lint @@ -164,7 +173,7 @@ pylint-celery==0.3 # via # -r requirements/testing.txt # edx-lint -pylint-django==2.5.4 +pylint-django==2.5.5 # via # -r requirements/testing.txt # edx-lint @@ -177,21 +186,22 @@ pynacl==1.5.0 # via # -r requirements/testing.txt # pygithub +pyproject-api==1.6.1 + # via + # -r requirements/ci.txt + # tox pyproject-hooks==1.0.0 # via # -r requirements/pip-tools.txt # build -pytest==7.4.2 + # pip-tools +pytest==8.1.1 # via # -r requirements/testing.txt # pytest-cov -pytest-cov==4.1.0 +pytest-cov==5.0.0 # via -r requirements/testing.txt -python-dateutil==2.8.2 - # via - # -r requirements/testing.txt - # pygithub -python-slugify==8.0.1 +python-slugify==8.0.4 # via # -r requirements/testing.txt # code-annotations @@ -205,20 +215,17 @@ requests==2.31.0 # pygithub six==1.16.0 # via - # -r requirements/ci.txt # -r requirements/testing.txt # edx-lint - # python-dateutil - # tox smmap==5.0.1 # via # -r requirements/testing.txt # gitdb -stevedore==5.1.0 +stevedore==5.2.0 # via # -r requirements/testing.txt # code-annotations -testfixtures==7.2.2 +testfixtures==8.1.0 # via -r requirements/testing.txt text-unidecode==1.3 # via @@ -233,41 +240,40 @@ tomli==2.0.1 # coverage # pip-tools # pylint + # pyproject-api # pyproject-hooks # pytest # tox -tomlkit==0.12.1 +tomlkit==0.12.4 # via # -r requirements/testing.txt # pylint -tox==3.28.0 - # via - # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt - # -r requirements/ci.txt -typing-extensions==4.8.0 +tox==4.14.2 + # via -r requirements/ci.txt +typing-extensions==4.11.0 # via # -r requirements/testing.txt # astroid # pygithub # pylint -urllib3==2.0.7 +urllib3==2.2.1 # via # -r requirements/testing.txt # pygithub # requests -virtualenv==20.24.5 +virtualenv==20.25.1 # via # -r requirements/ci.txt # tox -wheel==0.41.2 +wheel==0.43.0 # via # -r requirements/pip-tools.txt # pip-tools -wrapt==1.15.0 +wrapt==1.16.0 # via # -r requirements/testing.txt # deprecated -zipp==3.17.0 +zipp==3.18.1 # via # -r requirements/pip-tools.txt # importlib-metadata diff --git a/requirements/pip-tools.txt b/requirements/pip-tools.txt index 50d35f22..748bf44e 100644 --- a/requirements/pip-tools.txt +++ b/requirements/pip-tools.txt @@ -4,26 +4,30 @@ # # make upgrade # -build==1.0.3 +build==1.2.1 # via pip-tools click==8.1.7 # via pip-tools -importlib-metadata==6.8.0 - # via build -packaging==23.2 +importlib-metadata==6.11.0 + # via + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt + # build +packaging==24.0 # via build -pip-tools==7.3.0 +pip-tools==7.4.1 # via -r requirements/pip-tools.in pyproject-hooks==1.0.0 - # via build + # via + # build + # pip-tools tomli==2.0.1 # via # build # pip-tools # pyproject-hooks -wheel==0.41.2 +wheel==0.43.0 # via pip-tools -zipp==3.17.0 +zipp==3.18.1 # via importlib-metadata # The following packages are considered to be unsafe in a requirements file: diff --git a/requirements/pip.txt b/requirements/pip.txt index 0c788d61..e3ffcc7b 100644 --- a/requirements/pip.txt +++ b/requirements/pip.txt @@ -4,11 +4,11 @@ # # make upgrade # -wheel==0.41.2 +wheel==0.43.0 # via -r requirements/pip.in # The following packages are considered to be unsafe in a requirements file: -pip==23.3.1 +pip==24.0 # via -r requirements/pip.in -setuptools==68.2.2 +setuptools==69.5.1 # via -r requirements/pip.in diff --git a/requirements/testing.txt b/requirements/testing.txt index a02313a8..2ee005d9 100644 --- a/requirements/testing.txt +++ b/requirements/testing.txt @@ -4,11 +4,11 @@ # # make upgrade # -astroid==3.0.1 +astroid==3.1.0 # via # pylint # pylint-celery -certifi==2023.7.22 +certifi==2024.2.2 # via # -r requirements/base.txt # requests @@ -17,7 +17,7 @@ cffi==1.16.0 # -r requirements/base.txt # cryptography # pynacl -charset-normalizer==3.3.1 +charset-normalizer==3.3.2 # via # -r requirements/base.txt # requests @@ -29,13 +29,13 @@ click==8.1.7 # edx-lint click-log==0.4.0 # via edx-lint -code-annotations==1.5.0 +code-annotations==1.8.0 # via edx-lint -coverage[toml]==7.3.2 +coverage[toml]==7.4.4 # via # -r requirements/testing.in # pytest-cov -cryptography==41.0.4 +cryptography==42.0.5 # via # -r requirements/base.txt # pyjwt @@ -43,58 +43,57 @@ deprecated==1.2.14 # via # -r requirements/base.txt # pygithub -dill==0.3.7 +dill==0.3.8 # via pylint -edx-lint==5.3.4 +edx-lint==5.3.6 # via -r requirements/testing.in -exceptiongroup==1.1.3 +exceptiongroup==1.2.0 # via pytest gitdb==4.0.11 # via # -r requirements/base.txt # gitpython -gitpython==3.1.40 +gitpython==3.1.43 # via -r requirements/base.txt -idna==3.4 +idna==3.7 # via # -r requirements/base.txt # requests iniconfig==2.0.0 # via pytest -isort==5.12.0 +isort==5.13.2 # via pylint -jinja2==3.1.2 +jinja2==3.1.3 # via code-annotations -markupsafe==2.1.3 +markupsafe==2.1.5 # via jinja2 mccabe==0.7.0 # via pylint mock==5.1.0 # via -r requirements/testing.in -packaging==23.2 +packaging==24.0 # via # -r requirements/base.txt # pytest -pbr==5.11.1 +pbr==6.0.0 # via stevedore -platformdirs==3.11.0 +platformdirs==4.2.0 # via pylint -pluggy==1.3.0 +pluggy==1.4.0 # via pytest pycodestyle==2.11.1 # via -r requirements/testing.in -pycparser==2.21 +pycparser==2.22 # via # -r requirements/base.txt # cffi -pygithub==2.1.1 +pygithub==2.3.0 # via -r requirements/base.txt pyjwt[crypto]==2.8.0 # via # -r requirements/base.txt # pygithub - # pyjwt -pylint==3.0.2 +pylint==3.1.0 # via # edx-lint # pylint-celery @@ -102,7 +101,7 @@ pylint==3.0.2 # pylint-plugin-utils pylint-celery==0.3 # via edx-lint -pylint-django==2.5.4 +pylint-django==2.5.5 # via edx-lint pylint-plugin-utils==0.8.2 # via @@ -112,17 +111,13 @@ pynacl==1.5.0 # via # -r requirements/base.txt # pygithub -pytest==7.4.2 +pytest==8.1.1 # via # -r requirements/testing.in # pytest-cov -pytest-cov==4.1.0 +pytest-cov==5.0.0 # via -r requirements/testing.in -python-dateutil==2.8.2 - # via - # -r requirements/base.txt - # pygithub -python-slugify==8.0.1 +python-slugify==8.0.4 # via code-annotations pyyaml==6.0.1 # via code-annotations @@ -131,17 +126,14 @@ requests==2.31.0 # -r requirements/base.txt # pygithub six==1.16.0 - # via - # -r requirements/base.txt - # edx-lint - # python-dateutil + # via edx-lint smmap==5.0.1 # via # -r requirements/base.txt # gitdb -stevedore==5.1.0 +stevedore==5.2.0 # via code-annotations -testfixtures==7.2.2 +testfixtures==8.1.0 # via -r requirements/testing.in text-unidecode==1.3 # via python-slugify @@ -150,20 +142,20 @@ tomli==2.0.1 # coverage # pylint # pytest -tomlkit==0.12.1 +tomlkit==0.12.4 # via pylint -typing-extensions==4.8.0 +typing-extensions==4.11.0 # via # -r requirements/base.txt # astroid # pygithub # pylint -urllib3==2.0.7 +urllib3==2.2.1 # via # -r requirements/base.txt # pygithub # requests -wrapt==1.15.0 +wrapt==1.16.0 # via # -r requirements/base.txt # deprecated diff --git a/tox.ini b/tox.ini index ba9d4704..c6153a48 100644 --- a/tox.ini +++ b/tox.ini @@ -1,48 +1,31 @@ [tox] -envlist = py{38,311} +envlist = py{38, 311} skipsdist = True [doc8] max-line-length = 120 [pycodestyle] -; E722 = do not use bare 'except' -; W504 = line break after binary operator exclude = .git,.tox,migrations ignore = E722,W504 max-line-length = 120 [pydocstyle] -; D101 = Missing docstring in public class -; D200 = One-line docstring should fit on one line with quotes -; D203 = 1 blank line required before class docstring -; D212 = Multi-line docstring summary should start at the first line -; D215 = Section underline is over-indented (numpy style) -; D404 = First word of the docstring should not be This (numpy style) -; D405 = Section name should be properly capitalized (numpy style) -; D406 = Section name should end with a newline (numpy style) -; D407 = Missing dashed underline after section (numpy style) -; D408 = Section underline should be in the line following the section’s name (numpy style) -; D409 = Section underline should match the length of its name (numpy style) -; D410 = Missing blank line after section (numpy style) -; D411 = Missing blank line before section (numpy style) -; D412 = No blank lines allowed between a section header and its content (numpy style) -; D413 = Missing blank line after last section (numpy style) -; D414 = Section has no content (numpy style) ignore = D101,D200,D203,D212,D215,D404,D405,D406,D407,D408,D409,D410,D411,D412,D413,D414 [pytest] norecursedirs = .* requirements [testenv] -deps = - -r{toxinidir}/requirements/testing.txt -allowlist_externals = - make -commands = - make clean - pycodestyle . - pylint jenkins - isort --check-only --diff jenkins - make selfcheck - pytest --cov-report term-missing --cov=jenkins jenkins +deps = + -r{toxinidir}/requirements/testing.txt +allowlist_externals = + make +commands = + make clean + pycodestyle . + pylint jenkins + isort --check-only --diff jenkins + make selfcheck + pytest --cov-report term-missing --cov=jenkins jenkins +