blob: 31cd3b7a0ab1c63023ea22cd44f0d20b5cb4986f [file] [log] [blame]
Felipe Monteiroc4589322017-06-09 19:42:50 +01001========================
2Team and repository tags
3========================
4
shangxiaobj11b02322017-08-14 22:45:11 -07005.. image:: https://governance.openstack.org/tc/badges/patrole.svg
6 :target: https://governance.openstack.org/tc/reference/tags/index.html
Felipe Monteiroc4589322017-06-09 19:42:50 +01007
Felipe Monteiroc4589322017-06-09 19:42:50 +01008Patrole - RBAC Integration Tempest Plugin
9=========================================
DavidPurcell663aedf2017-01-03 10:01:14 -050010
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +010011Patrole is a set of integration tests to be run against a live OpenStack
12cluster. It has a battery of tests dedicated to validating the correctness and
13integrity of the cloud's RBAC implementation.
14
15More importantly, Patrole is a security validation tool for verifying that
16Role-Based Access Control is correctly configured and enforced in an OpenStack
17cloud. It runs `Tempest`_-based API tests using specified RBAC roles, thus
18allowing deployments to verify that only intended roles have access to those
19APIs.
DavidPurcell663aedf2017-01-03 10:01:14 -050020
Felipe Monteiro780210d2017-07-17 22:21:53 +010021Patrole currently offers testing for the following OpenStack services: Nova,
22Neutron, Glance, Cinder and Keystone.
DavidPurcell663aedf2017-01-03 10:01:14 -050023
Felipe Monteiroc2873892017-11-15 06:09:02 +000024Patrole is currently undergoing heavy development. As more projects move
25toward policy in code, Patrole will align its testing with the appropriate
26documentation.
27
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +010028* Free software: Apache license
29* Documentation: https://docs.openstack.org/patrole/latest
30* Source: https://git.openstack.org/cgit/openstack/patrole
31* Bugs: https://bugs.launchpad.net/patrole
32* Release notes: https://docs.openstack.org/releasenotes/patrole/
Felipe Monteiro443d39c2018-04-08 17:05:33 -040033
Felipe Monteiroe9176552018-07-16 14:39:55 -040034.. _design-principles:
35
Felipe Monteiroc2873892017-11-15 06:09:02 +000036Design Principles
37-----------------
38
ghanshyam9ee07cf2018-08-16 08:15:42 +000039As a `Tempest plugin`_, Patrole borrows some design principles from `Tempest design principles`_,
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +010040but not all, as its testing scope is confined to policies.
Felipe Monteiroc2873892017-11-15 06:09:02 +000041
42* *Stability*. Patrole uses OpenStack public interfaces. Tests in Patrole
43 should only touch public OpenStack APIs.
44* *Atomicity*. Patrole tests should be atomic: they should test policies in
45 isolation. Unlike Tempest, a Patrole test strives to only call a single
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +010046 endpoint at a time. This is because it is important to validate each policy
47 is authorized correctly and the best way to do that is to validate each
48 policy alone, to avoid test contamination.
Felipe Monteiro543f7b92018-06-10 13:38:31 -040049* *Complete coverage*. Patrole should validate all policy in code defaults. For
50 testing, Patrole uses the API-to-policy mapping contained in each project's
51 `policy in code`_ documentation where applicable.
52
53 For example, Nova's policy in code documentation is located in the
54 `Nova repository`_ under ``nova/policies``. Likewise, Keystone's policy in
55 code documentation is located in the `Keystone repository`_ under
56 ``keystone/common/policies``. The other OpenStack services follow the same
57 directory layout pattern with respect to policy in code.
58
59 .. note::
60
61 Realistically this is not always possible because some services have
62 not yet moved to policy in code.
63
Felipe Monteiroe9176552018-07-16 14:39:55 -040064* *Customizable*. Patrole should be able to validate custom policy overrides to
65 ensure that those overrides enhance rather than undermine the cloud's RBAC
66 configuration. In addition, Patrole should be able to validate any role.
Felipe Monteiro543f7b92018-06-10 13:38:31 -040067* *Self-cleaning*. Patrole should attempt to clean up after itself; whenever
Felipe Monteiroc2873892017-11-15 06:09:02 +000068 possible we should tear down resources when done.
69
70 .. note::
71
72 Patrole modifies roles dynamically in the background, which affects
73 pre-provisioned credentials. Work is currently underway to clean up
74 modifications made to pre-provisioned credentials.
75
Felipe Monteiro543f7b92018-06-10 13:38:31 -040076* *Self-testing*. Patrole should be self-testing.
77
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +010078.. _Tempest plugin: https://docs.openstack.org/tempest/latest/plugin.html
ghanshyam9ee07cf2018-08-16 08:15:42 +000079.. _Tempest design principles: https://docs.openstack.org/tempest/latest/overview.html#design-principles
Felipe Monteiro543f7b92018-06-10 13:38:31 -040080.. _policy in code: https://specs.openstack.org/openstack/oslo-specs/specs/newton/policy-in-code.html
81.. _Nova repository: https://github.com/openstack/nova/tree/master/nova/policies
82.. _Keystone repository: https://github.com/openstack/keystone/tree/master/keystone/common/policies
Felipe Monteiroc2873892017-11-15 06:09:02 +000083
DavidPurcell663aedf2017-01-03 10:01:14 -050084Features
Felipe Monteiro780210d2017-07-17 22:21:53 +010085--------
86* Validation of default policy definitions located in policy.json files.
87* Validation of in-code policy definitions.
88* Validation of custom policy file definitions that override default policy
89 definitions.
90* Built-in positive and negative testing. Positive and negative testing
91 are performed using the same tests and role-switching.
92* Valdation of custom roles as well as default OpenStack roles.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +010093
94.. note::
95
Felipe Monteiro780210d2017-07-17 22:21:53 +010096 Patrole does not yet support policy.yaml files, the new file format for
97 policy files in OpenStack.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +010098
99How It Works
Felipe Monteiro780210d2017-07-17 22:21:53 +0100100------------
101Patrole leverages ``oslo.policy`` (OpenStack's policy enforcement engine) to
102determine whether a given role is allowed to perform a policy action, given a
103specific role and OpenStack service. The output from ``oslo.policy`` (the
104expected result) and the actual result from test execution are compared to
105each other: if both results match, then the test passes; else it fails.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100106
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100107Terminology
108^^^^^^^^^^^
109* Expected Result - The expected result of a given test.
110* Actual Result - The actual result of a given test.
111* Final Result - A match between both expected and actual results. A mismatch
112 in the expected result and the actual result will result in a test failure.
113
114 * Expected: Pass | Actual: Pass - Test Case Success
115 * Expected: Pass | Actual: Fail - Test Case Under-Permission Failure
116 * Expected: Fail | Actual: Pass - Test Case Over-Permission Failure
117 * Expected: Fail | Actual: Fail (Expected exception) - Test Case Success
118 * Expected: Fail | Actual: Fail (Unexpected exception) - Test Case Failure
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100119
Felipe Monteiro780210d2017-07-17 22:21:53 +0100120Quickstart
Felipe Monteiro7c7b5702017-07-21 01:43:42 +0100121----------
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100122To run Patrole, you must first have `Tempest`_ installed and configured
ghanshyam9ee07cf2018-08-16 08:15:42 +0000123properly. Please reference `Tempest_quickstart`_ guide to do so. Follow all
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100124the steps outlined therein. Afterward, proceed with the steps below.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100125
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100126#. You first need to install Patrole. This is done with pip after you check out
127 the Patrole repo::
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100128
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100129 $ git clone https://git.openstack.org/openstack/patrole
130 $ pip install patrole/
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100131
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100132 This can be done within a venv.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100133
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100134 .. note::
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100135
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100136 You may also install Patrole from source code by running::
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100137
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100138 pip install -e patrole/
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100139
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100140#. Next you must properly configure Patrole, which is relatively
141 straightforward. For details on configuring Patrole refer to the
ghanshyam9ee07cf2018-08-16 08:15:42 +0000142 `Patrole Configuration <https://docs.openstack.org/patrole/latest/configuration.html#patrole-configuration>`_.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100143
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100144#. Once the configuration is done you're now ready to run Patrole. This can
145 be done using the `tempest_run`_ command. This can be done by running::
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100146
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100147 $ tempest run --regex '^patrole_tempest_plugin\.tests\.api'
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100148
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100149 There is also the option to use testr directly, or any `testr`_ based test
150 runner, like `ostestr`_. For example, from the workspace dir run::
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100151
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100152 $ stestr --regex '(?!.*\[.*\bslow\b.*\])(^patrole_tempest_plugin\.tests\.api))'
153
154 will run the same set of tests as the default gate jobs.
155
Felipe Monteiro0d3c7432018-10-28 02:14:22 +0000156 You can also run Patrole tests using `tox`_, but as Patrole needs access to
157 global packages use ``--sitepackages`` argument. To do so, ``cd`` into the
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100158 **Tempest** directory and run::
159
Felipe Monteiro0d3c7432018-10-28 02:14:22 +0000160 $ tox -eall --sitepackages -- patrole_tempest_plugin.tests.api
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100161
162 .. note::
163
164 It is possible to run Patrole via ``tox -eall`` in order to run Patrole
165 isolated from other plugins. This can be accomplished by including the
166 installation of services that currently use policy in code -- for example,
167 Nova and Keystone. For example::
168
169 $ tox -evenv-tempest -- pip install /opt/stack/patrole /opt/stack/keystone /opt/stack/nova
170 $ tox -eall -- patrole_tempest_plugin.tests.api
171
172#. Log information from tests is captured in ``tempest.log`` under the Tempest
173 repository. Some Patrole debugging information is captured in that log
ghanshyam9ee07cf2018-08-16 08:15:42 +0000174 related to expected test results and `Role Overriding <https://docs.openstack.org/patrole/latest/framework/rbac_utils.html#role-overriding>`_.
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100175
176 More detailed RBAC testing log output is emitted to ``patrole.log`` under
177 the Patrole repository. To configure Patrole's logging, see the
ghanshyam9ee07cf2018-08-16 08:15:42 +0000178 `Patrole Configuration Guide <https://docs.openstack.org/patrole/latest/configuration.html#patrole-configuration>`_.
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100179
180.. _Tempest: https://github.com/openstack/tempest
ghanshyam9ee07cf2018-08-16 08:15:42 +0000181.. _Tempest_quickstart: https://docs.openstack.org/tempest/latest/overview.html#quickstart
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100182.. _tempest_run: https://docs.openstack.org/tempest/latest/run.html
183.. _testr: https://testrepository.readthedocs.org/en/latest/MANUAL.html
184.. _ostestr: https://docs.openstack.org/os-testr/latest/
185.. _tox: https://tox.readthedocs.io/en/latest/
186
187RBAC Tests
188----------
189
Mykola Yakovlieve0f35502018-09-26 18:26:57 -0500190To change the roles that the patrole tests are being run as, edit
191``rbac_test_roles`` in the ``patrole`` section of tempest.conf: ::
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100192
193 [patrole]
Mykola Yakovlieve0f35502018-09-26 18:26:57 -0500194 rbac_test_role = member,reader
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100195 ...
196
197.. note::
198
Mykola Yakovlieve0f35502018-09-26 18:26:57 -0500199 The ``rbac_test_roles`` is service-specific. member, for example,
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100200 is an arbitrary role, but by convention is used to designate the default
201 non-admin role in the system. Most Patrole tests should be run with
202 **admin** and **member** roles. However, other services may use entirely
Mykola Yakovlieve0f35502018-09-26 18:26:57 -0500203 different roles or role combinations.
Felipe Monteiroe5ee4be2018-06-18 21:39:28 +0100204
205For more information about the member role and its nomenclature,
206please see: `<https://ask.openstack.org/en/question/4759/member-vs-_member_/>`__.
207
208Unit Tests
209----------
210
211Patrole also has a set of unit tests which test the Patrole code itself. These
212tests can be run by specifying the test discovery path::
213
214 $ stestr --test-path ./patrole_tempest_plugin/tests/unit run
215
216By setting ``--test-path`` option to ``./patrole_tempest_plugin/tests/unit``
217it specifies that test discovery should only be run on the unit test directory.
218
219Alternatively, there are the py27 and py35 tox jobs which will run the unit
220tests with the corresponding version of Python.
221
222One common activity is to just run a single test; you can do this with tox
223simply by specifying to just run py27 or py35 tests against a single test::
224
225 $ tox -e py27 -- -n patrole_tempest_plugin.tests.unit.test_rbac_utils.RBACUtilsTest.test_override_role_with_missing_admin_role
226
227Or all tests in the test_rbac_utils.py file::
228
229 $ tox -e py27 -- -n patrole_tempest_plugin.tests.unit.test_rbac_utils
230
231You may also use regular expressions to run any matching tests::
232
233 $ tox -e py27 -- test_rbac_utils
234
235For more information on these options and details about stestr, please see the
236`stestr documentation <http://stestr.readthedocs.io/en/latest/MANUAL.html>`_.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100237
Felipe Monteiro780210d2017-07-17 22:21:53 +0100238Release Versioning
Felipe Monteiro7c7b5702017-07-21 01:43:42 +0100239------------------
Felipe Monteiro780210d2017-07-17 22:21:53 +0100240`Patrole Release Notes <https://docs.openstack.org/releasenotes/patrole/>`_
241shows which changes have been released for each version.
Felipe Monteiro7bc35dc2017-04-19 21:11:46 +0100242
Felipe Monteiro780210d2017-07-17 22:21:53 +0100243Patrole's release versioning follows Tempest's conventions. Like Tempest,
244Patrole is branchless and uses versioning instead.