Project boilerplate and base modules
Change-Id: I2f7031c44afdc8faad33ba7818a90fe5cdc001cc
This commit is contained in:
		
							
								
								
									
										7
									
								
								.coveragerc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.coveragerc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| [run] | ||||
| branch = True | ||||
| source = gbp | ||||
| omit = gbp/tests/*,gbp/openstack/* | ||||
|  | ||||
| [report] | ||||
| ignore-errors = True | ||||
							
								
								
									
										54
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | ||||
| *.py[cod] | ||||
| .venv | ||||
|  | ||||
| # C extensions | ||||
| *.so | ||||
|  | ||||
| # Packages | ||||
| *.egg | ||||
| *.egg-info | ||||
| dist | ||||
| build | ||||
| eggs | ||||
| parts | ||||
| bin | ||||
| var | ||||
| sdist | ||||
| develop-eggs | ||||
| .installed.cfg | ||||
| lib | ||||
| lib64 | ||||
|  | ||||
| # Installer logs | ||||
| pip-log.txt | ||||
|  | ||||
| # Unit test / coverage reports | ||||
| .coverage | ||||
| .tox | ||||
| nosetests.xml | ||||
| .testrepository | ||||
| subunit.log | ||||
|  | ||||
| # Translations | ||||
| *.mo | ||||
|  | ||||
| # Mr Developer | ||||
| .mr.developer.cfg | ||||
| .project | ||||
| .pydevproject | ||||
|  | ||||
| # Complexity | ||||
| output/*.html | ||||
| output/*/index.html | ||||
|  | ||||
| # Sphinx | ||||
| doc/build | ||||
|  | ||||
| # pbr generates these | ||||
| AUTHORS | ||||
| ChangeLog | ||||
|  | ||||
| # Editors | ||||
| *~ | ||||
| .*.swp | ||||
| .*sw? | ||||
							
								
								
									
										7
									
								
								.testr.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								.testr.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| [DEFAULT] | ||||
| test_command=OS_STDOUT_CAPTURE=${OS_STDOUT_CAPTURE:-1} \ | ||||
|              OS_STDERR_CAPTURE=${OS_STDERR_CAPTURE:-1} \ | ||||
|              OS_TEST_TIMEOUT=${OS_TEST_TIMEOUT:-60} \ | ||||
|              ${PYTHON:-python} -m subunit.run discover -t ./ . $LISTOPT $IDOPTION | ||||
| test_id_option=--load-list $IDFILE | ||||
| test_list_option=--list | ||||
							
								
								
									
										17
									
								
								CONTRIBUTING.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								CONTRIBUTING.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | ||||
| If you would like to contribute to the development of OpenStack, | ||||
| you must follow the steps in the "If you're a developer, start here" | ||||
| section of this page: | ||||
|  | ||||
|    http://wiki.openstack.org/HowToContribute | ||||
|  | ||||
| Once those steps have been completed, changes to OpenStack | ||||
| should be submitted for review via the Gerrit tool, following | ||||
| the workflow documented at: | ||||
|  | ||||
|    http://wiki.openstack.org/GerritWorkflow | ||||
|  | ||||
| Pull requests submitted through GitHub will be ignored. | ||||
|  | ||||
| Bugs should be filed on Launchpad, not GitHub: | ||||
|  | ||||
|    https://bugs.launchpad.net/group-based-policy | ||||
							
								
								
									
										4
									
								
								HACKING.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								HACKING.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| Group Based Policy Style Commandments | ||||
| =============================================== | ||||
|  | ||||
| Read the OpenStack Style Commandments http://docs.openstack.org/developer/hacking/ | ||||
							
								
								
									
										175
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								LICENSE
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,175 @@ | ||||
|  | ||||
|                                  Apache License | ||||
|                            Version 2.0, January 2004 | ||||
|                         http://www.apache.org/licenses/ | ||||
|  | ||||
|    TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION | ||||
|  | ||||
|    1. Definitions. | ||||
|  | ||||
|       "License" shall mean the terms and conditions for use, reproduction, | ||||
|       and distribution as defined by Sections 1 through 9 of this document. | ||||
|  | ||||
|       "Licensor" shall mean the copyright owner or entity authorized by | ||||
|       the copyright owner that is granting the License. | ||||
|  | ||||
|       "Legal Entity" shall mean the union of the acting entity and all | ||||
|       other entities that control, are controlled by, or are under common | ||||
|       control with that entity. For the purposes of this definition, | ||||
|       "control" means (i) the power, direct or indirect, to cause the | ||||
|       direction or management of such entity, whether by contract or | ||||
|       otherwise, or (ii) ownership of fifty percent (50%) or more of the | ||||
|       outstanding shares, or (iii) beneficial ownership of such entity. | ||||
|  | ||||
|       "You" (or "Your") shall mean an individual or Legal Entity | ||||
|       exercising permissions granted by this License. | ||||
|  | ||||
|       "Source" form shall mean the preferred form for making modifications, | ||||
|       including but not limited to software source code, documentation | ||||
|       source, and configuration files. | ||||
|  | ||||
|       "Object" form shall mean any form resulting from mechanical | ||||
|       transformation or translation of a Source form, including but | ||||
|       not limited to compiled object code, generated documentation, | ||||
|       and conversions to other media types. | ||||
|  | ||||
|       "Work" shall mean the work of authorship, whether in Source or | ||||
|       Object form, made available under the License, as indicated by a | ||||
|       copyright notice that is included in or attached to the work | ||||
|       (an example is provided in the Appendix below). | ||||
|  | ||||
|       "Derivative Works" shall mean any work, whether in Source or Object | ||||
|       form, that is based on (or derived from) the Work and for which the | ||||
|       editorial revisions, annotations, elaborations, or other modifications | ||||
|       represent, as a whole, an original work of authorship. For the purposes | ||||
|       of this License, Derivative Works shall not include works that remain | ||||
|       separable from, or merely link (or bind by name) to the interfaces of, | ||||
|       the Work and Derivative Works thereof. | ||||
|  | ||||
|       "Contribution" shall mean any work of authorship, including | ||||
|       the original version of the Work and any modifications or additions | ||||
|       to that Work or Derivative Works thereof, that is intentionally | ||||
|       submitted to Licensor for inclusion in the Work by the copyright owner | ||||
|       or by an individual or Legal Entity authorized to submit on behalf of | ||||
|       the copyright owner. For the purposes of this definition, "submitted" | ||||
|       means any form of electronic, verbal, or written communication sent | ||||
|       to the Licensor or its representatives, including but not limited to | ||||
|       communication on electronic mailing lists, source code control systems, | ||||
|       and issue tracking systems that are managed by, or on behalf of, the | ||||
|       Licensor for the purpose of discussing and improving the Work, but | ||||
|       excluding communication that is conspicuously marked or otherwise | ||||
|       designated in writing by the copyright owner as "Not a Contribution." | ||||
|  | ||||
|       "Contributor" shall mean Licensor and any individual or Legal Entity | ||||
|       on behalf of whom a Contribution has been received by Licensor and | ||||
|       subsequently incorporated within the Work. | ||||
|  | ||||
|    2. Grant of Copyright License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       copyright license to reproduce, prepare Derivative Works of, | ||||
|       publicly display, publicly perform, sublicense, and distribute the | ||||
|       Work and such Derivative Works in Source or Object form. | ||||
|  | ||||
|    3. Grant of Patent License. Subject to the terms and conditions of | ||||
|       this License, each Contributor hereby grants to You a perpetual, | ||||
|       worldwide, non-exclusive, no-charge, royalty-free, irrevocable | ||||
|       (except as stated in this section) patent license to make, have made, | ||||
|       use, offer to sell, sell, import, and otherwise transfer the Work, | ||||
|       where such license applies only to those patent claims licensable | ||||
|       by such Contributor that are necessarily infringed by their | ||||
|       Contribution(s) alone or by combination of their Contribution(s) | ||||
|       with the Work to which such Contribution(s) was submitted. If You | ||||
|       institute patent litigation against any entity (including a | ||||
|       cross-claim or counterclaim in a lawsuit) alleging that the Work | ||||
|       or a Contribution incorporated within the Work constitutes direct | ||||
|       or contributory patent infringement, then any patent licenses | ||||
|       granted to You under this License for that Work shall terminate | ||||
|       as of the date such litigation is filed. | ||||
|  | ||||
|    4. Redistribution. You may reproduce and distribute copies of the | ||||
|       Work or Derivative Works thereof in any medium, with or without | ||||
|       modifications, and in Source or Object form, provided that You | ||||
|       meet the following conditions: | ||||
|  | ||||
|       (a) You must give any other recipients of the Work or | ||||
|           Derivative Works a copy of this License; and | ||||
|  | ||||
|       (b) You must cause any modified files to carry prominent notices | ||||
|           stating that You changed the files; and | ||||
|  | ||||
|       (c) You must retain, in the Source form of any Derivative Works | ||||
|           that You distribute, all copyright, patent, trademark, and | ||||
|           attribution notices from the Source form of the Work, | ||||
|           excluding those notices that do not pertain to any part of | ||||
|           the Derivative Works; and | ||||
|  | ||||
|       (d) If the Work includes a "NOTICE" text file as part of its | ||||
|           distribution, then any Derivative Works that You distribute must | ||||
|           include a readable copy of the attribution notices contained | ||||
|           within such NOTICE file, excluding those notices that do not | ||||
|           pertain to any part of the Derivative Works, in at least one | ||||
|           of the following places: within a NOTICE text file distributed | ||||
|           as part of the Derivative Works; within the Source form or | ||||
|           documentation, if provided along with the Derivative Works; or, | ||||
|           within a display generated by the Derivative Works, if and | ||||
|           wherever such third-party notices normally appear. The contents | ||||
|           of the NOTICE file are for informational purposes only and | ||||
|           do not modify the License. You may add Your own attribution | ||||
|           notices within Derivative Works that You distribute, alongside | ||||
|           or as an addendum to the NOTICE text from the Work, provided | ||||
|           that such additional attribution notices cannot be construed | ||||
|           as modifying the License. | ||||
|  | ||||
|       You may add Your own copyright statement to Your modifications and | ||||
|       may provide additional or different license terms and conditions | ||||
|       for use, reproduction, or distribution of Your modifications, or | ||||
|       for any such Derivative Works as a whole, provided Your use, | ||||
|       reproduction, and distribution of the Work otherwise complies with | ||||
|       the conditions stated in this License. | ||||
|  | ||||
|    5. Submission of Contributions. Unless You explicitly state otherwise, | ||||
|       any Contribution intentionally submitted for inclusion in the Work | ||||
|       by You to the Licensor shall be under the terms and conditions of | ||||
|       this License, without any additional terms or conditions. | ||||
|       Notwithstanding the above, nothing herein shall supersede or modify | ||||
|       the terms of any separate license agreement you may have executed | ||||
|       with Licensor regarding such Contributions. | ||||
|  | ||||
|    6. Trademarks. This License does not grant permission to use the trade | ||||
|       names, trademarks, service marks, or product names of the Licensor, | ||||
|       except as required for reasonable and customary use in describing the | ||||
|       origin of the Work and reproducing the content of the NOTICE file. | ||||
|  | ||||
|    7. Disclaimer of Warranty. Unless required by applicable law or | ||||
|       agreed to in writing, Licensor provides the Work (and each | ||||
|       Contributor provides its Contributions) on an "AS IS" BASIS, | ||||
|       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
|       implied, including, without limitation, any warranties or conditions | ||||
|       of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A | ||||
|       PARTICULAR PURPOSE. You are solely responsible for determining the | ||||
|       appropriateness of using or redistributing the Work and assume any | ||||
|       risks associated with Your exercise of permissions under this License. | ||||
|  | ||||
|    8. Limitation of Liability. In no event and under no legal theory, | ||||
|       whether in tort (including negligence), contract, or otherwise, | ||||
|       unless required by applicable law (such as deliberate and grossly | ||||
|       negligent acts) or agreed to in writing, shall any Contributor be | ||||
|       liable to You for damages, including any direct, indirect, special, | ||||
|       incidental, or consequential damages of any character arising as a | ||||
|       result of this License or out of the use or inability to use the | ||||
|       Work (including but not limited to damages for loss of goodwill, | ||||
|       work stoppage, computer failure or malfunction, or any and all | ||||
|       other commercial damages or losses), even if such Contributor | ||||
|       has been advised of the possibility of such damages. | ||||
|  | ||||
|    9. Accepting Warranty or Additional Liability. While redistributing | ||||
|       the Work or Derivative Works thereof, You may choose to offer, | ||||
|       and charge a fee for, acceptance of support, warranty, indemnity, | ||||
|       or other liability obligations and/or rights consistent with this | ||||
|       License. However, in accepting such obligations, You may act only | ||||
|       on Your own behalf and on Your sole responsibility, not on behalf | ||||
|       of any other Contributor, and only if You agree to indemnify, | ||||
|       defend, and hold each Contributor harmless for any liability | ||||
|       incurred by, or claims asserted against, such Contributor by reason | ||||
|       of your accepting any such warranty or additional liability. | ||||
							
								
								
									
										6
									
								
								MANIFEST.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								MANIFEST.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | ||||
| include AUTHORS | ||||
| include ChangeLog | ||||
| exclude .gitignore | ||||
| exclude .gitreview | ||||
|  | ||||
| global-exclude *.pyc | ||||
							
								
								
									
										75
									
								
								doc/source/conf.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										75
									
								
								doc/source/conf.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,75 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #    http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
| # implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
|  | ||||
| import os | ||||
| import sys | ||||
|  | ||||
| sys.path.insert(0, os.path.abspath('../..')) | ||||
| # -- General configuration ---------------------------------------------------- | ||||
|  | ||||
| # Add any Sphinx extension module names here, as strings. They can be | ||||
| # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom ones. | ||||
| extensions = [ | ||||
|     'sphinx.ext.autodoc', | ||||
|     #'sphinx.ext.intersphinx', | ||||
|     'oslosphinx' | ||||
| ] | ||||
|  | ||||
| # autodoc generation is a bit aggressive and a nuisance when doing heavy | ||||
| # text edit cycles. | ||||
| # execute "export SPHINX_DEBUG=1" in your terminal to disable | ||||
|  | ||||
| # The suffix of source filenames. | ||||
| source_suffix = '.rst' | ||||
|  | ||||
| # The master toctree document. | ||||
| master_doc = 'index' | ||||
|  | ||||
| # General information about the project. | ||||
| project = u'group-based-policy' | ||||
| copyright = u'2013, OpenStack Foundation' | ||||
|  | ||||
| # If true, '()' will be appended to :func: etc. cross-reference text. | ||||
| add_function_parentheses = True | ||||
|  | ||||
| # If true, the current module name will be prepended to all description | ||||
| # unit titles (such as .. function::). | ||||
| add_module_names = True | ||||
|  | ||||
| # The name of the Pygments (syntax highlighting) style to use. | ||||
| pygments_style = 'sphinx' | ||||
|  | ||||
| # -- Options for HTML output -------------------------------------------------- | ||||
|  | ||||
| # The theme to use for HTML and HTML Help pages.  Major themes that come with | ||||
| # Sphinx are currently 'default' and 'sphinxdoc'. | ||||
| # html_theme_path = ["."] | ||||
| # html_theme = '_theme' | ||||
| # html_static_path = ['static'] | ||||
|  | ||||
| # Output file base name for HTML help builder. | ||||
| htmlhelp_basename = '%sdoc' % project | ||||
|  | ||||
| # Grouping the document tree into LaTeX files. List of tuples | ||||
| # (source start file, target name, title, author, documentclass | ||||
| # [howto/manual]). | ||||
| latex_documents = [ | ||||
|     ('index', | ||||
|      '%s.tex' % project, | ||||
|      u'%s Documentation' % project, | ||||
|      u'OpenStack Foundation', 'manual'), | ||||
| ] | ||||
|  | ||||
| # Example configuration for intersphinx: refer to the Python standard library. | ||||
| #intersphinx_mapping = {'http://docs.python.org/': None} | ||||
							
								
								
									
										4
									
								
								doc/source/contributing.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								doc/source/contributing.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,4 @@ | ||||
| ============ | ||||
| Contributing | ||||
| ============ | ||||
| .. include:: ../../CONTRIBUTING.rst | ||||
							
								
								
									
										24
									
								
								doc/source/index.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								doc/source/index.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| .. group-based-policy documentation master file, created by | ||||
|    sphinx-quickstart on Tue Jul  9 22:26:36 2013. | ||||
|    You can adapt this file completely to your liking, but it should at least | ||||
|    contain the root `toctree` directive. | ||||
|  | ||||
| Welcome to group-based-policy's documentation! | ||||
| ======================================================== | ||||
|  | ||||
| Contents: | ||||
|  | ||||
| .. toctree:: | ||||
|    :maxdepth: 2 | ||||
|  | ||||
|    readme | ||||
|    installation | ||||
|    usage | ||||
|    contributing | ||||
|  | ||||
| Indices and tables | ||||
| ================== | ||||
|  | ||||
| * :ref:`genindex` | ||||
| * :ref:`modindex` | ||||
| * :ref:`search` | ||||
							
								
								
									
										12
									
								
								doc/source/installation.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								doc/source/installation.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| ============ | ||||
| Installation | ||||
| ============ | ||||
|  | ||||
| At the command line:: | ||||
|  | ||||
|     $ pip install group-based-policy | ||||
|  | ||||
| Or, if you have virtualenvwrapper installed:: | ||||
|  | ||||
|     $ mkvirtualenv group-based-policy | ||||
|     $ pip install group-based-policy | ||||
							
								
								
									
										1
									
								
								doc/source/readme.rst
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								doc/source/readme.rst
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| .. include:: ../../README.rst | ||||
| @@ -0,0 +1,19 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
|  | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
| # not use this file except in compliance with the License. You may obtain | ||||
| # a copy of the License at | ||||
| # | ||||
| #      http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||||
| # License for the specific language governing permissions and limitations | ||||
| # under the License. | ||||
|  | ||||
| import pbr.version | ||||
|  | ||||
|  | ||||
| __version__ = pbr.version.VersionInfo( | ||||
|     'group-based-policy').version_string() | ||||
|   | ||||
							
								
								
									
										0
									
								
								gbp/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								gbp/tests/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
								
								
									
										21
									
								
								gbp/tests/base.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								gbp/tests/base.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,21 @@ | ||||
| # Copyright 2010-2011 OpenStack Foundation | ||||
| # Copyright (c) 2013 Hewlett-Packard Development Company, L.P. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
| # not use this file except in compliance with the License. You may obtain | ||||
| # a copy of the License at | ||||
| # | ||||
| #      http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||||
| # License for the specific language governing permissions and limitations | ||||
| # under the License. | ||||
|  | ||||
| import testtools | ||||
|  | ||||
|  | ||||
| class TestCase(testtools.TestCase): | ||||
|  | ||||
|     """Test case base class for all unit tests.""" | ||||
							
								
								
									
										28
									
								
								gbp/tests/test_gbp.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								gbp/tests/test_gbp.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| # -*- coding: utf-8 -*- | ||||
|  | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
| # not use this file except in compliance with the License. You may obtain | ||||
| # a copy of the License at | ||||
| # | ||||
| #      http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||||
| # License for the specific language governing permissions and limitations | ||||
| # under the License. | ||||
|  | ||||
| """ | ||||
| test_group-based-policy | ||||
| ---------------------------------- | ||||
|  | ||||
| Tests for `group-based-policy` module. | ||||
| """ | ||||
|  | ||||
| from gbp.tests import base | ||||
|  | ||||
|  | ||||
| class TestGroupBasedPolicy(base.TestCase): | ||||
|  | ||||
|     def test_something(self): | ||||
|         pass | ||||
							
								
								
									
										11
									
								
								openstack-common.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								openstack-common.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
| [DEFAULT] | ||||
|  | ||||
| # The list of modules to copy from oslo-incubator.git | ||||
|  | ||||
| module=install_venv_common | ||||
| module=install_venv | ||||
| module=with_venv | ||||
| module=test | ||||
|  | ||||
| # The base module to hold the copy of openstack.common | ||||
| base=gbp | ||||
							
								
								
									
										5
									
								
								requirements.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								requirements.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| # The order of packages is significant, because pip processes them in the order | ||||
| # of appearance. Changing the order has an impact on the overall integration | ||||
| # process, which may cause wedges in the gate later. | ||||
|  | ||||
| gbptestneutron>=0.9.0 | ||||
							
								
								
									
										227
									
								
								run_tests.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										227
									
								
								run_tests.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,227 @@ | ||||
| #!/bin/bash | ||||
|  | ||||
| set -eu | ||||
|  | ||||
| function usage { | ||||
|   echo "Usage: $0 [OPTION]..." | ||||
|   echo "Run Group Based Policy's test suite(s)" | ||||
|   echo "" | ||||
|   echo "  -V, --virtual-env           Always use virtualenv.  Install automatically if not present" | ||||
|   echo "  -N, --no-virtual-env        Don't use virtualenv.  Run tests in local environment" | ||||
|   echo "  -s, --no-site-packages      Isolate the virtualenv from the global Python environment" | ||||
|   echo "  -r, --recreate-db           Recreate the test database (deprecated, as this is now the default)." | ||||
|   echo "  -n, --no-recreate-db        Don't recreate the test database." | ||||
|   echo "  -f, --force                 Force a clean re-build of the virtual environment. Useful when dependencies have been added." | ||||
|   echo "  -u, --update                Update the virtual environment with any newer package versions" | ||||
|   echo "  -p, --pep8                  Just run PEP8 and HACKING compliance check" | ||||
|   echo "  -P, --no-pep8               Don't run static code checks" | ||||
|   echo "  -c, --coverage              Generate coverage report" | ||||
|   echo "  -d, --debug                 Run tests with testtools instead of testr. This allows you to use the debugger." | ||||
|   echo "  -h, --help                  Print this usage message" | ||||
|   echo "  --virtual-env-path <path>   Location of the virtualenv directory" | ||||
|   echo "                               Default: \$(pwd)" | ||||
|   echo "  --virtual-env-name <name>   Name of the virtualenv directory" | ||||
|   echo "                               Default: .venv" | ||||
|   echo "  --tools-path <dir>          Location of the tools directory" | ||||
|   echo "                               Default: \$(pwd)" | ||||
|   echo "" | ||||
|   echo "Note: with no options specified, the script will try to run the tests in a virtual environment," | ||||
|   echo "      If no virtualenv is found, the script will ask if you would like to create one.  If you " | ||||
|   echo "      prefer to run tests NOT in a virtual environment, simply pass the -N option." | ||||
|   exit | ||||
| } | ||||
|  | ||||
| function process_options { | ||||
|   i=1 | ||||
|   while [ $i -le $# ]; do | ||||
|     case "${!i}" in | ||||
|       -h|--help) usage;; | ||||
|       -V|--virtual-env) always_venv=1; never_venv=0;; | ||||
|       -N|--no-virtual-env) always_venv=0; never_venv=1;; | ||||
|       -s|--no-site-packages) no_site_packages=1;; | ||||
|       -r|--recreate-db) recreate_db=1;; | ||||
|       -n|--no-recreate-db) recreate_db=0;; | ||||
|       -f|--force) force=1;; | ||||
|       -u|--update) update=1;; | ||||
|       -p|--pep8) just_pep8=1;; | ||||
|       -P|--no-pep8) no_pep8=1;; | ||||
|       -c|--coverage) coverage=1;; | ||||
|       -d|--debug) debug=1;; | ||||
|       --virtual-env-path) | ||||
|         (( i++ )) | ||||
|         venv_path=${!i} | ||||
|         ;; | ||||
|       --virtual-env-name) | ||||
|         (( i++ )) | ||||
|         venv_dir=${!i} | ||||
|         ;; | ||||
|       --tools-path) | ||||
|         (( i++ )) | ||||
|         tools_path=${!i} | ||||
|         ;; | ||||
|       -*) testropts="$testropts ${!i}";; | ||||
|       *) testrargs="$testrargs ${!i}" | ||||
|     esac | ||||
|     (( i++ )) | ||||
|   done | ||||
| } | ||||
|  | ||||
| tool_path=${tools_path:-$(pwd)} | ||||
| venv_path=${venv_path:-$(pwd)} | ||||
| venv_dir=${venv_name:-.venv} | ||||
| with_venv=tools/with_venv.sh | ||||
| always_venv=0 | ||||
| never_venv=0 | ||||
| force=0 | ||||
| no_site_packages=0 | ||||
| installvenvopts= | ||||
| testrargs= | ||||
| testropts= | ||||
| wrapper="" | ||||
| just_pep8=0 | ||||
| no_pep8=0 | ||||
| coverage=0 | ||||
| debug=0 | ||||
| recreate_db=1 | ||||
| update=0 | ||||
|  | ||||
| LANG=en_US.UTF-8 | ||||
| LANGUAGE=en_US:en | ||||
| LC_ALL=C | ||||
|  | ||||
| process_options $@ | ||||
| # Make our paths available to other scripts we call | ||||
| export venv_path | ||||
| export venv_dir | ||||
| export venv_name | ||||
| export tools_dir | ||||
| export venv=${venv_path}/${venv_dir} | ||||
|  | ||||
| if [ $no_site_packages -eq 1 ]; then | ||||
|   installvenvopts="--no-site-packages" | ||||
| fi | ||||
|  | ||||
|  | ||||
| function run_tests { | ||||
|   # Cleanup *pyc | ||||
|   ${wrapper} find . -type f -name "*.pyc" -delete | ||||
|  | ||||
|   if [ $debug -eq 1 ]; then | ||||
|     if [ "$testropts" = "" ] && [ "$testrargs" = "" ]; then | ||||
|       # Default to running all tests if specific test is not | ||||
|       # provided. | ||||
|       testrargs="discover ./gbp/" | ||||
|     fi | ||||
|     ${wrapper} python -m testtools.run $testropts $testrargs | ||||
|  | ||||
|     # Short circuit because all of the testr and coverage stuff | ||||
|     # below does not make sense when running testtools.run for | ||||
|     # debugging purposes. | ||||
|     return $? | ||||
|   fi | ||||
|  | ||||
|   if [ $coverage -eq 1 ]; then | ||||
|     TESTRTESTS="$TESTRTESTS --coverage" | ||||
|   else | ||||
|     TESTRTESTS="$TESTRTESTS --slowest" | ||||
|   fi | ||||
|  | ||||
|   # Just run the test suites in current environment | ||||
|   set +e | ||||
|   testrargs=`echo "$testrargs" | sed -e's/^\s*\(.*\)\s*$/\1/'` | ||||
|   TESTRTESTS="$TESTRTESTS --testr-args='--subunit $testropts $testrargs'" | ||||
|   OS_TEST_PATH=`echo $testrargs|grep -o 'gbp\.tests[^[:space:]:]*\+'|tr . /` | ||||
|   if [ -d "$OS_TEST_PATH" ]; then | ||||
|       wrapper="OS_TEST_PATH=$OS_TEST_PATH $wrapper" | ||||
|   elif [ -d "$(dirname $OS_TEST_PATH)" ]; then | ||||
|       wrapper="OS_TEST_PATH=$(dirname $OS_TEST_PATH) $wrapper" | ||||
|   fi | ||||
|   echo "Running \`${wrapper} $TESTRTESTS\`" | ||||
|   bash -c "${wrapper} $TESTRTESTS | ${wrapper} subunit2pyunit" | ||||
|   RESULT=$? | ||||
|   set -e | ||||
|  | ||||
|   copy_subunit_log | ||||
|  | ||||
|   if [ $coverage -eq 1 ]; then | ||||
|     echo "Generating coverage report in covhtml/" | ||||
|     # Don't compute coverage for common code, which is tested elsewhere | ||||
|     ${wrapper} coverage combine | ||||
|     ${wrapper} coverage html --include='gbp/*' --omit='gbp/openstack/common/*' -d covhtml -i | ||||
|   fi | ||||
|  | ||||
|   return $RESULT | ||||
| } | ||||
|  | ||||
| function copy_subunit_log { | ||||
|   LOGNAME=`cat .testrepository/next-stream` | ||||
|   LOGNAME=$(($LOGNAME - 1)) | ||||
|   LOGNAME=".testrepository/${LOGNAME}" | ||||
|   cp $LOGNAME subunit.log | ||||
| } | ||||
|  | ||||
| function run_pep8 { | ||||
|   echo "Running flake8 ..." | ||||
|  | ||||
|   ${wrapper} flake8 | ||||
| } | ||||
|  | ||||
|  | ||||
| TESTRTESTS="python -m neutron.openstack.common.lockutils python setup.py testr" | ||||
|  | ||||
| if [ $never_venv -eq 0 ] | ||||
| then | ||||
|   # Remove the virtual environment if --force used | ||||
|   if [ $force -eq 1 ]; then | ||||
|     echo "Cleaning virtualenv..." | ||||
|     rm -rf ${venv} | ||||
|   fi | ||||
|   if [ $update -eq 1 ]; then | ||||
|       echo "Updating virtualenv..." | ||||
|       python tools/install_venv.py $installvenvopts | ||||
|   fi | ||||
|   if [ -e ${venv} ]; then | ||||
|     wrapper="${with_venv}" | ||||
|   else | ||||
|     if [ $always_venv -eq 1 ]; then | ||||
|       # Automatically install the virtualenv | ||||
|       python tools/install_venv.py $installvenvopts | ||||
|       wrapper="${with_venv}" | ||||
|     else | ||||
|       echo -e "No virtual environment found...create one? (Y/n) \c" | ||||
|       read use_ve | ||||
|       if [ "x$use_ve" = "xY" -o "x$use_ve" = "x" -o "x$use_ve" = "xy" ]; then | ||||
|         # Install the virtualenv and run the test suite in it | ||||
|         python tools/install_venv.py $installvenvopts | ||||
|         wrapper=${with_venv} | ||||
|       fi | ||||
|     fi | ||||
|   fi | ||||
| fi | ||||
|  | ||||
| # Delete old coverage data from previous runs | ||||
| if [ $coverage -eq 1 ]; then | ||||
|     ${wrapper} coverage erase | ||||
| fi | ||||
|  | ||||
| if [ $just_pep8 -eq 1 ]; then | ||||
|     run_pep8 | ||||
|     exit | ||||
| fi | ||||
|  | ||||
| if [ $recreate_db -eq 1 ]; then | ||||
|     rm -f tests.sqlite | ||||
| fi | ||||
|  | ||||
| run_tests | ||||
|  | ||||
| # NOTE(sirp): we only want to run pep8 when we're running the full-test suite, | ||||
| # not when we're running tests individually. To handle this, we need to | ||||
| # distinguish between options (testropts), which begin with a '-', and | ||||
| # arguments (testrargs). | ||||
| if [ -z "$testrargs" ]; then | ||||
|   if [ $no_pep8 -eq 0 ]; then | ||||
|     run_pep8 | ||||
|   fi | ||||
| fi | ||||
|  | ||||
							
								
								
									
										48
									
								
								setup.cfg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								setup.cfg
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,48 @@ | ||||
| [metadata] | ||||
| name = group-based-policy | ||||
| version = 2014.2 | ||||
| summary = Openstack Group Based Policy | ||||
| description-file = | ||||
|     README.rst | ||||
| author = OpenStack | ||||
| author-email = openstack-dev@lists.openstack.org | ||||
| home-page = http://www.openstack.org/ | ||||
| classifier = | ||||
|     Environment :: OpenStack | ||||
|     Intended Audience :: Information Technology | ||||
|     Intended Audience :: System Administrators | ||||
|     License :: OSI Approved :: Apache Software License | ||||
|     Operating System :: POSIX :: Linux | ||||
|     Programming Language :: Python | ||||
|     Programming Language :: Python :: 2 | ||||
|     Programming Language :: Python :: 2.7 | ||||
|     Programming Language :: Python :: 2.6 | ||||
|     Programming Language :: Python :: 3 | ||||
|     Programming Language :: Python :: 3.3 | ||||
|     Programming Language :: Python :: 3.4 | ||||
|  | ||||
| [files] | ||||
| packages = | ||||
|     gbp | ||||
|  | ||||
| [build_sphinx] | ||||
| source-dir = doc/source | ||||
| build-dir = doc/build | ||||
| all_files = 1 | ||||
|  | ||||
| [upload_sphinx] | ||||
| upload-dir = doc/build/html | ||||
|  | ||||
| [compile_catalog] | ||||
| directory = group-based-policy/locale | ||||
| domain = group-based-policy | ||||
|  | ||||
| [update_catalog] | ||||
| domain = group-based-policy | ||||
| output_dir = group-based-policy/locale | ||||
| input_file = group-based-policy/locale/group-based-policy.pot | ||||
|  | ||||
| [extract_messages] | ||||
| keywords = _ gettext ngettext l_ lazy_gettext | ||||
| mapping_file = babel.cfg | ||||
| output_file = group-based-policy/locale/group-based-policy.pot | ||||
							
								
								
									
										22
									
								
								setup.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										22
									
								
								setup.py
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| #!/usr/bin/env python | ||||
| # Copyright (c) 2013 Hewlett-Packard Development Company, L.P. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #    http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or | ||||
| # implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
|  | ||||
| # THIS FILE IS MANAGED BY THE GLOBAL REQUIREMENTS REPO - DO NOT EDIT | ||||
| import setuptools | ||||
|  | ||||
| setuptools.setup( | ||||
|     setup_requires=['pbr'], | ||||
|     pbr=True) | ||||
							
								
								
									
										12
									
								
								test-requirements.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								test-requirements.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| # The order of packages is significant, because pip processes them in the order | ||||
| # of appearance. Changing the order has an impact on the overall integration | ||||
| # process, which may cause wedges in the gate later. | ||||
|  | ||||
| hacking>=0.9.2,<0.10 | ||||
|  | ||||
| discover | ||||
| sphinx>=1.1.2,!=1.2.0,<1.3 | ||||
| oslosphinx>=2.2.0.0a2 | ||||
| testrepository>=0.0.18 | ||||
| testtools>=0.9.34 | ||||
| WebTest>=2.0 | ||||
							
								
								
									
										29
									
								
								tools/config/check_uptodate.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										29
									
								
								tools/config/check_uptodate.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| #!/usr/bin/env bash | ||||
|  | ||||
| PROJECT_NAME=${PROJECT_NAME:-gbp} | ||||
| CFGFILE_NAME=${PROJECT_NAME}.conf.sample | ||||
|  | ||||
| if [ -e etc/${PROJECT_NAME}/${CFGFILE_NAME} ]; then | ||||
|     CFGFILE=etc/${PROJECT_NAME}/${CFGFILE_NAME} | ||||
| elif [ -e etc/${CFGFILE_NAME} ]; then | ||||
|     CFGFILE=etc/${CFGFILE_NAME} | ||||
| else | ||||
|     echo "${0##*/}: can not find config file" | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| TEMPDIR=`mktemp -d /tmp/${PROJECT_NAME}.XXXXXX` | ||||
| trap "rm -rf $TEMPDIR" EXIT | ||||
|  | ||||
| tools/config/generate_sample.sh -b ./ -p ${PROJECT_NAME} -o ${TEMPDIR} | ||||
| if [ $? != 0 ] | ||||
| then | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| if ! diff -u ${TEMPDIR}/${CFGFILE_NAME} ${CFGFILE} | ||||
| then | ||||
|    echo "${0##*/}: ${PROJECT_NAME}.conf.sample is not up to date." | ||||
|    echo "${0##*/}: Please run ${0%%${0##*/}}generate_sample.sh." | ||||
|    exit 1 | ||||
| fi | ||||
							
								
								
									
										138
									
								
								tools/config/generate_sample.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										138
									
								
								tools/config/generate_sample.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,138 @@ | ||||
| #!/usr/bin/env bash | ||||
|  | ||||
| # Generate sample configuration for your project. | ||||
| # | ||||
| # Aside from the command line flags, it also respects a config file which | ||||
| # should be named oslo.config.generator.rc and be placed in the same directory. | ||||
| # | ||||
| # You can then export the following variables: | ||||
| # GBP_CONFIG_GENERATOR_EXTRA_MODULES: list of modules to interrogate for options. | ||||
| # GBP_CONFIG_GENERATOR_EXTRA_LIBRARIES: list of libraries to discover. | ||||
| # GBP_CONFIG_GENERATOR_EXCLUDED_FILES: list of files to remove from automatic listing. | ||||
|  | ||||
| print_hint() { | ||||
|     echo "Try \`${0##*/} --help' for more information." >&2 | ||||
| } | ||||
|  | ||||
| PARSED_OPTIONS=$(getopt -n "${0##*/}" -o hb:p:m:l:o: \ | ||||
|                  --long help,base-dir:,package-name:,output-dir:,module:,library: -- "$@") | ||||
|  | ||||
| if [ $? != 0 ] ; then print_hint ; exit 1 ; fi | ||||
|  | ||||
| eval set -- "$PARSED_OPTIONS" | ||||
|  | ||||
| while true; do | ||||
|     case "$1" in | ||||
|         -h|--help) | ||||
|             echo "${0##*/} [options]" | ||||
|             echo "" | ||||
|             echo "options:" | ||||
|             echo "-h, --help                show brief help" | ||||
|             echo "-b, --base-dir=DIR        project base directory" | ||||
|             echo "-p, --package-name=NAME   project package name" | ||||
|             echo "-o, --output-dir=DIR      file output directory" | ||||
|             echo "-m, --module=MOD          extra python module to interrogate for options" | ||||
|             echo "-l, --library=LIB         extra library that registers options for discovery" | ||||
|             exit 0 | ||||
|             ;; | ||||
|         -b|--base-dir) | ||||
|             shift | ||||
|             BASEDIR=`echo $1 | sed -e 's/\/*$//g'` | ||||
|             shift | ||||
|             ;; | ||||
|         -p|--package-name) | ||||
|             shift | ||||
|             PACKAGENAME=`echo $1` | ||||
|             shift | ||||
|             ;; | ||||
|         -o|--output-dir) | ||||
|             shift | ||||
|             OUTPUTDIR=`echo $1 | sed -e 's/\/*$//g'` | ||||
|             shift | ||||
|             ;; | ||||
|         -m|--module) | ||||
|             shift | ||||
|             MODULES="$MODULES -m $1" | ||||
|             shift | ||||
|             ;; | ||||
|         -l|--library) | ||||
|             shift | ||||
|             LIBRARIES="$LIBRARIES -l $1" | ||||
|             shift | ||||
|             ;; | ||||
|         --) | ||||
|             break | ||||
|             ;; | ||||
|     esac | ||||
| done | ||||
|  | ||||
| BASEDIR=${BASEDIR:-`pwd`} | ||||
| if ! [ -d $BASEDIR ] | ||||
| then | ||||
|     echo "${0##*/}: missing project base directory" >&2 ; print_hint ; exit 1 | ||||
| elif [[ $BASEDIR != /* ]] | ||||
| then | ||||
|     BASEDIR=$(cd "$BASEDIR" && pwd) | ||||
| fi | ||||
|  | ||||
| PACKAGENAME=${PACKAGENAME:-$(python setup.py --name)} | ||||
| TARGETDIR=$BASEDIR/$PACKAGENAME | ||||
| if ! [ -d $TARGETDIR ] | ||||
| then | ||||
|     echo "${0##*/}: invalid project package name" >&2 ; print_hint ; exit 1 | ||||
| fi | ||||
|  | ||||
| OUTPUTDIR=${OUTPUTDIR:-$BASEDIR/etc} | ||||
| # NOTE(bnemec): Some projects put their sample config in etc/, | ||||
| #               some in etc/$PACKAGENAME/ | ||||
| if [ -d $OUTPUTDIR/$PACKAGENAME ] | ||||
| then | ||||
|     OUTPUTDIR=$OUTPUTDIR/$PACKAGENAME | ||||
| elif ! [ -d $OUTPUTDIR ] | ||||
| then | ||||
|     echo "${0##*/}: cannot access \`$OUTPUTDIR': No such file or directory" >&2 | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| BASEDIRESC=`echo $BASEDIR | sed -e 's/\//\\\\\//g'` | ||||
| find $TARGETDIR -type f -name "*.pyc" -delete | ||||
| FILES=$(find $TARGETDIR -type f -name "*.py" ! -path "*/tests/*" \ | ||||
|         -exec grep -l "Opt(" {} + | sed -e "s/^$BASEDIRESC\///g" | sort -u) | ||||
|  | ||||
| RC_FILE="`dirname $0`/oslo.config.generator.rc" | ||||
| if test -r "$RC_FILE" | ||||
| then | ||||
|     source "$RC_FILE" | ||||
| fi | ||||
|  | ||||
| for filename in ${GBP_CONFIG_GENERATOR_EXCLUDED_FILES}; do | ||||
|     FILES="${FILES[@]/$filename/}" | ||||
| done | ||||
|  | ||||
| for mod in ${GBP_CONFIG_GENERATOR_EXTRA_MODULES}; do | ||||
|     MODULES="$MODULES -m $mod" | ||||
| done | ||||
|  | ||||
| for lib in ${GBP_CONFIG_GENERATOR_EXTRA_LIBRARIES}; do | ||||
|     LIBRARIES="$LIBRARIES -l $lib" | ||||
| done | ||||
|  | ||||
| export EVENTLET_NO_GREENDNS=yes | ||||
|  | ||||
| OS_VARS=$(set | sed -n '/^OS_/s/=[^=]*$//gp' | xargs) | ||||
| [ "$OS_VARS" ] && eval "unset \$OS_VARS" | ||||
| DEFAULT_MODULEPATH=gbp.openstack.common.config.generator | ||||
| MODULEPATH=${MODULEPATH:-$DEFAULT_MODULEPATH} | ||||
| OUTPUTFILE=$OUTPUTDIR/$PACKAGENAME.conf.sample | ||||
| python -m $MODULEPATH $MODULES $LIBRARIES $FILES > $OUTPUTFILE | ||||
| if [ $? != 0 ] | ||||
| then | ||||
|     echo "Can not generate $OUTPUTFILE" | ||||
|     exit 1 | ||||
| fi | ||||
|  | ||||
| # Hook to allow projects to append custom config file snippets | ||||
| CONCAT_FILES=$(ls $BASEDIR/tools/config/*.conf.sample 2>/dev/null) | ||||
| for CONCAT_FILE in $CONCAT_FILES; do | ||||
|     cat $CONCAT_FILE >> $OUTPUTFILE | ||||
| done | ||||
							
								
								
									
										71
									
								
								tools/install_venv.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								tools/install_venv.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| # Copyright 2010 United States Government as represented by the | ||||
| # Administrator of the National Aeronautics and Space Administration. | ||||
| # All Rights Reserved. | ||||
| # | ||||
| # Copyright 2010 OpenStack Foundation | ||||
| # Copyright 2013 IBM Corp. | ||||
| # | ||||
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
| #    not use this file except in compliance with the License. You may obtain | ||||
| #    a copy of the License at | ||||
| # | ||||
| #         http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| #    Unless required by applicable law or agreed to in writing, software | ||||
| #    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| #    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||||
| #    License for the specific language governing permissions and limitations | ||||
| #    under the License. | ||||
|  | ||||
| import os | ||||
| import sys | ||||
|  | ||||
| import install_venv_common as install_venv  # noqa | ||||
|  | ||||
|  | ||||
| def print_help(venv, root): | ||||
|     help = """ | ||||
|     OpenStack development environment setup is complete. | ||||
|  | ||||
|     OpenStack development uses virtualenv to track and manage Python | ||||
|     dependencies while in development and testing. | ||||
|  | ||||
|     To activate the OpenStack virtualenv for the extent of your current shell | ||||
|     session you can run: | ||||
|  | ||||
|     $ source %s/bin/activate | ||||
|  | ||||
|     Or, if you prefer, you can run commands in the virtualenv on a case by case | ||||
|     basis by running: | ||||
|  | ||||
|     $ %s/tools/with_venv.sh <your command> | ||||
|  | ||||
|     Also, make test will automatically use the virtualenv. | ||||
|     """ | ||||
|     print(help % (venv, root)) | ||||
|  | ||||
|  | ||||
| def main(argv): | ||||
|     root = os.path.dirname(os.path.dirname(os.path.realpath(__file__))) | ||||
|  | ||||
|     if os.environ.get('tools_path'): | ||||
|         root = os.environ['tools_path'] | ||||
|     venv = os.path.join(root, '.venv') | ||||
|     if os.environ.get('venv'): | ||||
|         venv = os.environ['venv'] | ||||
|  | ||||
|     pip_requires = os.path.join(root, 'requirements.txt') | ||||
|     test_requires = os.path.join(root, 'test-requirements.txt') | ||||
|     py_version = "python%s.%s" % (sys.version_info[0], sys.version_info[1]) | ||||
|     project = 'OpenStack' | ||||
|     install = install_venv.InstallVenv(root, venv, pip_requires, test_requires, | ||||
|                                        py_version, project) | ||||
|     options = install.parse_args(argv) | ||||
|     install.check_python_version() | ||||
|     install.check_dependencies() | ||||
|     install.create_virtualenv(no_site_packages=options.no_site_packages) | ||||
|     install.install_dependencies() | ||||
|     print_help(venv, root) | ||||
|  | ||||
| if __name__ == '__main__': | ||||
|     main(sys.argv) | ||||
							
								
								
									
										172
									
								
								tools/install_venv_common.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										172
									
								
								tools/install_venv_common.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,172 @@ | ||||
| # Copyright 2013 OpenStack Foundation | ||||
| # Copyright 2013 IBM Corp. | ||||
| # | ||||
| #    Licensed under the Apache License, Version 2.0 (the "License"); you may | ||||
| #    not use this file except in compliance with the License. You may obtain | ||||
| #    a copy of the License at | ||||
| # | ||||
| #         http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| #    Unless required by applicable law or agreed to in writing, software | ||||
| #    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | ||||
| #    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the | ||||
| #    License for the specific language governing permissions and limitations | ||||
| #    under the License. | ||||
|  | ||||
| """Provides methods needed by installation script for OpenStack development | ||||
| virtual environments. | ||||
|  | ||||
| Since this script is used to bootstrap a virtualenv from the system's Python | ||||
| environment, it should be kept strictly compatible with Python 2.6. | ||||
|  | ||||
| Synced in from openstack-common | ||||
| """ | ||||
|  | ||||
| from __future__ import print_function | ||||
|  | ||||
| import optparse | ||||
| import os | ||||
| import subprocess | ||||
| import sys | ||||
|  | ||||
|  | ||||
| class InstallVenv(object): | ||||
|  | ||||
|     def __init__(self, root, venv, requirements, | ||||
|                  test_requirements, py_version, | ||||
|                  project): | ||||
|         self.root = root | ||||
|         self.venv = venv | ||||
|         self.requirements = requirements | ||||
|         self.test_requirements = test_requirements | ||||
|         self.py_version = py_version | ||||
|         self.project = project | ||||
|  | ||||
|     def die(self, message, *args): | ||||
|         print(message % args, file=sys.stderr) | ||||
|         sys.exit(1) | ||||
|  | ||||
|     def check_python_version(self): | ||||
|         if sys.version_info < (2, 6): | ||||
|             self.die("Need Python Version >= 2.6") | ||||
|  | ||||
|     def run_command_with_code(self, cmd, redirect_output=True, | ||||
|                               check_exit_code=True): | ||||
|         """Runs a command in an out-of-process shell. | ||||
|  | ||||
|         Returns the output of that command. Working directory is self.root. | ||||
|         """ | ||||
|         if redirect_output: | ||||
|             stdout = subprocess.PIPE | ||||
|         else: | ||||
|             stdout = None | ||||
|  | ||||
|         proc = subprocess.Popen(cmd, cwd=self.root, stdout=stdout) | ||||
|         output = proc.communicate()[0] | ||||
|         if check_exit_code and proc.returncode != 0: | ||||
|             self.die('Command "%s" failed.\n%s', ' '.join(cmd), output) | ||||
|         return (output, proc.returncode) | ||||
|  | ||||
|     def run_command(self, cmd, redirect_output=True, check_exit_code=True): | ||||
|         return self.run_command_with_code(cmd, redirect_output, | ||||
|                                           check_exit_code)[0] | ||||
|  | ||||
|     def get_distro(self): | ||||
|         if (os.path.exists('/etc/fedora-release') or | ||||
|                 os.path.exists('/etc/redhat-release')): | ||||
|             return Fedora( | ||||
|                 self.root, self.venv, self.requirements, | ||||
|                 self.test_requirements, self.py_version, self.project) | ||||
|         else: | ||||
|             return Distro( | ||||
|                 self.root, self.venv, self.requirements, | ||||
|                 self.test_requirements, self.py_version, self.project) | ||||
|  | ||||
|     def check_dependencies(self): | ||||
|         self.get_distro().install_virtualenv() | ||||
|  | ||||
|     def create_virtualenv(self, no_site_packages=True): | ||||
|         """Creates the virtual environment and installs PIP. | ||||
|  | ||||
|         Creates the virtual environment and installs PIP only into the | ||||
|         virtual environment. | ||||
|         """ | ||||
|         if not os.path.isdir(self.venv): | ||||
|             print('Creating venv...', end=' ') | ||||
|             if no_site_packages: | ||||
|                 self.run_command(['virtualenv', '-q', '--no-site-packages', | ||||
|                                  self.venv]) | ||||
|             else: | ||||
|                 self.run_command(['virtualenv', '-q', self.venv]) | ||||
|             print('done.') | ||||
|         else: | ||||
|             print("venv already exists...") | ||||
|             pass | ||||
|  | ||||
|     def pip_install(self, *args): | ||||
|         self.run_command(['tools/with_venv.sh', | ||||
|                          'pip', 'install', '--upgrade'] + list(args), | ||||
|                          redirect_output=False) | ||||
|  | ||||
|     def install_dependencies(self): | ||||
|         print('Installing dependencies with pip (this can take a while)...') | ||||
|  | ||||
|         # First things first, make sure our venv has the latest pip and | ||||
|         # setuptools and pbr | ||||
|         self.pip_install('pip>=1.4') | ||||
|         self.pip_install('setuptools') | ||||
|         self.pip_install('pbr') | ||||
|  | ||||
|         self.pip_install('-r', self.requirements, '-r', self.test_requirements) | ||||
|  | ||||
|     def parse_args(self, argv): | ||||
|         """Parses command-line arguments.""" | ||||
|         parser = optparse.OptionParser() | ||||
|         parser.add_option('-n', '--no-site-packages', | ||||
|                           action='store_true', | ||||
|                           help="Do not inherit packages from global Python " | ||||
|                                "install.") | ||||
|         return parser.parse_args(argv[1:])[0] | ||||
|  | ||||
|  | ||||
| class Distro(InstallVenv): | ||||
|  | ||||
|     def check_cmd(self, cmd): | ||||
|         return bool(self.run_command(['which', cmd], | ||||
|                     check_exit_code=False).strip()) | ||||
|  | ||||
|     def install_virtualenv(self): | ||||
|         if self.check_cmd('virtualenv'): | ||||
|             return | ||||
|  | ||||
|         if self.check_cmd('easy_install'): | ||||
|             print('Installing virtualenv via easy_install...', end=' ') | ||||
|             if self.run_command(['easy_install', 'virtualenv']): | ||||
|                 print('Succeeded') | ||||
|                 return | ||||
|             else: | ||||
|                 print('Failed') | ||||
|  | ||||
|         self.die('ERROR: virtualenv not found.\n\n%s development' | ||||
|                  ' requires virtualenv, please install it using your' | ||||
|                  ' favorite package management tool' % self.project) | ||||
|  | ||||
|  | ||||
| class Fedora(Distro): | ||||
|     """This covers all Fedora-based distributions. | ||||
|  | ||||
|     Includes: Fedora, RHEL, CentOS, Scientific Linux | ||||
|     """ | ||||
|  | ||||
|     def check_pkg(self, pkg): | ||||
|         return self.run_command_with_code(['rpm', '-q', pkg], | ||||
|                                           check_exit_code=False)[1] == 0 | ||||
|  | ||||
|     def install_virtualenv(self): | ||||
|         if self.check_cmd('virtualenv'): | ||||
|             return | ||||
|  | ||||
|         if not self.check_pkg('python-virtualenv'): | ||||
|             self.die("Please install 'python-virtualenv'.") | ||||
|  | ||||
|         super(Fedora, self).install_virtualenv() | ||||
							
								
								
									
										7
									
								
								tools/with_venv.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										7
									
								
								tools/with_venv.sh
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #!/bin/bash | ||||
| TOOLS_PATH=${TOOLS_PATH:-$(dirname $0)} | ||||
| VENV_PATH=${VENV_PATH:-${TOOLS_PATH}} | ||||
| VENV_DIR=${VENV_NAME:-/../.venv} | ||||
| TOOLS=${TOOLS_PATH} | ||||
| VENV=${VENV:-${VENV_PATH}/${VENV_DIR}} | ||||
| source ${VENV}/bin/activate && "$@" | ||||
							
								
								
									
										86
									
								
								tox.ini
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								tox.ini
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | ||||
| [tox] | ||||
| envlist = py26,py27,py33,pep8 | ||||
| minversion = 1.6 | ||||
| skipsdist = True | ||||
|  | ||||
| [testenv] | ||||
| # Note the hash seed is set to 0 until neutron can be tested with a | ||||
| # random hash seed successfully. | ||||
| setenv = VIRTUAL_ENV={envdir} | ||||
|          PYTHONHASHSEED=0 | ||||
| usedevelop = True | ||||
| install_command = pip install -U {opts} {packages} | ||||
| deps = -r{toxinidir}/requirements.txt | ||||
|        -r{toxinidir}/test-requirements.txt | ||||
| commands = | ||||
|   python -m neutron.openstack.common.lockutils python setup.py testr --slowest --testr-args='{posargs}' | ||||
|  | ||||
| [testenv:hashtest] | ||||
| # This is the same as default environment, but with a random PYTHONHASHSEED. | ||||
| # You can also specify a specific hashseed (for test repeatability) as follows: | ||||
| #   tox --hashseed 1235130571 -e hashtest | ||||
| setenv = VIRTUAL_ENV={envdir} | ||||
|  | ||||
| [testenv:functional] | ||||
| setenv = OS_TEST_PATH=./neutron/tests/functional | ||||
| commands = | ||||
|   python -m neutron.openstack.common.lockutils python setup.py testr --slowest --testr-args='{posargs}' | ||||
|  | ||||
| [testenv:dsvm-functional] | ||||
| setenv = OS_TEST_PATH=./neutron/tests/functional | ||||
|          OS_SUDO_TESTING=1 | ||||
|          OS_ROOTWRAP_CMD=sudo /usr/local/bin/neutron-rootwrap /etc/neutron/rootwrap.conf | ||||
|          OS_FAIL_ON_MISSING_DEPS=1 | ||||
| sitepackages=True | ||||
| commands = | ||||
|   python -m neutron.openstack.common.lockutils python setup.py testr --slowest --testr-args='{posargs}' | ||||
|  | ||||
| [tox:jenkins] | ||||
| sitepackages = True | ||||
| downloadcache = ~/cache/pip | ||||
|  | ||||
| [testenv:pep8] | ||||
| commands = | ||||
|   flake8 | ||||
|  | ||||
| [testenv:i18n] | ||||
| commands = python ./tools/check_i18n.py ./neutron ./tools/i18n_cfg.py | ||||
|  | ||||
| [testenv:cover] | ||||
| commands = | ||||
|   python -m neutron.openstack.common.lockutils python setup.py testr --coverage --testr-args='{posargs}' | ||||
|  | ||||
| [testenv:venv] | ||||
| commands = {posargs} | ||||
|  | ||||
| [testenv:docs] | ||||
| commands = python setup.py build_sphinx | ||||
|  | ||||
| [flake8] | ||||
| # E125 continuation line does not distinguish itself from next logical line | ||||
| # E126 continuation line over-indented for hanging indent | ||||
| # E128 continuation line under-indented for visual indent | ||||
| # E129 visually indented line with same indent as next logical line | ||||
| # E251 unexpected spaces around keyword / parameter equals | ||||
| # E265 block comment should start with ‘# ‘ | ||||
| # E713 test for membership should be ‘not in’ | ||||
| # F402 import module shadowed by loop variable | ||||
| # F811 redefinition of unused variable | ||||
| # F812 list comprehension redefines name from line | ||||
| # H104 file contains nothing but comments | ||||
| # H237 module is removed in Python 3 | ||||
| # H305 imports not grouped correctly | ||||
| # H307 like imports should be grouped together | ||||
| # H401 docstring should not start with a space | ||||
| # H402 one line docstring needs punctuation | ||||
| # H405 multi line docstring summary not separated with an empty line | ||||
| # H904 Wrap long lines in parentheses instead of a backslash | ||||
| # TODO(marun) H404 multi line docstring should start with a summary | ||||
| ignore = E125,E126,E128,E129,E251,E265,E713,F402,F811,F812,H104,H237,H305,H307,H401,H402,H404,H405,H904 | ||||
| show-source = true | ||||
| builtins = _ | ||||
| exclude = .venv,.git,.tox,dist,doc,*openstack/common*,*lib/python*,*egg,build,tools,.ropeproject,rally-scenarios | ||||
|  | ||||
| [hacking] | ||||
| import_exceptions = neutron.openstack.common.gettextutils | ||||
| local-check-factory = neutron.hacking.checks.factory | ||||
		Reference in New Issue
	
	Block a user
	 Ivar Lazzaro
					Ivar Lazzaro