This is an open repository, and we are very happy to receive contributions to the HERMES workflow from the community, for example as feedback, bug reports, feature requests, etc.
We see our project as part of a global and interdisciplinary effort to improve the state of the art in research software engineering, maintenance and scholarly communications around research software. We therefore appreciate any feedback you may have on the HERMES project itself and any of its outputs.
Either create an issue in our project repository or send us an email.
The following describes the workflow for contributions.
Branching is cheap!
Work in small packets, put up small pull requests!
Aim for quick turnaround times!
We loosely follow a mixture of GitHubFlow and GitFlow with the following branches.
- This is the stable branch.
- Merges into
main
come only fromdevelop
or a hotfix branch (i.e., when something needs to be fixed in "production").
- This is the unstable development branch.
- Before you attempt to break something or add experimental changes,
git tag
the current state.
- Naming convention: include an issue id if one exists, e.g.,
feature/62-improve-broken-thing
orfeature/42-add-new-thing
. - Branch from last tag on
develop
.
- Naming convention: include an issue id if one exists, e.g.,
hotfix/62-fix-broken-thing-in-release
. - Branch from
main
.
Project members may create pull requests from branches in the main repository, while external contributors need to follow a forking pattern. In both cases, please follow these rules:
- As soon as you have made 1 commit in a feature branch, put up a draft pull request.
- Keep pull requests small.
⚠️ Do not review draft pull requests, unless the PR author @-mentions you with this specific request.- When you think you're done, mark the PR ready for review to start the merge process.
- Create draft PR: The contributor creates a draft pull request (PR) from
feature/...
againstdevelop
(and becomes the PR author). - Describe changes: The PR author describes the changes in the PR in the initial comment:
- Reference any related issues (use, e.g.,
Fixes #n
or- Related: #n
) - Describe what new code does
- Optional: Describe what reviewers should look at specifically
- Include information on how to review:
- E.g.:
poetry install poetry run pytest test/
- E.g.:
- Reference any related issues (use, e.g.,
- Request review: The PR author requests one or more reviews.
- Eligible reviewers are:
- For Python code: @led02, @sdruskat, @jkelling
- For Documentation:
- Workflow: @all
- Project: @all
- Eligible reviewers are:
- Review: At least 1 reviewer reviews the changes:
- Follow the instructions in the PR
- Review thoroughly beyond instructions
- Add comments or change suggestions inline in the respective file using GitHub's * changed* tab
- Submit the review with the correct review outcome:
- CASE 1: Non-blocking change requests (typos, documentation wording, etc.) -> Document and Accept
- CASE 2: Blocking change requests (something doesn't work, bad quality code, docs are not understandable):
- Ideally, fix things yourself in the branch -> Request Changes (or do them on your own)
- CASE 3: "Just a comment"s, pointers to potential future changes -> Document and Accept
- CASE 4:
⚠️ If you want a second pair of eyes on the PR, use Comment to finish the review, then request another reviewer and @-mention them in a comment on the PR.
- Optional: If you find something blocking after your initial review, add another review with Request changes outcome.
- Act on review: The PR author acts on the review
- React to comments
- Fix issues (including non-blocking issues)
- Discuss options
- Then:
- CASE 1: The PR author merges the PR.
- CASE 2: The PR author re-requests a review from the original reviewer(s).
- CASE 3: The PR author reacts to any comments. If all comments are resolved, the PR author merges the PR.
- CASE 4: The correct next step depends on the outcome of the second review.
- Re-review:
- See Review above
- Any maintainer can:
- Close a PR if the PR is not suitable for merging, and no further changes to improve it come from the PR author.
⚠️ Only do this after after having communicated sensible requests with a deadline for further work in the PR comments. - Merge a PR and delete the remote branch if at least half of the invited reviewers have approved the PR, and no changes have been requested after review. This implements lazy consensus to avoid bottlenecks, where a PR has been approved by some reviewers but cannot be closed due to missing reviews.
- Close a PR if the PR is not suitable for merging, and no further changes to improve it come from the PR author.
- Create a release branch
release/v<version-id>
fromdevelop
. - Check if everything looks good:
- Audit the source code (using linters and other tooling).
- Ensure test coverage is at least 65%, and that all tests pass.
- Check if the documentation aligns with the code (also run tutorial to check completeness).
- Check if the metadata is correct in all relevant places.
- Put up a PR from the release branch against
main
. - Request a review (using the same workflow as above).
- Merge the PR into
main
. - Tag
main
'sHEAD
asv<version-id>
. - Push
main
. - Push tag.
- Merge
main
intodevelop
. - Delete the release branch.
- 💡 If something goes wrong in the release branch, you can always delete it, fix things in a feature branch, merge
into
develop
following the workflow above, and start anew.
To build hermes
locally, run the
following command from the project root:
poetry install
To build the documentation in your poetry environment, run the following commands from the project root:
poetry install --with docs
poetry run task docs-build
Or use sphinx-autobuild
to enable a self-updating preview service:
poetry install --with docs
poetry run task docs-live