1
mirror of https://gerrit.googlesource.com/git-repo synced 2025-01-04 16:14:25 +00:00
git-repo/SUBMITTING_PATCHES.md
David Pursehouse d6b8bd464c Reword the documentation regarding coding style
- flake8 is a wrapper around pyflakes, so it's redundant to mention
  both of them. Roll the explicit sections about coding errors and
  coding style violations into a single section.

- After recent cleanups the project now has zero warnings or errors
  from flake8. Reword the requirements so that it is now mandatory
  to not introduce new warnings.

- Expand the section on suppression of warnings to differentiate
  between suppressing inline individually and globally suppressing
  for the whole project.

- Properly capitalize "Python Style Guide".

Change-Id: I4b333d013e985db252873441b16cb719ed5be5b5
Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/255040
Tested-by: David Pursehouse <dpursehouse@collab.net>
Reviewed-by: Mike Frysinger <vapier@google.com>
2020-02-15 23:18:50 +00:00

5.8 KiB

[TOC]

Short Version

  • Make small logical changes.

  • Provide a meaningful commit message.

  • Check for coding errors and style nits with flake8.

  • Make sure all code is under the Apache License, 2.0.

  • Publish your changes for review.

  • Make corrections if requested.

  • Verify your changes on gerrit so they can be submitted.

    git push https://gerrit-review.googlesource.com/git-repo HEAD:refs/for/master

Long Version

I wanted a file describing how to submit patches for repo, so I started with the one found in the core Git distribution (Documentation/SubmittingPatches), which itself was based on the patch submission guidelines for the Linux kernel.

However there are some differences, so please review and familiarize yourself with the following relevant bits.

Make separate commits for logically separate changes.

Unless your patch is really trivial, you should not be sending out a patch that was generated between your working tree and your commit head. Instead, always make a commit with complete commit message and generate a series of patches from your repository. It is a good discipline.

Describe the technical detail of the change(s).

If your description starts to get too long, that's a sign that you probably need to split up your commit to finer grained pieces.

Check for coding errors and style violations with flake8

Run flake8 on changed modules:

flake8 file.py

Note that repo generally follows Google's Python Style Guide rather than PEP 8, with a couple of notable exceptions:

  • Indentation is at 2 columns rather than 4
  • The maximum line length is 100 columns rather than 80

There should be no new errors or warnings introduced.

Warnings that cannot be avoided without going against the Google Style Guide may be suppressed inline individally using a # noqa comment as described in the flake8 documentation.

If there are many occurrences of the same warning, these may be suppressed for the entire project in the included .flake8 file.

Running tests

We use pytest and tox for running tests. You should make sure to install those first.

To run the full suite against all supported Python versions, simply execute:

$ tox -p auto

We have ./run_tests which is a simple wrapper around pytest:

# Run the full suite against the default Python version.
$ ./run_tests
# List each test as it runs.
$ ./run_tests -v

# Run a specific unittest module (and all tests in it).
$ ./run_tests tests/test_git_command.py

# Run a specific testsuite in a specific unittest module.
$ ./run_tests tests/test_editor.py::EditString

# Run a single test.
$ ./run_tests tests/test_editor.py::EditString::test_cat_editor

# List all available tests.
$ ./run_tests --collect-only

# Run a single test using substring match.
$ ./run_tests -k test_cat_editor

The coverage isn't great currently, but it should still be run for all commits. Adding more unittests for changes you make would be greatly appreciated :). Check out the tests/ subdirectory for more details.

Check the license

repo is licensed under the Apache License, 2.0.

Because of this licensing model every file within the project must list the license that covers it in the header of the file. Any new contributions to an existing file must be submitted under the current license of that file. Any new files must clearly indicate which license they are provided under in the file header.

Please verify that you are legally allowed and willing to submit your changes under the license covering each file prior to submitting your patch. It is virtually impossible to remove a patch once it has been applied and pushed out.

Sending your patches.

Do not email your patches to anyone.

Instead, login to the Gerrit Code Review tool at:

https://gerrit-review.googlesource.com/

Ensure you have completed one of the necessary contributor agreements, providing documentation to the project maintainers that they have right to redistribute your work under the Apache License:

https://gerrit-review.googlesource.com/#/settings/agreements

Ensure you have obtained an HTTP password to authenticate:

https://gerrit-review.googlesource.com/new-password

Ensure that you have the local commit hook installed to automatically add a ChangeId to your commits:

curl -Lo `git rev-parse --git-dir`/hooks/commit-msg https://gerrit-review.googlesource.com/tools/hooks/commit-msg
chmod +x `git rev-parse --git-dir`/hooks/commit-msg

If you have already committed your changes you will need to amend the commit to get the ChangeId added.

git commit --amend

Push your patches over HTTPS to the review server, possibly through a remembered remote to make this easier in the future:

git config remote.review.url https://gerrit-review.googlesource.com/git-repo
git config remote.review.push HEAD:refs/for/master

git push review

You will be automatically emailed a copy of your commits, and any comments made by the project maintainers.

Make changes if requested

The project maintainer who reviews your changes might request changes to your commit. If you make the requested changes you will need to amend your commit and push it to the review server again.

Verify your changes on gerrit

After you receive a Code-Review+2 from the maintainer, select the Verified button on the gerrit page for the change. This verifies that you have tested your changes and notifies the maintainer that they are ready to be submitted. The maintainer will then submit your changes to the repository.