trove/CONTRIBUTING.rst
Amrith Kumar a2d336de2a improve pylint; generate errors and config in sorted order
Since the config is not in a deterministic order makes it hard to
compare two config's and see what changed. Personally, I'm not
positive I understand this use-case; i.e. you have an existing config
file, you save it, and then rebuild and then diff the two files. I'd
have thought you'd just run check and the output of the tool was the
diff.

I however do see the value in sorting the file so that when someone
submits a change that includes a change to the config, reviewers can
see more easily what the change is doing.

Similarly, the output from pylint (errors) are generated one file at a
time and os.walk makes no guarantee of deterministic order. So we
should collect all errors (across all files) and then print an ordered
list for human consumption.

The intent is also to make pylint voting soon (in master). the changes
to contributing.rst and tox.ini are to make that easier. The config
file has also been sorted in place.

This change was motivated by an email exchange with Peter so I am
marking him as a co-conspirator.

The line numbers were removed from the tools/trove-pylint.config file
as these would change whenever the line numbers in the file changed
(since they are currently not being used in the comparison; they can
be re-added if deemed necessary at the cost of having every 'rebuild'
run create a different file).

The tools/trove-pylint.config was regenerated as well, since the
remaining two errors seem to be innocuous:

  ERROR: trove/taskmanager/manager.py 392: E1101 no-member,
  Manager.upgrade: Instance of 'BuiltInstance' has no 'upgrade' member
  (new method introduced by instance upgrade; other BuiltInstance
  member errors are already ignored.)

and

  ERROR: trove/guestagent/datastore/experimental/postgresql/service/
  access.py 80: E1101 no-member, PgSqlAccess.list_access: Instance ofi
  'PgSqlAccess' has no '_find_user' member
  (this is due to the fact that PostgreSQL is spread over multiple
  files and pylint should cease to complain once
  https://review.openstack.org/#/c/346082/ lands.)

Change-Id: I910c738d3845b7749e57910f76523150ec5a5bff
Closes-Bug: #1625158
Closes-Bug: #1625245
Co-Authored-By: Peter Stachowski <peter@tesora.com>
2016-09-19 21:04:14 +00:00

8.0 KiB

Contributing

Our community welcomes all people interested in open source cloud computing, and encourages you to join the OpenStack Foundation.

If you would like to contribute to the development of OpenStack, you must follow the steps documented at:

http://docs.openstack.org/infra/manual/developers.html#development-workflow

Once those steps have been completed, changes to OpenStack should be submitted for review via the Gerrit tool, following the workflow documented at:

http://docs.openstack.org/infra/manual/developers.html#development-workflow

(Pull requests submitted through GitHub will be ignored.)

Bugs should be filed on Launchpad, not GitHub:

https://bugs.launchpad.net/trove

We welcome all types of contributions, from blueprint designs to documentation to testing to deployment scripts. The best way to get involved with the community is to talk with others online or at a meetup and offer contributions through our processes, the OpenStack wiki, blogs, or on IRC at #openstack-trove on irc.freenode.net.

House Rules

Code Reviews

We value your contribution in reviewing code changes submitted by others, as this helps increase the quality of the product as well. The Trove project encourages the guidelines (below).

  • A rating of +1 on a code review is indicated if:
    • It is your opinion that the change, as proposed, should be considered for merging.
  • A rating of 0 on a code review is indicated if:
    • The reason why you believe that the proposed change needs improvement is merely an opinion,
    • You have a question, or need a clarification from the author,
    • The proposed change is functional but you believe that there is a different, better, or more appropriate way in which to achieve the end result being sought by the proposed change,
    • There is an issue of some kind with the Commit Message, including violations of the Commit Message guidelines,
    • There is a typographical or formatting error in the commit message or the body of the change itself,
    • There could be improvements in the test cases provided as part of the proposed change.
  • A rating of -1 on a code review is indicated if:
    • The reason why you believe that the proposed change needs improvement is irrefutable, or it is a widely shared opinion as indicated by a number of +0 comments,
    • The subject matter of the change (not the commit message) violates some well understood OpenStack procedure(s),
    • The change contains content that is demonstrably inappropriate,
    • The test cases do not exercise the change(s) being proposed,
    • The change causes a failure in the pylint job (see pylint section below).

Some other reviewing guidelines:

  • In general, when in doubt, a rating of 0 is advised,
  • The code style guidelines accepted by the project are part of tox.ini, a violation of some other hacking rule(s), or pep8 is not a reason to -1 a change.

Other references:

Approving changes

The Trove project follows the conventions below in approving changes.

  1. In general, two core reviewers must +2 a change before it can be approved. In practice this means that coreA can +2 the change, then coreB can +2/+A the change and it can be merged.
  2. coreA and coreB should belong to different organizations.
  3. For requirements changes proposed by the Proposal Bot or translations proposed by Zanata, a single core reviewer can review and approve the change.

NOTE:

For the remainder of the Newton release cycle, we will relax the above conventions. These relaxations apply to the master branch only.

We will adopt a practice of lazy consensus for approving all changes and a single core reviewer can review and approve a change. This could be done, for example, by allowing all reviewers know that he or she intends to approve some change or set of changes if there are no additional negative comments by a certain time definite.

We will however still require that at least one other person review (and +1 or +2) the change before it can be +A'ed.

Abandoning changes

At the Trove mid-cycle held in July 2016 we discussed our process for abandoning changes and concluded that we would adopt the following process.

  1. We will take a more proactive policy towards abandoning changes that have not been merged for a long time.
  2. A list of changes proposed for abandonment will be presented at a weekly meeting and if there is no objection, those changes will be abandoned. If the patch sets are associated with bugs, the bugs will be unassigned.
  3. In general, changes will be proposed for abandonment if the change being proposed has either been addressed in some other patch set, or if the patch is not being actively maintained by the author and there is no available volunteer who will step up to take over the patch set.

Trove Documentation

This repository also contains the Database Services API Reference. To build the API reference, run:

$ tox -e api-ref

The generated documentation is found:

api-ref/html/index.html

Trove PyLint Failures

The Trove project uses trove-pylint (tools/trove-pylint) in the gate and this job is intended to help catch coding errors that sometimes may not get caught in a code review, or by the automated tests.

The gate-trove-tox-pylint jobs are run by the CI, and these invoke the command in tools/trove-pylint.

The tool can produce false-positive notifications and therefore supports a mechanism to provide a list of errors that are to be ignored.

Before submitting a change, please do run

$ tox -e pylint

on your development environment. If this fails, you will have to resolve all the errors before you can commit the code.

This means you either must fix the problem being identified, or regenerate the list of ignored errors and submit that as part of your review.

To regenerate the list of ignored errors, you run the command(s):

$ tox -e pylint rebuild

Warning: trove-pylint is very sensitive to the version(s) of pylint and astroid that are installed on your system and for this reason, a tox environment is provided that will mimic the environment that pylint will encouter in the gate.

Pre-commit checklist

Before commiting code to Gerrit for review, please at least do the following on your development system and ensure that they pass.

$ tox -e pep8
$ tox -e py27
$ tox -e py34
$ tox -e pylint

If you are unable to get these to pass locally, it is a waste of the CI resources to push up a change for review.

Testing

Usage for integration testing

If you'd like to start up a fake Trove API daemon for integration testing with your own tool, run:

$ ./tools/start-fake-mode.sh

Stop the server with:

$ ./tools/stop-fake-mode.sh

Tests

To run all tests and PEP8, run tox, like so:

$ tox

To run just the tests for Python 2.7, run:

$ tox -epy27

To run just PEP8, run:

$ tox -epep8

To generate a coverage report,run:

$ tox -ecover

(note: on some boxes, the results may not be accurate unless you run it twice)

If you want to run only the tests in one file you can use testtools e.g.

$ python -m testtools.run trove.tests.unittests.python.module.path