Skip to content

Latest commit

 

History

History
143 lines (127 loc) · 6.78 KB

CONTRIBUTING.md

File metadata and controls

143 lines (127 loc) · 6.78 KB

How to Contribute

We'd love to accept your patches and contributions to this project. We do have some guidelines to follow, covered in this document, but don't worry about (or expect to) get everything right the first time! Create a pull request and we'll nudge you in the right direction.

Contributor License Agreement

Contributions to this project must be accompanied by a Contributor License Agreement. You (or your employer) retain the copyright to your contribution; this simply gives us permission to use and redistribute your contributions as part of the project. Head over to https://cla.developers.google.com/ to see your current agreements on file or to sign a new one.

You generally only need to submit a CLA once, so if you've already submitted one (even if it was for a different project), you probably don't need to do it again.

Pull Request Process and Code Review

All submissions, including submissions by project members, require review. We use GitHub pull requests for this purpose. GitHub Help has information on using pull requests.

The preferred manner for submitting pull requests is for users to fork the Cirq repo and then use a branch from this fork to create a pull request to the main Cirq repo.

The basic process for setting up a fork is

  1. Fork the Cirq repo (Fork button in upper right corner of repo page). Forking creates a new github repo at the location https://github.com/USERNAME/cirq where USERNAME is your github id.
  2. Clone the fork you created to your local machine at the directory where you would like to store your local copy of the code.
    git clone [email protected]:USERNAME/cirq.git
  3. Add a remote called upstream to git. This remote will represent the main git repo for cirq (as opposed to the clone, which you just created, which will be the origin remote). This remote can be used to sync your local git repos with the main git repo for cirq.
    git remote add upstream https://github.com/quantumlib/cirq.git
    To verify the remote run git remote -v and you should see both the origin and upstream remotes.
  4. Sync up your local git with the upstream remote:
    git fetch upstream
    You can check the branches that are on the upstream remote by running git remote -va. Most importantly you should see upstream/master listed.
  5. Merge the upstream master into your local master so that it is up to date
    git checkout master
    git merge upstream/master
    At this point your local git master should be synced with the master from the main cirq repo.

The process of doing work which you would like to contribute is then to

  1. Checkout master and create a new branch from this master
    git checkout master -b new_branch_name
    where new_branch_name is the name of your new branch.
  2. Do your work and commit your changes to this branch.
  3. If you have drifted out of sync with the master from the main cirq repo you may need to merge in changes. To do this, first update your local master and then merge the local master into your branch:
    # Update your local master.
    git fetch upstream
    git checkout master
    git merge upstream/master
    # Merge local master into your branch.
    git checkout new_branch_name
    git merge master
    You may need to fix merge conflicts for both of these merge commands.
  4. Finally, push your change to your clone
    git push origin new_branch_name
  5. Now when you navigate to the cirq page on github, https://github.com/quantumlib/cirq you should see the option to create a new pull request from your clone repository. Alternatively you can create the pull request by navigating to the "Pull requests" tab in the page, and selecting the appropriate branches.
  6. The reviewer will comment on your code and may ask for changes, you can perform these locally, and then push the new commit following the same process as above.

Continuous Integration and Standards

When a pull request is created or updated, various automatic checks will run to ensure that the change won't break Cirq and meets our coding standards.

The continuous integration tooling checks the following:

  • Tests. Existing tests must continue to pass (or be updated) when new changes are introduced. We use pytest to run our tests.
  • Coverage. Code should be covered by tests. We use pytest-cov to compute coverage, and custom tooling to filter down the output to only include new or changed code. We don't require 100% coverage, but any uncovered code must be annotated with # coverage: ignore. To ignore coverage of a single line, place # coverage: ignore at the end of the line. To ignore coverage for an entire block, start the block with a # coverage: ignore comment on its own line.
  • Lint. Code should meet common style standards for python and be free of error-prone constructs. We use pylint to check for lint. To see which lint checks we enforce, see the continuous-integration/.pylintrc file. When pylint produces a false positive, it can be squashed with annotations like # pylint: disable=unused-import.
  • Types. Code should have type annotations. We use mypy to check that type annotations are correct. When type checking produces a false positive, it can be ignored with annotations like # type: ignore.
  • Python 2 Convertability. Code must avoid constructs which fail to translate to python 2. Cirq is written in python 3, but we use 3to2 (and some custom tooling) to automatically translate the code into runnable python 2 code. This translation step is not perfect. For example, max([], default=2) fails to translate. We check that the translation worked by testing the translated code against the translated tests. Cirq has several utilities to help the translation process along, such as the @cirq.testing.only_test_in_python3 decorator for tests that check functionality specific to python 3.

If you are on a debian machine, you can run the continuous integration checks for yourself. Simply run the following command from a terminal at the root of your clone of cirq's repo, with your local changes:

bash continous-integration/check.sh

You can run a subset of the checks using the --only flag. This flag value can be pylint, typecheck, pytest, pytest2, or incremental-coverage.