Welcome! We're delighted that you're interested in contributing. Your help is essential for keeping the project great.
Before you start working on a new feature or a fix, here's how you can contribute:
- Fork the repository: Visit the GitHub page of our project and use the "Fork" button to create a copy of the project in your own GitHub account.
- Create a Development Branch: After forking, clone the repository to your local machine and create a new branch for your development. Use a descriptive name for your branch, such as
feature-<feature-name>
orbugfix-<bug-description>
. - Commit Your Changes: Make your changes in your development branch and commit them. Be sure to write clear, concise commit messages.
- Push to Your Fork: Push your changes to your forked repository on GitHub.
- Create a Pull Request: Go to the original project repository and click on "Pull Requests", then click the "New Pull Request" button
git clone https://github.com/qBraid/qbraid-qir.git
cd qbraid-qir
pip install -e '.[qasm3,cirq]'
Before submitting a pull request (PR), ensure your contributions comply with the Developer's Certificate of Origin, confirming your right to submit the work under this project's license. Contributors are encouraged to sign commits, however, it is not required.
For code changes, please ensure that:
- All new code includes corresponding unit tests and satisfies code coverage.
- Docstrings are thorough and accurate for both new and updated features.
- All integration tests, including docs and linters, are passing.
- New functions and classes are annotated with Python type hints to support
py.typed
.
Once PR has been validated by the maintainers, please ensure to update the CHANGELOG.md
with a description of the PR and its link. You can refer to the past release changelogs as an example. Please make sure to correctly classify your work under one of the available contribution types.
Workflow: main.yml
- All unit tests are passing
- New/modified code has corresponding unit tests and satisfies
codecov
checks.
Install pytest:
pip install qbraid pytest pytest-cov
Run unit tests:
pytest tests
Generate a coverage report and verify that project and diff codecov
are both upheld:
pytest --cov=qbraid_qir --cov-report=term tests/
Workflow: docs.yml
- Docs builds are passing.
- New/modified code has appropriate docstrings.
- Tree stubs are updated, if applicable.
- README and/or example notebooks are updated, if applicable.
Static docs pages (e.g. User Guide) are written using reStructuredText (reST), which is the default plaintext markup language used by Sphinx. It's pretty straightforward once you get the hang of it. If you're unfamiliar, reStructuredText Primer is a good place to start.
Use Google Style Python Docstrings
to specify attributes, arguments, exceptions, returns, and other related info. The docstrings are compiled into HTML using Sphinx, so to add relative links, in-line markup, bulleted lists, code-blocks, or do other types of formatting inside of docstrings, use the reST
syntax mentioned (linked) above.
Install sphinx and other docs requirements:
pip install -e '.[docs]'
Then, build docs with:
cd docs
make html
View docs in local browser window:
open build/html/index.html
Workflow: format.yml
- Formatting/linters checks pass
- All files have appropriate licensing header
For code style, our project uses a combination of isort, pylint,
and black. Specific configurations for these tools should be added to pyproject.toml
.
Install linters:
pip install black isort pylint mypy qbraid
Run the following and make changes as needed to satisfy format checks:
black qbraid_qir tests
isort qbraid_qir tests
pylint qbraid_qir tests
mypy qbraid_qir
Add licensing headers to all files:
qbraid admin headers tests bin qbraid_qir docker --type=gpl -p qbraid-qir --fix
git submodule sync
git submodule init
git submodule update --remote --recursive
git submodule update --remote --merge
git add examples
git commit -m "update examples submodule"