Matthew Treinish | 16dd51b | 2014-06-11 12:04:51 -0400 | [diff] [blame] | 1 | Reviewing Tempest Code |
| 2 | ====================== |
| 3 | |
| 4 | To start read the `OpenStack Common Review Checklist |
Masayuki Igawa | 1608cc0 | 2016-04-11 13:54:38 +0900 | [diff] [blame] | 5 | <http://docs.openstack.org/infra/manual/developers.html#peer-review>`_ |
Matthew Treinish | 16dd51b | 2014-06-11 12:04:51 -0400 | [diff] [blame] | 6 | |
| 7 | |
| 8 | Ensuring code is executed |
| 9 | ------------------------- |
| 10 | |
| 11 | For any new or change to a test it has to be verified in the gate. This means |
| 12 | that the first thing to check with any change is that a gate job actually runs |
| 13 | it. Tests which aren't executed either because of configuration or skips should |
| 14 | not be accepted. |
| 15 | |
| 16 | |
| 17 | Unit Tests |
| 18 | ---------- |
| 19 | |
| 20 | For any change that adds new functionality to either common functionality or an |
| 21 | out-of-band tool unit tests are required. This is to ensure we don't introduce |
| 22 | future regressions and to test conditions which we may not hit in the gate runs. |
| 23 | Tests, and service clients aren't required to have unit tests since they should |
| 24 | be self verifying by running them in the gate. |
| 25 | |
| 26 | |
| 27 | API Stability |
| 28 | ------------- |
| 29 | Tests should only be added for a published stable APIs. If a patch contains |
| 30 | tests for an API which hasn't been marked as stable or for an API that which |
| 31 | doesn't conform to the `API stability guidelines |
| 32 | <https://wiki.openstack.org/wiki/Governance/Approved/APIStability>`_ then it |
| 33 | should not be approved. |
| 34 | |
| 35 | |
| 36 | Reject Copy and Paste Test Code |
Matthew Treinish | f45ba2e | 2015-08-24 15:05:01 -0400 | [diff] [blame] | 37 | ------------------------------- |
Matthew Treinish | 16dd51b | 2014-06-11 12:04:51 -0400 | [diff] [blame] | 38 | When creating new tests that are similar to existing tests it is tempting to |
| 39 | simply copy the code and make a few modifications. This increases code size and |
| 40 | the maintenance burden. Such changes should not be approved if it is easy to |
| 41 | abstract the duplicated code into a function or method. |
| 42 | |
| 43 | |
| 44 | Being explicit |
| 45 | -------------- |
| 46 | When tests are being added that depend on a configurable feature or extension, |
| 47 | polling the API to discover that it is enabled should not be done. This will |
| 48 | just result in bugs being masked because the test can be skipped automatically. |
| 49 | Instead the config file should be used to determine whether a test should be |
| 50 | skipped or not. Do not approve changes that depend on an API call to determine |
| 51 | whether to skip or not. |
| 52 | |
| 53 | |
Matthew Treinish | 13a1ed6 | 2015-09-08 10:39:58 -0400 | [diff] [blame] | 54 | Configuration Options |
| 55 | --------------------- |
| 56 | With the introduction of the tempest external test plugin interface we needed |
| 57 | to provide a stable contract for tempest's configuration options. This means |
| 58 | we can no longer simply remove a configuration option when it's no longer used. |
| 59 | Patches proposed that remove options without a deprecation cycle should not |
| 60 | be approved. Similarly when changing default values with configuration we need |
| 61 | to similarly be careful that we don't break existing functionality. Also, when |
| 62 | adding options, just as before, we need to weigh the benefit of adding an |
| 63 | additional option against the complexity and maintenance overhead having it |
| 64 | costs. |
| 65 | |
| 66 | |
Matthew Treinish | 5507888 | 2014-08-12 19:01:34 -0400 | [diff] [blame] | 67 | Test Documentation |
| 68 | ------------------ |
| 69 | When a new test is being added refer to the :ref:`TestDocumentation` section in |
| 70 | hacking to see if the requirements are being met. With the exception of a class |
| 71 | level docstring linking to the API ref doc in the API tests and a docstring for |
| 72 | scenario tests this is up to the reviewers discretion whether a docstring is |
| 73 | required or not. |
| 74 | |
Matthew Treinish | b786dca | 2016-06-22 10:32:45 -0400 | [diff] [blame] | 75 | Release Notes |
| 76 | ------------- |
| 77 | Release notes are how we indicate to users and other consumers of Tempest what |
| 78 | has changed in a given release. Since Tempest 10.0.0 we've been using `reno`_ |
| 79 | to manage and build the release notes. There are certain types of changes that |
| 80 | require release notes and we should not approve them without including a release |
| 81 | note. These include but aren't limited to, any addition, deprecation or removal |
| 82 | from the lib interface, any change to configuration options (including |
| 83 | deprecation), CLI additions or deprecations, major feature additions, and |
| 84 | anything backwards incompatible or would require a user to take note or do |
| 85 | something extra. |
| 86 | |
| 87 | .. _reno: http://docs.openstack.org/developer/reno/ |
Matthew Treinish | 5507888 | 2014-08-12 19:01:34 -0400 | [diff] [blame] | 88 | |
Matthew Treinish | 16dd51b | 2014-06-11 12:04:51 -0400 | [diff] [blame] | 89 | When to approve |
| 90 | --------------- |
| 91 | * Every patch needs two +2s before being approved. |
| 92 | * Its ok to hold off on an approval until a subject matter expert reviews it |
| 93 | * If a patch has already been approved but requires a trivial rebase to merge, |
| 94 | you do not have to wait for a second +2, since the patch has already had |
| 95 | two +2s. |