-
Notifications
You must be signed in to change notification settings - Fork 448
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat!: Rename branches master->release, nightly->main
BREAKING CHANGES: * Change default TUTOR_ROOT folder name from tutor-nightly to tutor-main. * Change default TUTOR_PLUGINS_ROOT folder name from tutor-nightly-plugins to tutor-main-plugins. Note that both the project root and the plugins root will be automatically migrated from the -"nightly" to the "-main" suffix if the destination does not already exist. Other changes: * Update container suffixes from _nightly to _main. * Update "Tutor Nightly" in docs to "Tutor Main". * Update references to "master" and "nightly" branches to "release" and "main", respectively. * Update GitHub links to Tutor's master branch to its release branch. * Update CI to also test main and release branches. TEP: https://discuss.openedx.org/t/tep-rename-nightly-next-and-master-release/12994 GitHub issue: #1096 --------- Co-authored-by: Régis Behmo <[email protected]>
- Loading branch information
1 parent
b169f69
commit a63eeee
Showing
22 changed files
with
141 additions
and
89 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
- 💥[Improvement] Rename Tutor's two branches (by @kdmccormick): | ||
* Rename **master** to **release**, as this branch runs the latest official Open edX release. | ||
* Rename **nightly** to **main**, as this branch runs the Open edX master (a.k.a. main) branches, which are the basis fort the next Open edX release. | ||
* For Tutor Nightly users who do not set a TUTOR_ROOT, both the project root (`~/.local/share/tutor-nightly` on Linux) and the plugins root (`~/.local/share/tutor-nightly-plugins` on Linux) will be automatically renamed. (by @regisb) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
- [Feature] Add the `TUTOR_BRANCH_IS_MAIN` variable to the template context, which is set to True for users running Tutor Main (by @kdmccormick). | ||
- [Bugfix] Use `TUTOR_BRANCH_IS_MAIN` rather than the edx-platform branch name in order to determine which patches to apply. This way, when developers are testing an edx-platform branch that is not master but which may be *based on* master, they will receive master patches rather than release patches, assuming they are running Tutor Main in the first place (by @kdmccormick). |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,64 @@ | ||
.. _main: | ||
|
||
Running Open edX on the master branch ("Tutor Main") | ||
==================================================== | ||
|
||
Tutor was designed to make it easy for everyone to run the latest release of Open edX. But sometimes, you want to run the latest, bleeding-edge version of Open edX. This is what we call "running master", as opposed to running the release branch. Running the master branch in production is strongly **not** recommended unless you are an Open edX expert and you really know what you are doing. But Open edX developers frequently need to run the master branch locally to implement and test new features. Thus, Tutor makes it easy to run Open edX on the master branch: this is called "Tutor Main". | ||
|
||
Installing Tutor Main | ||
--------------------- | ||
|
||
Running Tutor Main requires more than setting a few configuration variables: because there are so many Open edX settings, version numbers, etc. which may change between the latest release and the current master branch, Tutor Main is actually maintained as a separate branch of the Tutor repository. To install Tutor Main, you should install Tutor from the "main" branch of the source repository. To do so, run:: | ||
|
||
git clone --branch=main https://github.com/overhangio/tutor.git | ||
pip install -e "./tutor[full]" | ||
|
||
As usual, it is strongly recommended to run the command above in a `Python virtual environment <https://docs.python.org/3/tutorial/venv.html>`__. | ||
|
||
In addition to installing Tutor Main itself, this will install automatically the main versions of all official Tutor plugins (which are enumerated in `plugins.txt <https://github.com/overhangio/tutor/tree/main/requirements/plugins.txt>`_). Alternatively, if you wish to hack on an official plugin or install a custom plugin, you can clone that plugin's repository and install it. For instance:: | ||
|
||
git clone --branch=main https://github.com/myorganization/tutor-contrib-myplugin.git | ||
pip install -e ./tutor-contrib-myplugin | ||
|
||
Once Tutor Main is installed, you can run the usual ``tutor`` commands:: | ||
|
||
tutor dev launch | ||
tutor dev run lms bash | ||
# ... and so on | ||
|
||
Upgrading to the latest version of Open edX | ||
------------------------------------------- | ||
|
||
To pull the latest upstream changes, you should first upgrade Tutor Main:: | ||
|
||
cd ./tutor | ||
git pull | ||
|
||
Then, you will have to generate a more recent version of the main Docker images. Images for running Tutor Main are published daily to docker.io (see `here <https://hub.docker.com/r/overhangio/openedx/tags?page=1&ordering=last_updated&name=main>`__). You can fetch the latest images with:: | ||
|
||
tutor images pull all | ||
|
||
Alternatively, you may want to build the images yourself. As usual, this is done with:: | ||
|
||
tutor images build all | ||
|
||
However, these images include the application master branch at the point in time when the image was built. The Docker layer caching mechanism might cause the ``git clone`` step from the build to be skipped. In such cases, you will have to bypass the caching mechanism with:: | ||
|
||
tutor images build --no-cache all | ||
|
||
Running Tutor Main alongside the latest release | ||
-------------------------------------------------- | ||
|
||
When running Tutor Main, you usually do not want to override your existing Tutor installation. That's why a Tutor Main installation has the following differences from a regular release installation: | ||
|
||
- The default Tutor project root is different in Tutor Main. By default it is set to ``~/.local/share/tutor-main`` on Linux (instead of ``~/.local/share/tutor``). To modify this location check the :ref:`corresponding documentation <tutor_root>`. | ||
- The plugins root is set to ``~/.local/share/tutor-main-plugins`` on Linux (instead of ``~/.local/share/tutor-plugins``). This location may be modified by setting the ``TUTOR_PLUGINS_ROOT`` environment variable. | ||
- The default docker-compose project name is set to ``tutor_main_local`` (instead of ``tutor_local``). This value may be modified by manually setting the ``LOCAL_PROJECT_NAME``. | ||
|
||
Making changes to Tutor Main | ||
---------------------------- | ||
|
||
In general pull requests should be open on the "release" branch of Tutor: the "release" branch is automatically merged on the "main" branch at every commit, such that changes made to Tutor releases find their way to Tutor Main as soon as they are merged. However, sometimes you want to make changes to Tutor Main exclusively, and not to the Tutor releases. This might be the case for instance when upgrading the running version of a third-party service (for instance: Elasticsearch, MySQL), or when the release branch requires specific changes. In that case, you should follow the instructions from the :ref:`contributing` section of the docs, with the following differences: | ||
|
||
- Open your pull request on top of the "main" branch instead of "release". | ||
- Add a description of your changes by creating a changelog entry with `make changelog-entry`, as in the release branch. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,64 +1,8 @@ | ||
.. _nightly: | ||
|
||
Running Open edX on the master branch ("nightly") | ||
================================================= | ||
|
||
Tutor was designed to make it easy for everyone to run the latest release of Open edX. But sometimes, you want to run the latest, bleeding-edge version of Open edX. This is what we call "running master", as opposed to running the release branch. Running the master branch in production is strongly **not** recommended unless you are an Open edX expert and you really know what you are doing. But Open edX developers frequently need to run the master branch locally to implement and test new features. Thus, Tutor makes it easy to run Open edX on the master branch: this is called "Tutor Nightly". | ||
|
||
Installing Tutor Nightly | ||
------------------------ | ||
|
||
Running Tutor Nightly requires more than setting a few configuration variables: because there are so many Open edX settings, version numbers, etc. which may change between the latest release and the current master branch, Tutor Nightly is actually maintained as a separate branch of the Tutor repository. To install Tutor Nightly, you should install Tutor from the "nightly" branch of the source repository. To do so, run:: | ||
|
||
git clone --branch=nightly https://github.com/overhangio/tutor.git | ||
pip install -e "./tutor[full]" | ||
|
||
As usual, it is strongly recommended to run the command above in a `Python virtual environment <https://docs.python.org/3/tutorial/venv.html>`__. | ||
|
||
In addition to installing Tutor Nightly itself, this will install automatically the nightly versions of all official Tutor plugins (which are enumerated in `plugins.txt <https://github.com/overhangio/tutor/tree/nightly/requirements/plugins.txt>`_). Alternatively, if you wish to hack on an official plugin or install a custom plugin, you can clone that plugin's repository and install it. For instance:: | ||
|
||
git clone --branch=nightly https://github.com/myorganization/tutor-contrib-myplugin.git | ||
pip install -e ./tutor-contrib-myplugin | ||
|
||
Once Tutor Nightly is installed, you can run the usual ``tutor`` commands:: | ||
|
||
tutor dev launch | ||
tutor dev run lms bash | ||
# ... and so on | ||
|
||
Upgrading to the latest version of Open edX | ||
------------------------------------------- | ||
:orphan: | ||
|
||
To pull the latest upstream changes, you should first upgrade Tutor Nightly:: | ||
|
||
cd ./tutor | ||
git pull | ||
|
||
Then, you will have to generate a more recent version of the nightly Docker images. Images for running Tutor Nightly are published daily to docker.io (see `here <https://hub.docker.com/r/overhangio/openedx/tags?page=1&ordering=last_updated&name=nightly>`__). You can fetch the latest images with:: | ||
|
||
tutor images pull all | ||
|
||
Alternatively, you may want to build the images yourself. As usual, this is done with:: | ||
|
||
tutor images build all | ||
|
||
However, these images include the application master branch at the point in time when the image was built. The Docker layer caching mechanism might cause the ``git clone`` step from the build to be skipped. In such cases, you will have to bypass the caching mechanism with:: | ||
|
||
tutor images build --no-cache all | ||
|
||
Running Tutor Nightly alongside the latest release | ||
-------------------------------------------------- | ||
|
||
When running Tutor Nightly, you usually do not want to override your existing Tutor installation. That's why a Tutor Nightly installation has the following differences from a regular release installation: | ||
|
||
- The default Tutor project root is different in Tutor Nightly. By default it is set to ``~/.local/share/tutor-nightly`` on Linux (instead of ``~/.local/share/tutor``). To modify this location check the :ref:`corresponding documentation <tutor_root>`. | ||
- The plugins root is set to ``~/.local/share/tutor-nightly-plugins`` on Linux (instead of ``~/.local/share/tutor-plugins``). This location may be modified by setting the ``TUTOR_PLUGINS_ROOT`` environment variable. | ||
- The default docker-compose project name is set to ``tutor_nightly_local`` (instead of ``tutor_local``). This value may be modified by manually setting the ``LOCAL_PROJECT_NAME``. | ||
|
||
Making changes to Tutor Nightly | ||
------------------------------- | ||
.. _nightly: | ||
|
||
In general pull requests should be open on the "master" branch of Tutor: the "master" branch is automatically merged on the "nightly" branch at every commit, such that changes made to Tutor releases find their way to Tutor Nightly as soon as they are merged. However, sometimes you want to make changes to Tutor Nightly exclusively, and not to the Tutor releases. This might be the case for instance when upgrading the running version of a third-party service (for instance: Elasticsearch, MySQL), or when the master branch requires specific changes. In that case, you should follow the instructions from the :ref:`contributing` section of the docs, with the following differences: | ||
Obsolete: Tutor nightly | ||
======================= | ||
|
||
- Open your pull request on top of the "nightly" branch instead of "master". | ||
- Add a description of your changes by creating a changelog entry with `make changelog-entry`, as in the master branch. | ||
The "nightly" branch was renamed to "main". See :ref:`Tutor Main <main>`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.