data:image/s3,"s3://crabby-images/24c1d/24c1d5c8cb9f9b23a868a8c34a86739b82233062" alt=""
Git / versioning workflow
and suggested RSE work
on the TTI project
Ann Gledson, Research Software Engineer
The University of Manchester
data:image/s3,"s3://crabby-images/48a1c/48a1cc24741d02637e85ed8d52cfec873199f91f" alt=""
data:image/s3,"s3://crabby-images/24c1d/24c1d5c8cb9f9b23a868a8c34a86739b82233062" alt=""
Overview
data:image/s3,"s3://crabby-images/48a1c/48a1cc24741d02637e85ed8d52cfec873199f91f" alt=""
- Gitflow workflow
- Versioning / release process
- Current workflow
- Proposed RSE work
Gitflow Workflow
Gitflow branch types
- Master branch is public release code – each version on master is tagged with a semantic version number (https://semver.org/). Code in master works.
- Release branch (if present) is temporary. Preparation for version release. (Or use develop)
- Commits on develop are stable and should work but some unanticipated unexpected behaviour may be present.
- Feature branches are temporary*. Commits on these may be broken/unstable.
Gitflow release process
- Tests run on develop branch – before making a release, make sure that all tests are passing (can be run as a CI job).
- (optional) Create an issue that describes what changes have been made since last release version. Make sure everyone agrees that behaviour is as expected. Link to passing tests.
- Merge develop into master and tag with the version number.
data:image/s3,"s3://crabby-images/fec28/fec281c4de1c3c00e33ac2a0f215142f52a4fcad" alt=""
Current
Workflow
- Works well if:
- Contributors are working in the same context, same goals
- Communicate frequently
- Or each individual is working on their own branch/version
data:image/s3,"s3://crabby-images/7ecd8/7ecd87cca92af6a8d374bbe61eb6432fcf61b277" alt=""
data:image/s3,"s3://crabby-images/b489f/b489fb5afa8cd10a9bd64c083132df01b8b7e596" alt=""
data:image/s3,"s3://crabby-images/cddb9/cddb9515611929c90f69d02e9c4c1215009e2699" alt=""
- Falls down if:
- Code shared with external users
- Change in context / purpose
- Package users expect a single, main branch
- Extensibility logic is in the code, not branches
- Versions: whole code, working snapshots
data:image/s3,"s3://crabby-images/c8596/c85960f5c9e7f28a1794e61fca2e07f88f416655" alt=""
data:image/s3,"s3://crabby-images/dbd25/dbd2575f53f278ea6926e8e7a74efa0cd19faf01" alt=""
data:image/s3,"s3://crabby-images/1ba9f/1ba9f25e45a59ce3bc9cb0dfad8e2020b8da1f77" alt=""
data:image/s3,"s3://crabby-images/f621f/f621f74c7c2d72da2966be3f4e4516a11bd8844c" alt=""
data:image/s3,"s3://crabby-images/96d28/96d28e67cf46afe7378345e8a79bd369b09f9070" alt=""
data:image/s3,"s3://crabby-images/92e4a/92e4a140c0a5428602419183924f86bed1d269cd" alt=""
data:image/s3,"s3://crabby-images/7a7cf/7a7cf0ceb85ccf5049e02dd99c68fd381f69123a" alt=""
data:image/s3,"s3://crabby-images/dc5bd/dc5bd6572d9d04ed4d6611098c394fe6483f6755" alt=""
2. Develop parallel
version of repository
1. Keep current
workflow
- Help with:
- Packaging
- Testing
- Versioning
Upcoming RSE Work
TTI-git-workflow-RSE-work
By Ann Gledson
TTI-git-workflow-RSE-work
- 525