diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index f8d4d585..8d873560 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -15,7 +15,7 @@ jobs: strategy: matrix: os: [ 'ubuntu-20.04' ] - python-version: ['3.8', '3.11', '3.12'] + python-version: ['3.11', '3.12'] toxenv: [ 'django42' ] # Only run these other workflows on the latest python version we support. include: @@ -48,7 +48,7 @@ jobs: run: tox - name: Run Coverage - if: matrix.python-version == '3.8' && matrix.toxenv=='django42' + if: matrix.python-version == '3.11' && matrix.toxenv=='django42' uses: codecov/codecov-action@v4 with: flags: unittests diff --git a/.github/workflows/publish_pypi.yml b/.github/workflows/publish_pypi.yml index a47eb5a3..968584c5 100644 --- a/.github/workflows/publish_pypi.yml +++ b/.github/workflows/publish_pypi.yml @@ -16,7 +16,7 @@ jobs: - name: setup python uses: actions/setup-python@v5 with: - python-version: 3.8 + python-version: 3.11 - name: Install pip run: pip install -r requirements/pip.txt diff --git a/.readthedocs.yaml b/.readthedocs.yaml index 363472a3..790103ad 100644 --- a/.readthedocs.yaml +++ b/.readthedocs.yaml @@ -13,7 +13,7 @@ sphinx: build: os: "ubuntu-22.04" tools: - python: "3.8" + python: "3.11" python: install: diff --git a/event_routing_backends/processors/xapi/event_transformers/navigation_events.py b/event_routing_backends/processors/xapi/event_transformers/navigation_events.py index 731d2ec9..d0460041 100644 --- a/event_routing_backends/processors/xapi/event_transformers/navigation_events.py +++ b/event_routing_backends/processors/xapi/event_transformers/navigation_events.py @@ -67,8 +67,8 @@ def get_object(self): ) -@ XApiTransformersRegistry.register('edx.ui.lms.sequence.outline.selected') -@ XApiTransformersRegistry.register('edx.ui.lms.outline.selected') +@XApiTransformersRegistry.register('edx.ui.lms.sequence.outline.selected') +@XApiTransformersRegistry.register('edx.ui.lms.outline.selected') class OutlineSelectedTransformer(NavigationTransformersMixin): """ xAPI transformer for Navigation events. @@ -91,9 +91,9 @@ def get_object(self): ) -@ XApiTransformersRegistry.register('edx.ui.lms.sequence.next_selected') -@ XApiTransformersRegistry.register('edx.ui.lms.sequence.previous_selected') -@ XApiTransformersRegistry.register('edx.ui.lms.sequence.tab_selected') +@XApiTransformersRegistry.register('edx.ui.lms.sequence.next_selected') +@XApiTransformersRegistry.register('edx.ui.lms.sequence.previous_selected') +@XApiTransformersRegistry.register('edx.ui.lms.sequence.tab_selected') class TabNavigationTransformer(NavigationTransformersMixin): """ xAPI transformer for Navigation events. diff --git a/requirements/base.txt b/requirements/base.txt index b0ecba75..d3dca529 100644 --- a/requirements/base.txt +++ b/requirements/base.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade @@ -12,26 +12,17 @@ apache-libcloud==3.8.0 # via -r requirements/base.in asgiref==3.8.1 # via django -async-timeout==4.0.3 - # via redis -attrs==23.2.0 +attrs==24.2.0 # via openedx-events -backports-zoneinfo[tzdata]==0.2.1 ; python_version < "3.9" - # via - # -c requirements/constraints.txt - # celery - # django - # djangorestframework - # kombu billiard==4.2.0 # via celery celery==5.4.0 # via # edx-celeryutils # event-tracking -certifi==2024.6.2 +certifi==2024.7.4 # via requests -cffi==1.16.0 +cffi==1.17.0 # via # cryptography # pynacl @@ -53,9 +44,9 @@ click-repl==0.3.0 # via celery code-annotations==1.8.0 # via edx-toggles -cryptography==42.0.8 +cryptography==43.0.0 # via django-fernet-fields-v2 -django==4.2.13 +django==4.2.15 # via # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/base.in @@ -89,19 +80,19 @@ django-waffle==4.1.0 # via # edx-django-utils # edx-toggles -djangorestframework==3.15.1 +djangorestframework==3.15.2 # via django-config-models edx-ccx-keys==1.3.0 # via openedx-events edx-celeryutils==1.3.0 # via -r requirements/base.in -edx-django-utils==5.14.2 +edx-django-utils==5.15.0 # via # django-config-models # edx-toggles # event-tracking # openedx-events -edx-opaque-keys[django]==2.9.0 +edx-opaque-keys[django]==2.10.0 # via # edx-ccx-keys # openedx-events @@ -111,13 +102,13 @@ edx-toggles==5.2.0 # event-tracking event-tracking==2.4.0 # via - # -c requirements/constraints.txt + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/base.in -fastavro==1.9.4 +fastavro==1.9.5 # via openedx-events fasteners==0.19 # via -r requirements/base.in -idna==3.7 +idna==3.8 # via requests isodate==0.6.1 # via -r requirements/base.in @@ -127,21 +118,21 @@ jsonfield==3.1.0 # via # -r requirements/base.in # edx-celeryutils -kombu==5.3.7 +kombu==5.4.0 # via celery markupsafe==2.1.5 # via jinja2 -newrelic==9.10.0 +newrelic==9.13.0 # via edx-django-utils -openedx-events==9.10.0 +openedx-events==9.12.0 # via event-tracking -openedx-filters==1.8.1 +openedx-filters==1.9.0 # via -r requirements/base.in -pbr==6.0.0 +pbr==6.1.0 # via stevedore -prompt-toolkit==3.0.46 +prompt-toolkit==3.0.47 # via click-repl -psutil==5.9.8 +psutil==6.0.0 # via edx-django-utils pycparser==2.22 # via cffi @@ -162,9 +153,9 @@ pytz==2024.1 # -r requirements/base.in # event-tracking # tincan -pyyaml==6.0.1 +pyyaml==6.0.2 # via code-annotations -redis==5.0.4 +redis==5.0.8 # via django-redis requests==2.32.3 # via @@ -176,9 +167,9 @@ six==1.16.0 # event-tracking # isodate # python-dateutil -sqlparse==0.5.0 +sqlparse==0.5.1 # via django -stevedore==5.2.0 +stevedore==5.3.0 # via # code-annotations # edx-django-utils @@ -187,16 +178,11 @@ text-unidecode==1.3 # via python-slugify tincan==1.0.0 # via -r requirements/base.in -typing-extensions==4.12.1 - # via - # asgiref - # edx-opaque-keys - # kombu +typing-extensions==4.12.2 + # via edx-opaque-keys tzdata==2024.1 - # via - # backports-zoneinfo - # celery -urllib3==2.2.1 + # via celery +urllib3==2.2.2 # via requests vine==5.1.0 # via diff --git a/requirements/ci.txt b/requirements/ci.txt index 0008d40b..e39ed77c 100644 --- a/requirements/ci.txt +++ b/requirements/ci.txt @@ -1,10 +1,10 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade # -cachetools==5.3.3 +cachetools==5.5.0 # via tox chardet==5.2.0 # via tox @@ -12,11 +12,11 @@ colorama==0.4.6 # via tox distlib==0.3.8 # via virtualenv -filelock==3.14.0 +filelock==3.15.4 # via # tox # virtualenv -packaging==24.0 +packaging==24.1 # via # pyproject-api # tox @@ -26,13 +26,9 @@ platformdirs==4.2.2 # virtualenv pluggy==1.5.0 # via tox -pyproject-api==1.6.1 +pyproject-api==1.7.1 # via tox -tomli==2.0.1 - # via - # pyproject-api - # tox -tox==4.15.0 +tox==4.18.0 # via -r requirements/ci.in -virtualenv==20.26.2 +virtualenv==20.26.3 # via tox diff --git a/requirements/constraints.txt b/requirements/constraints.txt index c072cd86..d91704bb 100644 --- a/requirements/constraints.txt +++ b/requirements/constraints.txt @@ -10,19 +10,3 @@ # Common constraints for edx repos -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt - -# diff-cover latest requires (pluggy>=0.13.1,<0.14.0) -# which conflicts with pytest(pluggy>=0.12,<2.0.0) and tox(pluggy>0.12) both of these fetch pluggy==1.0.0 -# but diff-cover latest has a pin (pluggy<1.0.0a1) -# Using the same version of diff-cover which is being used currently in edx-platform to avoid this conflict. -diff-cover==4.0.0 - -# greater version failing docs build -sphinx==4.2.0 -# Sphinx requires docutils<0.18 && doc8<1.0.0 -# This pin can be removed once sphinx constraint is removed. -docutils<0.18 -doc8<1.0.0 -event-tracking>=2.3.2 -# it is not availablein python3.9 -backports.zoneinfo;python_version<"3.9" diff --git a/requirements/dev.txt b/requirements/dev.txt index 6d42eb1f..b7df87ba 100644 --- a/requirements/dev.txt +++ b/requirements/dev.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade @@ -18,27 +18,15 @@ asgiref==3.8.1 # via # -r requirements/quality.txt # django -astroid==3.2.2 +astroid==3.2.4 # via # -r requirements/quality.txt # pylint # pylint-celery -async-timeout==4.0.3 - # via - # -r requirements/quality.txt - # redis -attrs==23.2.0 +attrs==24.2.0 # via # -r requirements/quality.txt # openedx-events -backports-zoneinfo[tzdata]==0.2.1 ; python_version < "3.9" - # via - # -c requirements/constraints.txt - # -r requirements/quality.txt - # celery - # django - # djangorestframework - # kombu billiard==4.2.0 # via # -r requirements/quality.txt @@ -47,7 +35,7 @@ build==1.2.1 # via # -r requirements/pip-tools.txt # pip-tools -cachetools==5.3.3 +cachetools==5.5.0 # via # -r requirements/ci.txt # tox @@ -56,11 +44,11 @@ celery==5.4.0 # -r requirements/quality.txt # edx-celeryutils # event-tracking -certifi==2024.6.2 +certifi==2024.7.4 # via # -r requirements/quality.txt # requests -cffi==1.16.0 +cffi==1.17.0 # via # -r requirements/quality.txt # cryptography @@ -68,6 +56,7 @@ cffi==1.16.0 chardet==5.2.0 # via # -r requirements/ci.txt + # diff-cover # tox charset-normalizer==3.3.2 # via @@ -111,20 +100,18 @@ colorama==0.4.6 # via # -r requirements/ci.txt # tox -coverage[toml]==7.5.3 +coverage[toml]==7.6.1 # via # -r requirements/quality.txt # pytest-cov -cryptography==42.0.8 +cryptography==43.0.0 # via # -r requirements/quality.txt # django-fernet-fields-v2 ddt==1.7.2 # via -r requirements/quality.txt -diff-cover==4.0.0 - # via - # -c requirements/constraints.txt - # -r requirements/dev.in +diff-cover==9.1.1 + # via -r requirements/dev.in dill==0.3.8 # via # -r requirements/quality.txt @@ -133,7 +120,7 @@ distlib==0.3.8 # via # -r requirements/ci.txt # virtualenv -django==4.2.13 +django==4.2.15 # via # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/quality.txt @@ -172,7 +159,7 @@ django-waffle==4.1.0 # -r requirements/quality.txt # edx-django-utils # edx-toggles -djangorestframework==3.15.1 +djangorestframework==3.15.2 # via # -r requirements/quality.txt # django-config-models @@ -182,18 +169,18 @@ edx-ccx-keys==1.3.0 # openedx-events edx-celeryutils==1.3.0 # via -r requirements/quality.txt -edx-django-utils==5.14.2 +edx-django-utils==5.15.0 # via # -r requirements/quality.txt # django-config-models # edx-toggles # event-tracking # openedx-events -edx-i18n-tools==1.6.0 +edx-i18n-tools==1.6.2 # via -r requirements/dev.in -edx-lint==5.3.6 +edx-lint==5.4.0 # via -r requirements/quality.txt -edx-opaque-keys[django]==2.9.0 +edx-opaque-keys[django]==2.10.0 # via # -r requirements/quality.txt # edx-ccx-keys @@ -204,41 +191,29 @@ edx-toggles==5.2.0 # event-tracking event-tracking==2.4.0 # via - # -c requirements/constraints.txt - # -r requirements/quality.txt -exceptiongroup==1.2.1 - # via + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/quality.txt - # pytest -factory-boy==3.3.0 +factory-boy==3.3.1 # via -r requirements/quality.txt -faker==25.5.0 +faker==28.0.0 # via # -r requirements/quality.txt # factory-boy -fastavro==1.9.4 +fastavro==1.9.5 # via # -r requirements/quality.txt # openedx-events fasteners==0.19 # via -r requirements/quality.txt -filelock==3.14.0 +filelock==3.15.4 # via # -r requirements/ci.txt # tox # virtualenv -idna==3.7 +idna==3.8 # via # -r requirements/quality.txt # requests -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 - # typeguard -inflect==7.2.1 - # via jinja2-pluralize iniconfig==2.0.0 # via # -r requirements/quality.txt @@ -254,23 +229,16 @@ jinja2==3.1.4 # -r requirements/quality.txt # code-annotations # diff-cover - # jinja2-pluralize -jinja2-pluralize==0.3.0 - # via diff-cover jsonfield==3.1.0 # via # -r requirements/quality.txt # edx-celeryutils -kombu==5.3.7 +kombu==5.4.0 # via # -r requirements/quality.txt # celery -lxml[html-clean,html_clean]==5.2.2 - # via - # edx-i18n-tools - # lxml-html-clean -lxml-html-clean==0.1.1 - # via lxml +lxml==5.3.0 + # via edx-i18n-tools markupsafe==2.1.5 # via # -r requirements/quality.txt @@ -281,19 +249,17 @@ mccabe==0.7.0 # pylint mock==5.1.0 # via -r requirements/quality.txt -more-itertools==10.2.0 - # via inflect -newrelic==9.10.0 +newrelic==9.13.0 # via # -r requirements/quality.txt # edx-django-utils -openedx-events==9.10.0 +openedx-events==9.12.0 # via # -r requirements/quality.txt # event-tracking -openedx-filters==1.8.1 +openedx-filters==1.9.0 # via -r requirements/quality.txt -packaging==24.0 +packaging==24.1 # via # -r requirements/ci.txt # -r requirements/pip-tools.txt @@ -302,9 +268,9 @@ packaging==24.0 # pyproject-api # pytest # tox -path==16.14.0 +path==16.16.0 # via edx-i18n-tools -pbr==6.0.0 +pbr==6.1.0 # via # -r requirements/quality.txt # stevedore @@ -326,15 +292,15 @@ pluggy==1.5.0 # tox polib==1.2.0 # via edx-i18n-tools -prompt-toolkit==3.0.46 +prompt-toolkit==3.0.47 # via # -r requirements/quality.txt # click-repl -psutil==5.9.8 +psutil==6.0.0 # via # -r requirements/quality.txt # edx-django-utils -pycodestyle==2.11.1 +pycodestyle==2.12.1 # via -r requirements/quality.txt pycparser==2.22 # via @@ -344,7 +310,7 @@ pydocstyle==6.3.0 # via -r requirements/quality.txt pygments==2.18.0 # via diff-cover -pylint==3.2.2 +pylint==3.2.6 # via # -r requirements/quality.txt # edx-lint @@ -373,7 +339,7 @@ pynacl==1.5.0 # via # -r requirements/quality.txt # edx-django-utils -pyproject-api==1.6.1 +pyproject-api==1.7.1 # via # -r requirements/ci.txt # tox @@ -382,7 +348,7 @@ pyproject-hooks==1.1.0 # -r requirements/pip-tools.txt # build # pip-tools -pytest==8.2.2 +pytest==8.3.2 # via # -r requirements/quality.txt # pytest-cov @@ -405,12 +371,12 @@ pytz==2024.1 # -r requirements/quality.txt # event-tracking # tincan -pyyaml==6.0.1 +pyyaml==6.0.2 # via # -r requirements/quality.txt # code-annotations # edx-i18n-tools -redis==5.0.4 +redis==5.0.8 # via # -r requirements/quality.txt # django-redis @@ -430,11 +396,11 @@ snowballstemmer==2.2.0 # via # -r requirements/quality.txt # pydocstyle -sqlparse==0.5.0 +sqlparse==0.5.1 # via # -r requirements/quality.txt # django -stevedore==5.2.0 +stevedore==5.3.0 # via # -r requirements/quality.txt # code-annotations @@ -446,42 +412,21 @@ text-unidecode==1.3 # python-slugify tincan==1.0.0 # via -r requirements/quality.txt -tomli==2.0.1 - # via - # -r requirements/ci.txt - # -r requirements/pip-tools.txt - # -r requirements/quality.txt - # build - # coverage - # pip-tools - # pylint - # pyproject-api - # pytest - # tox -tomlkit==0.12.5 +tomlkit==0.13.2 # via # -r requirements/quality.txt # pylint -tox==4.15.0 +tox==4.18.0 # via -r requirements/ci.txt -typeguard==4.3.0 - # via inflect -typing-extensions==4.12.1 +typing-extensions==4.12.2 # via # -r requirements/quality.txt - # asgiref - # astroid # edx-opaque-keys - # inflect - # kombu - # pylint - # typeguard tzdata==2024.1 # via # -r requirements/quality.txt - # backports-zoneinfo # celery -urllib3==2.2.1 +urllib3==2.2.2 # via # -r requirements/quality.txt # requests @@ -491,7 +436,7 @@ vine==5.1.0 # amqp # celery # kombu -virtualenv==20.26.2 +virtualenv==20.26.3 # via # -r requirements/ci.txt # tox @@ -499,15 +444,11 @@ wcwidth==0.2.13 # via # -r requirements/quality.txt # prompt-toolkit -wheel==0.43.0 +wheel==0.44.0 # via # -r requirements/pip-tools.txt # -r requirements/quality.txt # pip-tools -zipp==3.19.2 - # via - # -r requirements/pip-tools.txt - # importlib-metadata # The following packages are considered to be unsafe in a requirements file: # pip diff --git a/requirements/doc.txt b/requirements/doc.txt index 915a49e2..e978f665 100644 --- a/requirements/doc.txt +++ b/requirements/doc.txt @@ -1,12 +1,12 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade # -accessible-pygments==0.0.4 +accessible-pygments==0.0.5 # via pydata-sphinx-theme -alabaster==0.7.13 +alabaster==1.0.0 # via sphinx amqp==5.2.0 # via @@ -22,28 +22,16 @@ asgiref==3.8.1 # via # -r requirements/test.txt # django -async-timeout==4.0.3 - # via - # -r requirements/test.txt - # redis -attrs==23.2.0 +attrs==24.2.0 # via # -r requirements/test.txt # openedx-events -babel==2.15.0 +babel==2.16.0 # via # pydata-sphinx-theme # sphinx backports-tarfile==1.2.0 # via jaraco-context -backports-zoneinfo[tzdata]==0.2.1 ; python_version < "3.9" - # via - # -c requirements/constraints.txt - # -r requirements/test.txt - # celery - # django - # djangorestframework - # kombu beautifulsoup4==4.12.3 # via pydata-sphinx-theme billiard==4.2.0 @@ -57,11 +45,11 @@ celery==5.4.0 # -r requirements/test.txt # edx-celeryutils # event-tracking -certifi==2024.6.2 +certifi==2024.7.4 # via # -r requirements/test.txt # requests -cffi==1.16.0 +cffi==1.17.0 # via # -r requirements/test.txt # cryptography @@ -95,18 +83,17 @@ code-annotations==1.8.0 # via # -r requirements/test.txt # edx-toggles -coverage[toml]==7.5.3 +coverage[toml]==7.6.1 # via # -r requirements/test.txt # pytest-cov -cryptography==42.0.8 +cryptography==43.0.0 # via # -r requirements/test.txt # django-fernet-fields-v2 - # secretstorage ddt==1.7.2 # via -r requirements/test.txt -django==4.2.13 +django==4.2.15 # via # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/test.txt @@ -144,17 +131,14 @@ django-waffle==4.1.0 # -r requirements/test.txt # edx-django-utils # edx-toggles -djangorestframework==3.15.1 +djangorestframework==3.15.2 # via # -r requirements/test.txt # django-config-models -doc8==0.11.2 - # via - # -c requirements/constraints.txt - # -r requirements/doc.in -docutils==0.17.1 +doc8==1.1.1 + # via -r requirements/doc.in +docutils==0.20.1 # via - # -c requirements/constraints.txt # doc8 # pydata-sphinx-theme # readme-renderer @@ -166,14 +150,14 @@ edx-ccx-keys==1.3.0 # openedx-events edx-celeryutils==1.3.0 # via -r requirements/test.txt -edx-django-utils==5.14.2 +edx-django-utils==5.15.0 # via # -r requirements/test.txt # django-config-models # edx-toggles # event-tracking # openedx-events -edx-opaque-keys[django]==2.9.0 +edx-opaque-keys[django]==2.10.0 # via # -r requirements/test.txt # edx-ccx-keys @@ -184,38 +168,30 @@ edx-toggles==5.2.0 # event-tracking event-tracking==2.4.0 # via - # -c requirements/constraints.txt - # -r requirements/test.txt -exceptiongroup==1.2.1 - # via + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/test.txt - # pytest -factory-boy==3.3.0 +factory-boy==3.3.1 # via -r requirements/test.txt -faker==25.5.0 +faker==28.0.0 # via # -r requirements/test.txt # factory-boy -fastavro==1.9.4 +fastavro==1.9.5 # via # -r requirements/test.txt # openedx-events fasteners==0.19 # via -r requirements/test.txt -idna==3.7 +idna==3.8 # via # -r requirements/test.txt # requests imagesize==1.4.1 # via sphinx -importlib-metadata==6.11.0 +importlib-metadata==8.4.0 # via - # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt - # build # keyring # twine -importlib-resources==6.4.0 - # via keyring iniconfig==2.0.0 # via # -r requirements/test.txt @@ -224,14 +200,10 @@ isodate==0.6.1 # via -r requirements/test.txt jaraco-classes==3.4.0 # via keyring -jaraco-context==5.3.0 +jaraco-context==6.0.1 # via keyring -jaraco-functools==4.0.1 +jaraco-functools==4.0.2 # via keyring -jeepney==0.8.0 - # via - # keyring - # secretstorage jinja2==3.1.4 # via # -r requirements/test.txt @@ -241,9 +213,9 @@ jsonfield==3.1.0 # via # -r requirements/test.txt # edx-celeryutils -keyring==25.2.1 +keyring==25.3.0 # via twine -kombu==5.3.7 +kombu==5.4.0 # via # -r requirements/test.txt # celery @@ -257,44 +229,44 @@ mdurl==0.1.2 # via markdown-it-py mock==5.1.0 # via -r requirements/test.txt -more-itertools==10.2.0 +more-itertools==10.4.0 # via # jaraco-classes # jaraco-functools -newrelic==9.10.0 +newrelic==9.13.0 # via # -r requirements/test.txt # edx-django-utils -nh3==0.2.17 +nh3==0.2.18 # via readme-renderer -openedx-events==9.10.0 +openedx-events==9.12.0 # via # -r requirements/test.txt # event-tracking -openedx-filters==1.8.1 +openedx-filters==1.9.0 # via -r requirements/test.txt -packaging==24.0 +packaging==24.1 # via # -r requirements/test.txt # build # pydata-sphinx-theme # pytest # sphinx -pbr==6.0.0 +pbr==6.1.0 # via # -r requirements/test.txt # stevedore -pkginfo==1.11.0 +pkginfo==1.10.0 # via twine pluggy==1.5.0 # via # -r requirements/test.txt # pytest -prompt-toolkit==3.0.46 +prompt-toolkit==3.0.47 # via # -r requirements/test.txt # click-repl -psutil==5.9.8 +psutil==6.0.0 # via # -r requirements/test.txt # edx-django-utils @@ -302,7 +274,7 @@ pycparser==2.22 # via # -r requirements/test.txt # cffi -pydata-sphinx-theme==0.13.3 +pydata-sphinx-theme==0.15.4 # via sphinx-book-theme pygments==2.18.0 # via @@ -323,7 +295,7 @@ pynacl==1.5.0 # edx-django-utils pyproject-hooks==1.1.0 # via build -pytest==8.2.2 +pytest==8.3.2 # via # -r requirements/test.txt # pytest-cov @@ -344,16 +316,15 @@ python-slugify==8.0.4 pytz==2024.1 # via # -r requirements/test.txt - # babel # event-tracking # tincan -pyyaml==6.0.1 +pyyaml==6.0.2 # via # -r requirements/test.txt # code-annotations readme-renderer==43.0 # via twine -redis==5.0.4 +redis==5.0.8 # via # -r requirements/test.txt # django-redis @@ -370,10 +341,8 @@ restructuredtext-lint==1.4.0 # via doc8 rfc3986==2.0.0 # via twine -rich==13.7.1 +rich==13.8.0 # via twine -secretstorage==3.3.3 - # via keyring six==1.16.0 # via # -r requirements/test.txt @@ -383,33 +352,32 @@ six==1.16.0 # python-dateutil snowballstemmer==2.2.0 # via sphinx -soupsieve==2.5 +soupsieve==2.6 # via beautifulsoup4 -sphinx==4.2.0 +sphinx==8.0.2 # via - # -c requirements/constraints.txt # -r requirements/doc.in # pydata-sphinx-theme # sphinx-book-theme -sphinx-book-theme==1.0.1 +sphinx-book-theme==1.1.3 # via -r requirements/doc.in -sphinxcontrib-applehelp==1.0.4 +sphinxcontrib-applehelp==2.0.0 # via sphinx -sphinxcontrib-devhelp==1.0.2 +sphinxcontrib-devhelp==2.0.0 # via sphinx -sphinxcontrib-htmlhelp==2.0.1 +sphinxcontrib-htmlhelp==2.1.0 # via sphinx sphinxcontrib-jsmath==1.0.1 # via sphinx -sphinxcontrib-qthelp==1.0.3 +sphinxcontrib-qthelp==2.0.0 # via sphinx -sphinxcontrib-serializinghtml==1.1.5 +sphinxcontrib-serializinghtml==2.0.0 # via sphinx -sqlparse==0.5.0 +sqlparse==0.5.1 # via # -r requirements/test.txt # django -stevedore==5.2.0 +stevedore==5.3.0 # via # -r requirements/test.txt # code-annotations @@ -422,28 +390,18 @@ text-unidecode==1.3 # python-slugify tincan==1.0.0 # via -r requirements/test.txt -tomli==2.0.1 - # via - # -r requirements/test.txt - # build - # coverage - # pytest -twine==5.1.0 +twine==5.1.1 # via -r requirements/doc.in -typing-extensions==4.12.1 +typing-extensions==4.12.2 # via # -r requirements/test.txt - # asgiref # edx-opaque-keys - # kombu # pydata-sphinx-theme - # rich tzdata==2024.1 # via # -r requirements/test.txt - # backports-zoneinfo # celery -urllib3==2.2.1 +urllib3==2.2.2 # via # -r requirements/test.txt # requests @@ -458,10 +416,5 @@ wcwidth==0.2.13 # via # -r requirements/test.txt # prompt-toolkit -zipp==3.19.2 - # via - # importlib-metadata - # importlib-resources - -# The following packages are considered to be unsafe in a requirements file: -# setuptools +zipp==3.20.1 + # via importlib-metadata diff --git a/requirements/pip-tools.txt b/requirements/pip-tools.txt index 186a075b..fedf88df 100644 --- a/requirements/pip-tools.txt +++ b/requirements/pip-tools.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade @@ -8,11 +8,7 @@ build==1.2.1 # via pip-tools click==8.1.7 # via pip-tools -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 +packaging==24.1 # via build pip-tools==7.4.1 # via -r requirements/pip-tools.in @@ -20,14 +16,8 @@ pyproject-hooks==1.1.0 # via # build # pip-tools -tomli==2.0.1 - # via - # build - # pip-tools -wheel==0.43.0 +wheel==0.44.0 # via pip-tools -zipp==3.19.2 - # via importlib-metadata # The following packages are considered to be unsafe in a requirements file: # pip diff --git a/requirements/pip.txt b/requirements/pip.txt index 8a72bb0b..92563d4f 100644 --- a/requirements/pip.txt +++ b/requirements/pip.txt @@ -1,14 +1,14 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade # -wheel==0.43.0 +wheel==0.44.0 # via -r requirements/pip.in # The following packages are considered to be unsafe in a requirements file: -pip==24.0 +pip==24.2 # via -r requirements/pip.in -setuptools==70.0.0 +setuptools==74.0.0 # via -r requirements/pip.in diff --git a/requirements/quality.txt b/requirements/quality.txt index 35338d17..18a3868e 100644 --- a/requirements/quality.txt +++ b/requirements/quality.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade @@ -18,26 +18,14 @@ asgiref==3.8.1 # via # -r requirements/test.txt # django -astroid==3.2.2 +astroid==3.2.4 # via # pylint # pylint-celery -async-timeout==4.0.3 - # via - # -r requirements/test.txt - # redis -attrs==23.2.0 +attrs==24.2.0 # via # -r requirements/test.txt # openedx-events -backports-zoneinfo[tzdata]==0.2.1 ; python_version < "3.9" - # via - # -c requirements/constraints.txt - # -r requirements/test.txt - # celery - # django - # djangorestframework - # kombu billiard==4.2.0 # via # -r requirements/test.txt @@ -47,11 +35,11 @@ celery==5.4.0 # -r requirements/test.txt # edx-celeryutils # event-tracking -certifi==2024.6.2 +certifi==2024.7.4 # via # -r requirements/test.txt # requests -cffi==1.16.0 +cffi==1.17.0 # via # -r requirements/test.txt # cryptography @@ -90,11 +78,11 @@ code-annotations==1.8.0 # -r requirements/test.txt # edx-lint # edx-toggles -coverage[toml]==7.5.3 +coverage[toml]==7.6.1 # via # -r requirements/test.txt # pytest-cov -cryptography==42.0.8 +cryptography==43.0.0 # via # -r requirements/test.txt # django-fernet-fields-v2 @@ -102,7 +90,7 @@ ddt==1.7.2 # via -r requirements/test.txt dill==0.3.8 # via pylint -django==4.2.13 +django==4.2.15 # via # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/test.txt @@ -140,7 +128,7 @@ django-waffle==4.1.0 # -r requirements/test.txt # edx-django-utils # edx-toggles -djangorestframework==3.15.1 +djangorestframework==3.15.2 # via # -r requirements/test.txt # django-config-models @@ -150,16 +138,16 @@ edx-ccx-keys==1.3.0 # openedx-events edx-celeryutils==1.3.0 # via -r requirements/test.txt -edx-django-utils==5.14.2 +edx-django-utils==5.15.0 # via # -r requirements/test.txt # django-config-models # edx-toggles # event-tracking # openedx-events -edx-lint==5.3.6 +edx-lint==5.4.0 # via -r requirements/quality.in -edx-opaque-keys[django]==2.9.0 +edx-opaque-keys[django]==2.10.0 # via # -r requirements/test.txt # edx-ccx-keys @@ -170,25 +158,21 @@ edx-toggles==5.2.0 # event-tracking event-tracking==2.4.0 # via - # -c requirements/constraints.txt - # -r requirements/test.txt -exceptiongroup==1.2.1 - # via + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/test.txt - # pytest -factory-boy==3.3.0 +factory-boy==3.3.1 # via -r requirements/test.txt -faker==25.5.0 +faker==28.0.0 # via # -r requirements/test.txt # factory-boy -fastavro==1.9.4 +fastavro==1.9.5 # via # -r requirements/test.txt # openedx-events fasteners==0.19 # via -r requirements/test.txt -idna==3.7 +idna==3.8 # via # -r requirements/test.txt # requests @@ -210,7 +194,7 @@ jsonfield==3.1.0 # via # -r requirements/test.txt # edx-celeryutils -kombu==5.3.7 +kombu==5.4.0 # via # -r requirements/test.txt # celery @@ -222,21 +206,21 @@ mccabe==0.7.0 # via pylint mock==5.1.0 # via -r requirements/test.txt -newrelic==9.10.0 +newrelic==9.13.0 # via # -r requirements/test.txt # edx-django-utils -openedx-events==9.10.0 +openedx-events==9.12.0 # via # -r requirements/test.txt # event-tracking -openedx-filters==1.8.1 +openedx-filters==1.9.0 # via -r requirements/test.txt -packaging==24.0 +packaging==24.1 # via # -r requirements/test.txt # pytest -pbr==6.0.0 +pbr==6.1.0 # via # -r requirements/test.txt # stevedore @@ -246,15 +230,15 @@ pluggy==1.5.0 # via # -r requirements/test.txt # pytest -prompt-toolkit==3.0.46 +prompt-toolkit==3.0.47 # via # -r requirements/test.txt # click-repl -psutil==5.9.8 +psutil==6.0.0 # via # -r requirements/test.txt # edx-django-utils -pycodestyle==2.11.1 +pycodestyle==2.12.1 # via -r requirements/quality.in pycparser==2.22 # via @@ -262,7 +246,7 @@ pycparser==2.22 # cffi pydocstyle==6.3.0 # via -r requirements/quality.in -pylint==3.2.2 +pylint==3.2.6 # via # edx-lint # pylint-celery @@ -285,7 +269,7 @@ pynacl==1.5.0 # via # -r requirements/test.txt # edx-django-utils -pytest==8.2.2 +pytest==8.3.2 # via # -r requirements/test.txt # pytest-cov @@ -308,11 +292,11 @@ pytz==2024.1 # -r requirements/test.txt # event-tracking # tincan -pyyaml==6.0.1 +pyyaml==6.0.2 # via # -r requirements/test.txt # code-annotations -redis==5.0.4 +redis==5.0.8 # via # -r requirements/test.txt # django-redis @@ -330,11 +314,11 @@ six==1.16.0 # python-dateutil snowballstemmer==2.2.0 # via pydocstyle -sqlparse==0.5.0 +sqlparse==0.5.1 # via # -r requirements/test.txt # django -stevedore==5.2.0 +stevedore==5.3.0 # via # -r requirements/test.txt # code-annotations @@ -346,28 +330,17 @@ text-unidecode==1.3 # python-slugify tincan==1.0.0 # via -r requirements/test.txt -tomli==2.0.1 - # via - # -r requirements/test.txt - # coverage - # pylint - # pytest -tomlkit==0.12.5 +tomlkit==0.13.2 # via pylint -typing-extensions==4.12.1 +typing-extensions==4.12.2 # via # -r requirements/test.txt - # asgiref - # astroid # edx-opaque-keys - # kombu - # pylint tzdata==2024.1 # via # -r requirements/test.txt - # backports-zoneinfo # celery -urllib3==2.2.1 +urllib3==2.2.2 # via # -r requirements/test.txt # requests @@ -381,9 +354,9 @@ wcwidth==0.2.13 # via # -r requirements/test.txt # prompt-toolkit -wheel==0.43.0 +wheel==0.44.0 # via -r requirements/quality.in # The following packages are considered to be unsafe in a requirements file: -setuptools==70.0.0 +setuptools==74.0.0 # via -r requirements/quality.in diff --git a/requirements/test.txt b/requirements/test.txt index 1f5297bb..221217cf 100644 --- a/requirements/test.txt +++ b/requirements/test.txt @@ -1,5 +1,5 @@ # -# This file is autogenerated by pip-compile with Python 3.8 +# This file is autogenerated by pip-compile with Python 3.11 # by the following command: # # make upgrade @@ -18,22 +18,10 @@ asgiref==3.8.1 # via # -r requirements/base.txt # django -async-timeout==4.0.3 - # via - # -r requirements/base.txt - # redis -attrs==23.2.0 +attrs==24.2.0 # via # -r requirements/base.txt # openedx-events -backports-zoneinfo[tzdata]==0.2.1 ; python_version < "3.9" - # via - # -c requirements/constraints.txt - # -r requirements/base.txt - # celery - # django - # djangorestframework - # kombu billiard==4.2.0 # via # -r requirements/base.txt @@ -43,11 +31,11 @@ celery==5.4.0 # -r requirements/base.txt # edx-celeryutils # event-tracking -certifi==2024.6.2 +certifi==2024.7.4 # via # -r requirements/base.txt # requests -cffi==1.16.0 +cffi==1.17.0 # via # -r requirements/base.txt # cryptography @@ -82,9 +70,9 @@ code-annotations==1.8.0 # -r requirements/base.txt # -r requirements/test.in # edx-toggles -coverage[toml]==7.5.3 +coverage[toml]==7.6.1 # via pytest-cov -cryptography==42.0.8 +cryptography==43.0.0 # via # -r requirements/base.txt # django-fernet-fields-v2 @@ -127,7 +115,7 @@ django-waffle==4.1.0 # -r requirements/base.txt # edx-django-utils # edx-toggles -djangorestframework==3.15.1 +djangorestframework==3.15.2 # via # -r requirements/base.txt # django-config-models @@ -137,14 +125,14 @@ edx-ccx-keys==1.3.0 # openedx-events edx-celeryutils==1.3.0 # via -r requirements/base.txt -edx-django-utils==5.14.2 +edx-django-utils==5.15.0 # via # -r requirements/base.txt # django-config-models # edx-toggles # event-tracking # openedx-events -edx-opaque-keys[django]==2.9.0 +edx-opaque-keys[django]==2.10.0 # via # -r requirements/base.txt # edx-ccx-keys @@ -155,21 +143,19 @@ edx-toggles==5.2.0 # event-tracking event-tracking==2.4.0 # via - # -c requirements/constraints.txt + # -c https://raw.githubusercontent.com/edx/edx-lint/master/edx_lint/files/common_constraints.txt # -r requirements/base.txt -exceptiongroup==1.2.1 - # via pytest -factory-boy==3.3.0 +factory-boy==3.3.1 # via -r requirements/test.in -faker==25.5.0 +faker==28.0.0 # via factory-boy -fastavro==1.9.4 +fastavro==1.9.5 # via # -r requirements/base.txt # openedx-events fasteners==0.19 # via -r requirements/base.txt -idna==3.7 +idna==3.8 # via # -r requirements/base.txt # requests @@ -185,7 +171,7 @@ jsonfield==3.1.0 # via # -r requirements/base.txt # edx-celeryutils -kombu==5.3.7 +kombu==5.4.0 # via # -r requirements/base.txt # celery @@ -195,29 +181,29 @@ markupsafe==2.1.5 # jinja2 mock==5.1.0 # via -r requirements/test.in -newrelic==9.10.0 +newrelic==9.13.0 # via # -r requirements/base.txt # edx-django-utils -openedx-events==9.10.0 +openedx-events==9.12.0 # via # -r requirements/base.txt # event-tracking -openedx-filters==1.8.1 +openedx-filters==1.9.0 # via -r requirements/base.txt -packaging==24.0 +packaging==24.1 # via pytest -pbr==6.0.0 +pbr==6.1.0 # via # -r requirements/base.txt # stevedore pluggy==1.5.0 # via pytest -prompt-toolkit==3.0.46 +prompt-toolkit==3.0.47 # via # -r requirements/base.txt # click-repl -psutil==5.9.8 +psutil==6.0.0 # via # -r requirements/base.txt # edx-django-utils @@ -234,7 +220,7 @@ pynacl==1.5.0 # via # -r requirements/base.txt # edx-django-utils -pytest==8.2.2 +pytest==8.3.2 # via # pytest-cov # pytest-django @@ -256,11 +242,11 @@ pytz==2024.1 # -r requirements/base.txt # event-tracking # tincan -pyyaml==6.0.1 +pyyaml==6.0.2 # via # -r requirements/base.txt # code-annotations -redis==5.0.4 +redis==5.0.8 # via # -r requirements/base.txt # django-redis @@ -275,11 +261,11 @@ six==1.16.0 # event-tracking # isodate # python-dateutil -sqlparse==0.5.0 +sqlparse==0.5.1 # via # -r requirements/base.txt # django -stevedore==5.2.0 +stevedore==5.3.0 # via # -r requirements/base.txt # code-annotations @@ -291,22 +277,15 @@ text-unidecode==1.3 # python-slugify tincan==1.0.0 # via -r requirements/base.txt -tomli==2.0.1 - # via - # coverage - # pytest -typing-extensions==4.12.1 +typing-extensions==4.12.2 # via # -r requirements/base.txt - # asgiref # edx-opaque-keys - # kombu tzdata==2024.1 # via # -r requirements/base.txt - # backports-zoneinfo # celery -urllib3==2.2.1 +urllib3==2.2.2 # via # -r requirements/base.txt # requests diff --git a/setup.py b/setup.py index b04c07bc..4f068d2c 100644 --- a/setup.py +++ b/setup.py @@ -148,7 +148,7 @@ def is_requirement(line): ], include_package_data=True, install_requires=load_requirements('requirements/base.in'), - python_requires=">=3.8", + python_requires=">=3.11", license="AGPL 3.0", zip_safe=False, keywords='Python edx', @@ -160,7 +160,6 @@ def is_requirement(line): 'License :: OSI Approved :: GNU Affero General Public License v3 or later (AGPLv3+)', 'Natural Language :: English', 'Programming Language :: Python :: 3', - 'Programming Language :: Python :: 3.8', 'Programming Language :: Python :: 3.11', 'Programming Language :: Python :: 3.12', ], diff --git a/tox.ini b/tox.ini index 40d90f26..1903935c 100644 --- a/tox.ini +++ b/tox.ini @@ -1,5 +1,5 @@ [tox] -envlist = py{38,311,312}-django{42}, quality, docs, pii_check +envlist = py{311,312}-django{42}, quality, docs, pii_check [doc8] ignore = D001