summaryrefslogtreecommitdiff
path: root/openstackclient/tests/integ/base.py
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2016-08-31 13:55:59 -0500
committerDean Troyer <dtroyer@gmail.com>2016-08-31 14:59:36 -0500
commitca15cd434bcdcab330b8823b60e12d8886b655b3 (patch)
tree0361d5b951a64f94eaf5be84c0513caaf6cf7e86 /openstackclient/tests/integ/base.py
parent8241f08ee1a67bbdaabd1026b81cc494a53530f2 (diff)
downloadpython-openstackclient-ca15cd434bcdcab330b8823b60e12d8886b655b3.tar.gz
Rearrange integration tests
Move the integration tests into their final home... * Create tests/integ to hold the integration tests * Split tests/test_shell_integ.py into tests/integ/base.py and tests/integ/cli/test_shell.py * Rename TestXXXXInteg classes to TestIntegXXXX * Adds tests/integ/cli/test_project.py for some simple project argument tests Change-Id: I2cdd340d1d446d61784eae35dd5aa09d40d5899d
Diffstat (limited to 'openstackclient/tests/integ/base.py')
-rw-r--r--openstackclient/tests/integ/base.py121
1 files changed, 121 insertions, 0 deletions
diff --git a/openstackclient/tests/integ/base.py b/openstackclient/tests/integ/base.py
new file mode 100644
index 00000000..9ee84893
--- /dev/null
+++ b/openstackclient/tests/integ/base.py
@@ -0,0 +1,121 @@
+# 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.
+
+from keystoneauth1 import fixture as ksa_fixture
+from requests_mock.contrib import fixture
+
+from openstackclient.tests import test_shell
+from openstackclient.tests import utils
+
+
+HOST = "192.168.5.41"
+URL_BASE = "http://%s/identity" % HOST
+
+V2_AUTH_URL = URL_BASE + "/v2.0/"
+V2_VERSION_RESP = {
+ "version": {
+ "status": "stable",
+ "updated": "2014-04-17T00:00:00Z",
+ "media-types": [
+ {
+ "base": "application/json",
+ "type": "application/vnd.openstack.identity-v2.0+json",
+ },
+ ],
+ "id": "v2.0",
+ "links": [
+ {
+ "href": V2_AUTH_URL,
+ "rel": "self",
+ },
+ {
+ "href": "http://docs.openstack.org/",
+ "type": "text/html",
+ "rel": "describedby",
+ },
+ ],
+ },
+}
+
+V3_AUTH_URL = URL_BASE + "/v3/"
+V3_VERSION_RESP = {
+ "version": {
+ "status": "stable",
+ "updated": "2016-04-04T00:00:00Z",
+ "media-types": [{
+ "base": "application/json",
+ "type": "application/vnd.openstack.identity-v3+json",
+ }],
+ "id": "v3.6",
+ "links": [{
+ "href": V3_AUTH_URL,
+ "rel": "self",
+ }]
+ }
+}
+
+
+def make_v2_token(req_mock):
+ """Create an Identity v2 token and register the responses"""
+
+ token = ksa_fixture.V2Token(
+ tenant_name=test_shell.DEFAULT_PROJECT_NAME,
+ user_name=test_shell.DEFAULT_USERNAME,
+ )
+
+ # Set up the v2 auth routes
+ req_mock.register_uri(
+ 'GET',
+ V2_AUTH_URL,
+ json=V2_VERSION_RESP,
+ status_code=200,
+ )
+ req_mock.register_uri(
+ 'POST',
+ V2_AUTH_URL + 'tokens',
+ json=token,
+ status_code=200,
+ )
+ return token
+
+
+def make_v3_token(req_mock):
+ """Create an Identity v3 token and register the response"""
+
+ token = ksa_fixture.V3Token(
+ # project_domain_id=test_shell.DEFAULT_PROJECT_DOMAIN_ID,
+ user_domain_id=test_shell.DEFAULT_USER_DOMAIN_ID,
+ user_name=test_shell.DEFAULT_USERNAME,
+ )
+
+ # Set up the v3 auth routes
+ req_mock.register_uri(
+ 'GET',
+ V3_AUTH_URL,
+ json=V3_VERSION_RESP,
+ status_code=200,
+ )
+ req_mock.register_uri(
+ 'POST',
+ V3_AUTH_URL + 'auth/tokens',
+ json=token,
+ status_code=200,
+ )
+ return token
+
+
+class TestInteg(utils.TestCase):
+
+ def setUp(self):
+ super(TestInteg, self).setUp()
+
+ self.requests_mock = self.useFixture(fixture.Fixture())