This guide provides instructions for contributing to the pybsm
project. For additional details, please refer to the pybsm
README.
-
Access the Repository
Navigate to the officialpybsm
repository on JATIC GitLab. -
Fork and Clone
Fork the repository into your GitLab user namespace and clone it to your local system.$ git clone <your-fork-url> $ cd pybsm
-
Create a Topic Branch
Work on a new topic branch for your contribution:$ git checkout -b <branch-name> $ <edit files> $ git add <file1> <file2> ... $ git commit -m "Descriptive commit message"
- Ensure that your commits include an update to the
docs/release_notes/pending_release.rst
file (or a relevant patch release notes file). - Provide a concise summary of the feature, update, or fix being added. This is generally required for approval.
- Ensure that your commits include an update to the
-
Push Your Branch
Push your changes to your forked repository:$ git push origin HEAD -u
-
Create a Merge Request (MR)
On GitLab, navigate to the "Merge Requests" tab of your forked project and click "New merge request."- Set the source branch to your forked branch and the target branch to the appropriate branch of the
pybsm
repository. - Click "Compare branches and continue" and then "Create merge request."
- Set the source branch to your forked branch and the target branch to the appropriate branch of the
pybsm
uses GitLab for code reviews and GitLab CI/CD for automated testing.
- New MRs trigger CI workflows for
master
andrelease
branches. - All CI checks must pass before an MR can be merged.
We use Sphinx for API documentation, both manual and automated.
When adding or modifying Jupyter Notebooks:
-
CI Inclusion
- Ensure notebooks are part of the CI workflow and executable within its environment.
- Add references to
.gitlab-ci/.gitlab-test.yml
and totests/examples/test_notebooks.py
.
-
Execution Requirements
- Keep execution concise to avoid CI timeouts.
- Include a cell for dependency installation (e.g.,
pip install ...
) to ensure proper setup in the CI environment.
-
Resource Constraints
- Optimize notebooks to use minimal computational resources, aligning with CI environment limitations.
Typically, every contribution requires an associated release note. Add this to the docs/release_notes/pending_release.rst
file, summarizing the changes made.
If your contribution fixes a minor issue in a recent update and does not alter the summary in existing release notes, the requirement may be waived.
- Contributors should explain why a release note is unnecessary for the reviewers to consider on a case-by-case basis.
We adopt a "Verb-Noun" convention for class names. This structure highlights the behavior or transformation a class performs.
- Verb: Indicates the primary action or behavior.
- Noun: Specifies the subject of the action, typically related to input or output.
- Classes performing similar actions on different subjects should clearly differentiate the subjects in their names.
- Names should be concise and intuitive, aiding user understanding.