-
Notifications
You must be signed in to change notification settings - Fork 3.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[DEPR]: Paver #34467
Closed
23 tasks done
Labels
depr
Proposal for deprecation & removal per OEP-21
Comments
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Apr 3, 2024
All CI used to go through scripts/generic-ci-tests.sh, which is a wrapper around various `paver` test/linting/check invocations. These days, most edx-platform CI checks just invoke their tools (pylint, pycodestyle, pytest, etc.) directly. In anticipation of the proposed Paver deprecation [1], let's remove the parts of this script that aren't used any more, including several `paver` command invocations. This should have no impact on CI. Furthermore, we are able to remove the SHARD environment variable, which was formely used to split unit and quality checks up into smaller pieces. Unit tests and pylint checks now have their own separate sharding logic, so there is only one "quality" shard remaining (SHARD=4, ie generic quality checks), thus we don't need a SHARD variable at all. [1] openedx#34467
kdmccormick
added a commit
that referenced
this issue
Apr 4, 2024
All CI used to go through scripts/generic-ci-tests.sh, which is a wrapper around various `paver` test/linting/check invocations. These days, most edx-platform CI checks just invoke their tools (pylint, pycodestyle, pytest, etc.) directly. In anticipation of the proposed Paver deprecation [1], let's remove the parts of this script that aren't used any more, including several `paver` command invocations. This should have no impact on CI. Furthermore, we are able to remove the SHARD environment variable, which was formely used to split unit and quality checks up into smaller pieces. Unit tests and pylint checks now have their own separate sharding logic, so there is only one "quality" shard remaining (SHARD=4, ie generic quality checks), thus we don't need a SHARD variable at all. [1] #34467
KyryloKireiev
pushed a commit
to raccoongang/edx-platform
that referenced
this issue
Apr 24, 2024
) All CI used to go through scripts/generic-ci-tests.sh, which is a wrapper around various `paver` test/linting/check invocations. These days, most edx-platform CI checks just invoke their tools (pylint, pycodestyle, pytest, etc.) directly. In anticipation of the proposed Paver deprecation [1], let's remove the parts of this script that aren't used any more, including several `paver` command invocations. This should have no impact on CI. Furthermore, we are able to remove the SHARD environment variable, which was formely used to split unit and quality checks up into smaller pieces. Unit tests and pylint checks now have their own separate sharding logic, so there is only one "quality" shard remaining (SHARD=4, ie generic quality checks), thus we don't need a SHARD variable at all. [1] openedx#34467
7 tasks
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
May 5, 2024
Together, these changes make it so that all features of the Paver-based asset compilation system are supported with drop-in Paver-free replacements. The remaining Paver asset functions are trivial wrappers, which can be comfortably deleted before Sumac * Turn `./manage.py ... compile_sass` into a simple wrapper around `npm run compile-sass` * Turn `paver webpack` into a simple wrapper around `npm run webpack` * Turn `pavelib.assets:collect_assets` into a simple wrapper around `./manage.py ... collectstatic` * Add/improve deprecation warnings for all Paver asset commands. * Load defaults for asset-related Django settings from environment variables. This allows the build to work without Python. For the settings which will be removed in Sumac, I've added deprecation warnings. * Change EDX_PLATFORM_THEME_DIRS env var to COMPREHENSIVE_THEME_DIRS. This simplifies the migration instructions, because all the new env vars now match their corresponding Django settings. This amends an ADR, but it should not be a breaking change because the env var was recently added (since Quince) and nobody should be using it yet. * Future-proof the static assets ADR with links. The linked pages will be kept up-to-date even if the ADR isn't. Part of: openedx#34467
kdmccormick
added a commit
that referenced
this issue
May 6, 2024
Together, these changes make it so that all features of the Paver-based asset compilation system are supported with drop-in Paver-free replacements. The remaining Paver asset functions are trivial wrappers, which can be comfortably deleted before Sumac. * Turn `./manage.py ... compile_sass` into a simple wrapper around `npm run compile-sass` * Turn `paver webpack` into a simple wrapper around `npm run webpack` * Turn `pavelib.assets:collect_assets` into a simple wrapper around `./manage.py ... collectstatic` * Add/improve deprecation warnings for all Paver asset commands. * Load defaults for asset-related Django settings from environment variables. This allows the build to work without Python. For the settings which will be removed in Sumac, I've added deprecation warnings. * Change EDX_PLATFORM_THEME_DIRS env var to COMPREHENSIVE_THEME_DIRS. This simplifies the migration instructions, because all the new env vars now match their corresponding Django settings. This amends an ADR, but it should not be a breaking change because the env var was recently added (since Quince) and nobody should be using it yet. * Future-proof the static assets ADR with links. The linked pages will be kept up-to-date even if the ADR isn't. Part of: #34467
I have updated the Django settings to clarify that we will also be removing the STATIC_ROOT_BASE Django setting. |
Merged
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
May 21, 2024
This is the first step of Paver removal. These are the parts that we are confident are unused. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
May 21, 2024
TODO describe merge timing concerns Part of: openedx#34467
Closed
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
May 21, 2024
This is the first step of Paver removal. These are the parts that we are confident are unused. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
May 21, 2024
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Dec 13, 2024
These packages were installed transitively through paver.in, but they are used as direct dependencies in edx-platform application code: * psutil * pymemcache * wrapt Since we are demoting paver.in to be a dev-only dependency (with plans to remove paver.in entirely), we need to make those three packages explicit dependencies in kernel.in Part of: openedx#34467
kdmccormick
added a commit
to overhangio/tutor
that referenced
this issue
Dec 17, 2024
From the upstream Paver DEPR [1], this accounts for a change in the requirements files: > Starting in Sumac, these dependencies will be removed from > requirements/edx/base.txt. Instead, operators will need to install: > * requirements/edx/assets.txt to build static assets In the future, we could optimize the openedx image build by installing assets.txt in a separate, rarely-invalidated cache layer. libsass in particular takes 60+ seconds to install, so this is promising. However, for now, in order to prepare for [1], we make just the simplest possible change, which is to install assets.txt along with base.txt. We also take this opportunity to bump the nodeenv version from 1.8.0 to 1.9.1, matching edx-platform's. This is another area where we could make use of assets.txt in a future Dockerfile refactoring. [1] openedx/edx-platform#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Dec 17, 2024
BREAKING CHANGE: Removes all remaining Paver commands including `pavelib/prereqs.py:*` and `pavelib/assets.py:*`. BREAKING CHANGE: Removes `./manage.py [lms|cms] compile_sass`, which was just a wrapper around Paver commands. BREAKING CHANGE: Removes paver.txt. Operators should install testing.txt instead. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Dec 17, 2024
There are three packages which edx-platform needs in order to run which were being installed transitively via paver.in. Since we are removing paver.in, these dependencies need to be transferred into kernel.in: * psutil * pymemcache * wrapt Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Dec 17, 2024
BREAKING CHANGE: Removes all remaining Paver commands including `pavelib/prereqs.py:*` and `pavelib/assets.py:*`. BREAKING CHANGE: Removes `./manage.py [lms|cms] compile_sass`, which was just a wrapper around Paver commands. BREAKING CHANGE: Removes paver.txt. Operators should install testing.txt instead. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Dec 17, 2024
There are three packages which edx-platform needs in order to run which were being installed transitively via paver.in. Since we are removing paver.in, these dependencies need to be transferred into kernel.in: * psutil * pymemcache * wrapt Part of: openedx#34467
kdmccormick
added a commit
that referenced
this issue
Dec 18, 2024
This is a record of the various existing CI issues we faced and the trade-offs we made to move forward while replacing the Paver CI commands as part of: #34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
BREAKING CHANGE: Removes all remaining Paver commands including `pavelib/prereqs.py:*` and `pavelib/assets.py:*`. BREAKING CHANGE: Removes `./manage.py [lms|cms] compile_sass`, which was just a wrapper around Paver commands. BREAKING CHANGE: Removes paver.txt. Operators should install testing.txt instead. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
There are three packages which edx-platform needs in order to run which were being installed transitively via paver.in. Since we are removing paver.in, these dependencies need to be transferred into kernel.in: * psutil * pymemcache * wrapt Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
BREAKING CHANGE: Removes all remaining Paver commands including `pavelib/prereqs.py:*` and `pavelib/assets.py:*`. BREAKING CHANGE: Removes `./manage.py [lms|cms] compile_sass`, which was just a wrapper around Paver commands. BREAKING CHANGE: Removes paver.txt. Operators should install testing.txt instead. Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
There are three packages which edx-platform needs in order to run which were being installed transitively via paver.in. Since we are removing paver.in, these dependencies need to be transferred into kernel.in: * psutil * pymemcache * wrapt Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
BREAKING CHANGE: Removes libsass from requirements/edx/base.txt. Operators will need to install requirements/edx/assets.txt in order to compile Sass. Commit generated by workflow `kdmccormick/edx-platform/.github/workflows/compile-python-requirements.yml@refs/heads/master` Part of: openedx#34467
kdmccormick
added a commit
to kdmccormick/edx-platform
that referenced
this issue
Jan 2, 2025
kdmccormick
added a commit
that referenced
this issue
Jan 2, 2025
BREAKING CHANGE: Removes all remaining Paver commands including `pavelib/prereqs.py:*` and `pavelib/assets.py:*`. BREAKING CHANGE: Removes `./manage.py [lms|cms] compile_sass`, which was just a wrapper around Paver commands. BREAKING CHANGE: Removes paver.txt. Operators should install testing.txt instead. Part of: #34467
kdmccormick
added a commit
that referenced
this issue
Jan 2, 2025
There are three packages which edx-platform needs in order to run which were being installed transitively via paver.in. Since we are removing paver.in, these dependencies need to be transferred into kernel.in: * psutil * pymemcache * wrapt Part of: #34467
kdmccormick
added a commit
that referenced
this issue
Jan 2, 2025
BREAKING CHANGE: Removes libsass from requirements/edx/base.txt. Operators will need to install requirements/edx/assets.txt in order to compile Sass. Commit generated by workflow `kdmccormick/edx-platform/.github/workflows/compile-python-requirements.yml@refs/heads/master` Part of: #34467
kdmccormick
added a commit
that referenced
this issue
Jan 2, 2025
The final Paver removal PR has merged into edx-platform. All that's left is some doc updates in other openedx repos, and then we're good to close this. |
kdmccormick
added a commit
to kdmccormick/studio-frontend
that referenced
this issue
Jan 9, 2025
kdmccormick
added a commit
to kdmccormick/studio-frontend
that referenced
this issue
Jan 23, 2025
kdmccormick
added a commit
to kdmccormick/studio-frontend
that referenced
this issue
Jan 23, 2025
kdmccormick
added a commit
to kdmccormick/studio-frontend
that referenced
this issue
Jan 23, 2025
kdmccormick
added a commit
to openedx/studio-frontend
that referenced
this issue
Jan 23, 2025
This has been fully removed. |
github-project-automation
bot
moved this from Removal Pending
to Removed
in DEPR: Deprecation & Removal
Jan 23, 2025
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
ℹ️ This DEPR ticket considers the Paver commands in two groups:
Timeline
Communicated
Operator-facing commands: 2023-03-08 (thread)
Internal CI commands: 2024-05-01 (thread)
Acceptance
Operator-facing commands: 2023-05-03
Internal CI commands: 2024-05-21
Replacement available
Operator-facing commands: 2024-05-07, Redwood
Internal CI commands: ~2024-11-09, early Teak (Target)
Earliest removal
Operator-facing commands: 2024-11-09, early Teak
Internal CI commands: as soon as replacement is available
Rationale
edx-platform historically handled its build scripts with paver:
Using paver has a few problems:
paver
package, this means that we installlibsass-python
in production, which takes 60+ seconds (!) to compile and install.For the Paver Asset commands in particular, more depth is provided in the 'Reimplement edx-platform static asset processing' ADR.
Replacement
pylint
, etc.) when possible, Makefile targets otherwisepip
Migration
To ease migration for Paver users, in Redwood, each Paver Asset command will simply proxy to its replacement command, and will raise a deprecation warning explaining the new command that it is running.
By Nov 9th 2024, operators will need to have switched to the new commands, taking the steps indicated below by ACTION REQUIRED.
Requirements (Operators: ACTION REQUIRED)
In Redwood and earlier, Paver and its dependencies were included in requirements/edx/base.txt
Starting in Sumac, these dependencies will be removed from requirements/edx/base.txt. Instead, operators will need to install:
Operator-facing commands with known users (Operators: ACTION REQUIRED)
These replacements are production-ready as of May 7th, for Redwood.
paver update_assets
npm run build && ./manage.py lms collectstatic --noinput && ./manage.py cms collectstatic
paver process_xmodule_assets
paver compile_sass
npm run compile-sass
./manage.py [lms/cms] compile_sass
npm run compile-sass
paver webpack
npm run webpack
paver watch_assets
npm run watch
paver install_prereqs
pip install -r requirements/edx/base.txt -r requirements/edx/assets.txt && npm clean-install
paver install_node_prereqs
npm clean-install
paver uninstall_python_packages
paver install_coverage_prereqs
pip install -r requirements/edx/coverage.txt
paver install_python_prereqs
pip install -r requirements/edx/base.txt
Operator-facing commands without known users
These commands have been replaced for a long time. We don't know of any users of them, except the old Vagrant Devstack, which was deprecated 8 years ago.
paver build_docs
make docs
paver i18n_validate_gettext
which xgettext
paver i18n_extract
make extract_translations
paver i18n_dummy
i18n_tool dummy && i18n_tool generate
paver i18n_generate
i18n_tool generate
paver i18n_generate_strict
i18n_tool generate --strict
paver i18n_clean
make clean_translations
paver check_settings
paver lms
./manage.py lms runserver
paver studio
./manage.py cms runserver
paver run_all_servers
tutor local ...
paver devstack
tutor dev ...
Internal CI commands
These commands are only used by the upstream openedx project for CI. They will replaced before Sumac. Operators do not need to take action.
paver find_fixme
paver run_eslint
eslint
paver run_stylelint
make stylelint_js
paver run_xsslint
make xsslint
paver run_pii_check
make pii_check
paver check_keywords
make check_keywords
paver run_quality
paver run_pylint
pylint
paver run_pep8
pycodestyle
paver diff_coverage
make diff_coverage_js
paver test_js
make test_js
paver test_js_run
make test_js
paver test_js_dev
make test_js MODE=browser
Django settings for Asset commands (Operators: ACTION REQUIRED)
In order to reimplement the Paver Asset commands without Python/Django, we are changing how several settings are configured.
The following Django settings are becoming read-only mirrors. If you override them now, remove your overrides:
STATIC_ROOT
(a string, loaded fromSTATIC_ROOT_LMS
env var)COMPREHENSIVE_THEME_DIRS
(loaded from the env var, parsed into a list of strings)STATIC_ROOT
(a string, loaded fromSTATIC_ROOT_CMS
env var)COMPREHENSIVE_THEME_DIRS
(loaded from the env var, parsed into a list of strings)The following Django settings are being removed. If you override them now, remove your overrides:
STATIC_ROOT_BASE
WEBPACK_CONFIG_PATH
JS_ENV_EXTRA_CONFIG
STATIC_ROOT_BASE
WEBPACK_CONFIG_PATH
JS_ENV_EXTRA_CONFIG
The following new environment variables are available. Set these in your environment, in place of the overrides you removed above:
STATIC_ROOT_LMS
(path)STATIC_ROOT_CMS
(path)COMPREHENSIVE_THEME_DIRS
(colon-separated paths)WEBPACK_CONFIG_PATH
(path)JS_ENV_EXTRA_CONFIG
(serialized as json)Note: If you previously set the
STATIC_ROOT_BASE
Django setting to/blah
, then you should now set the LMS and CMS environment variables as so:STATIC_ROOT_LMS=/blah
STATIC_ROOT_CMS=/blah/studio
Deprecation
In time for Redwood, deprecation warnings will be added to all edx-platform Paver Asset commands.
Removal
In edx-platform:
Elsewhere in the openedx GitHub org:
In Tutor:
Tasks/PRs
npm run build
(experimental) #32823npm run watch
(experimental) #32866The text was updated successfully, but these errors were encountered: