-
Notifications
You must be signed in to change notification settings - Fork 1k
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
Release script for downstream OTP forks #6345
Draft
t2gran
wants to merge
1
commit into
opentripplanner:dev-2.x
Choose a base branch
from
entur:release_scripts
base: dev-2.x
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Draft
Changes from all commits
Commits
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -0,0 +1,187 @@ | ||||||
# README - OTP Fork Release Scripts | ||||||
|
||||||
**Note! This describes how you can set up and release OTP in you own GitHub fork, not how OTP in the | ||||||
main repo is released.** | ||||||
|
||||||
## Introduction | ||||||
|
||||||
The scripts here can be used to release a fork of OTP. Run | ||||||
|
||||||
``` | ||||||
# script/prepare_release otp/dev-2.x | ||||||
# script/release | ||||||
``` | ||||||
|
||||||
### Process overview | ||||||
|
||||||
- You specify the _base branch_, normally `dev-2.x` in git repo [`opentripplanner/OpenTripPlanner`](https://github.com/opentripplanner/OpenTripPlanner). | ||||||
The release branch is rebased on top of the base branch(fork). | ||||||
**Nothing is kept from previous releases.** | ||||||
- The 2 steps allow you to merge in "work in progress" before the final release is made. | ||||||
- If something goes wrong, like a conflicting merge, you may fix the problem and resume the release | ||||||
by running the `prepare_release` script again. Use the exact same arguments. | ||||||
- Each release is given a unique version number specific to your fork, like `v2.7.0-MY_ORG-1`. | ||||||
- The release is tagged with the version in the Git repository. | ||||||
- The old release is then merged with an _empty merge_, this is done to create a continuous line | ||||||
of releases in the release branch for easy viewing and navigation of the git history. Nothing | ||||||
from the previous release is copied into the new release. We call this an _empty merge_. | ||||||
- Roll-back by rolling-forward. | ||||||
|
||||||
|
||||||
### Advanced Git flow - roll back | ||||||
|
||||||
![Release git flow](images/release-git-flow.svg) | ||||||
|
||||||
Each release has a single commit as a base, this allows us to choose any commit as the base and | ||||||
safely **Roll-back, by rolling forward**. In the diagram above, commit (D) contained a bug. So, we | ||||||
can go back to commit (C). If we merged `dev2-x` into the release-branch then going back to this | ||||||
commit would be challenging since commit (D) was already in the release branch at this point. | ||||||
Also note that the CI configuration is changed (c2) and this change needs to be included in the | ||||||
new release (v3). | ||||||
|
||||||
> **Note!** OTP ignore config it does not understand it. This allows us to roll out config for new | ||||||
> features BEFORE we roll out the new version of OTP. We can then verify that the old version of | ||||||
> OTP works with the new config. Config is dependent on both the environment OTP run in and OTP. | ||||||
> So, the config has its own life-cycle, independent of the OTP software. | ||||||
|
||||||
|
||||||
### Advanced Git flow - rollback and a feature branch | ||||||
|
||||||
![Release git flow with feature branch](images/release-git-flow-feature-branch.svg) | ||||||
|
||||||
After the `prepare_release` script is run, you may merge in any number of _feature branches_. | ||||||
|
||||||
|
||||||
## The `ext_config` branch | ||||||
|
||||||
You should create a branch in the local git repository where you keep your deployment-specific | ||||||
config. The `ext_config` branch should have **one** commit with all changes needed. If you need to | ||||||
change the config, you will have to amend the changes. This is because the release script chery-pick | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
the top commit and then reset the `ext_config` branch. | ||||||
|
||||||
The branch must include: | ||||||
|
||||||
- The `script/release_env` script, containing the target release information. | ||||||
|
||||||
The branch may include: | ||||||
|
||||||
- Local CI build configuration. | ||||||
- OTP deployment configuration. | ||||||
|
||||||
|
||||||
## Setup | ||||||
|
||||||
Create a script in your local fork with the release target git repo and branch name. This small | ||||||
script is used by the `prepare_release` and `release` scripts to identify the target git repository | ||||||
and branch. | ||||||
|
||||||
#### Add file _script/release_env_ | ||||||
|
||||||
```bach | ||||||
#!/usr/bin/env bash | ||||||
|
||||||
export GIT_REMOTE_RELEASE_BRANCH="<release branch>" | ||||||
export GIT_REMOTE_RELEASE_ORG="<org>" | ||||||
``` | ||||||
|
||||||
Substitute `<org>` and `<release branch>` with the correct values. Commit and push this file to | ||||||
the `ext_config` branch in your organizations fork of OTP. Note! The <org> must match the | ||||||
GitHub organization name in your local Git clone. Use `git remote -v` to list all remote repos. | ||||||
|
||||||
|
||||||
## Pending Pull Requests | ||||||
|
||||||
You may want to merge in pending PRs when releasing your fork. The two-step build process | ||||||
(`prepare_release` and then `release`) allow you to merge in any feature branches, before the | ||||||
final release is made. At Entur we label all PRs we want to be merged into the next release with | ||||||
`Entur test`, this ensures that any team member can do the release. This allows us to test features | ||||||
at Entur before the PR is accepted and merged in the upstream repo. We combine this with config, | ||||||
and sometimes the OTPFeature toggle to turn on new features in over test environment. When a new | ||||||
feature is tested ok, then we enable it in the production environment. | ||||||
|
||||||
|
||||||
## How To Make A Release | ||||||
|
||||||
Find the target branch/commit or use the branch `otp/dev-2.x`. If you use a specific branch/commit, | ||||||
then replace `otp/dev-2.x` below with your branch/commit hash. | ||||||
|
||||||
Run the `prepare_release` script. The script does the following: | ||||||
- Reset main to the right latest commit on `dev-2.x` | ||||||
- Rebase and merge in the `ext_config` extension branches into the local release branch. You will | ||||||
be prompted for each step allowing you to perform/skip the steps you want. Also. the script keeps | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
track of the progress and will resume where it stopped in case of a merge conflict or compile | ||||||
error. If the script aborts, you should fix the problem (resolve conflicts or fix compile errors) | ||||||
and run the script again. | ||||||
|
||||||
|
||||||
### Run the `prepare_release` script | ||||||
|
||||||
The `--dryRun` options is used to run the script and skip pushing changes to the remote repo. Be | ||||||
aware that the local git repo is changed, and you must manually revert all changes. The `--dryRun` | ||||||
option is used to test the script. | ||||||
|
||||||
```bash | ||||||
git fetch otp | ||||||
git fetch entur | ||||||
git checkout ext_config | ||||||
git pull | ||||||
script/prepare_release [--dryRun] otp/dev-2.x | ||||||
``` | ||||||
If the script fails to rebase/compile one of the extension branches, you should resolve the | ||||||
problem/conflict and complete the rebase. | ||||||
|
||||||
```bash | ||||||
# Resolving any conflicts, run test to verify everything still works | ||||||
mvn clean test | ||||||
|
||||||
# Add all of the conflicted file files to the staging area using `git add` | ||||||
git rebase --continue | ||||||
|
||||||
# Resume prepare_release sscript | ||||||
script/prepare_release otp/dev-2.x | ||||||
``` | ||||||
> **Tip!** If you have conflicts in documentation files, then consider running the test. The tests | ||||||
> will regenerate the correct documentation file. After the test is run and new documentation is | ||||||
> generated you mark the conflict as resolved. | ||||||
|
||||||
### Merge in feature branches | ||||||
|
||||||
Merge in all feature branches you want. For each feature branch, make sure the branch is up-to-date | ||||||
with `dev-2.x` BEFORE you merge it into the release branch. | ||||||
|
||||||
```bash | ||||||
git merge my_org_repo/feature_branch | ||||||
mvn test | ||||||
``` | ||||||
|
||||||
### Run the `release` script | ||||||
|
||||||
Run the `script/release script to complete the OTP2 release. The script will verify that you are | ||||||
on the correct branch, fetch updates(tags) from the remote repo, resolve what the next version is | ||||||
and set the version in the pom.xml. Then it runs all tests and commits. Then the script finishes up | ||||||
by tagging the release and pushing it to the remote repo. | ||||||
|
||||||
Yuor CI server should pick the new version up and build it, then deploy it to your artifact repo. | ||||||
|
||||||
```bash | ||||||
script/release | ||||||
``` | ||||||
The script should be run on the developer local machine, not on the CI Server. | ||||||
|
||||||
|
||||||
## How-to make a hot-fix release 🔥 | ||||||
|
||||||
Sometimes it is necessary to roll out a new fix as fast as possible and with minimum risk. You can | ||||||
do this by applying the new “hot-fix” on top of the latest release, and then make a new release. | ||||||
A hot-fix release can normally be rolled out without waiting for new graphs to build, since the | ||||||
serialization version number is the same. | ||||||
|
||||||
1. Find out what the current OTP version is. | ||||||
2. Check out the `release branch`, pull the latest version. You may have to reset it to the | ||||||
version in the production environment. | ||||||
3. Cherry-pick or fix the problem. | ||||||
4. Run tests. | ||||||
5. Complete the release by running the `release` script. | ||||||
|
||||||
Do not worry about deleting more recent versions, the release script will preserve the history so | ||||||
nothing is lost. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.