summaryrefslogtreecommitdiff
path: root/openstackclient/tests/api/test_api.py
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2015-01-21 15:02:58 -0600
committerDean Troyer <dtroyer@gmail.com>2015-01-27 19:17:35 -0600
commit61a40343fdbb89a1c6404ab03fcfd84daee31c9e (patch)
tree8b34e7f8ba5d26a911023cc447308c21e7dcd612 /openstackclient/tests/api/test_api.py
parent2c03f6f42fc17ca145e527cc87a7c2e7043e32c7 (diff)
downloadpython-openstackclient-61a40343fdbb89a1c6404ab03fcfd84daee31c9e.tar.gz
Add filter to image list
* Hides previously broken --page-size option * Adds --property to image list for filtering on properties * Adds Visibility, Protected, Owner, Properties/Tags to --long output * Adds api.utils.simple_filter() for selecting matches out of a list of objects * Adds tests for all of the above * Updates image docs There are additional filtering options to be added in later reviews. Change-Id: I32feff0ad61aae749b33621c817658d7dc90c3aa Closes-bug: 1401902
Diffstat (limited to 'openstackclient/tests/api/test_api.py')
-rw-r--r--openstackclient/tests/api/test_api.py131
1 files changed, 47 insertions, 84 deletions
diff --git a/openstackclient/tests/api/test_api.py b/openstackclient/tests/api/test_api.py
index 32042e4f..81197967 100644
--- a/openstackclient/tests/api/test_api.py
+++ b/openstackclient/tests/api/test_api.py
@@ -13,49 +13,12 @@
"""Base API Library Tests"""
-from requests_mock.contrib import fixture
-
-from keystoneclient import session
from openstackclient.api import api
from openstackclient.common import exceptions
-from openstackclient.tests import utils
-
-
-RESP_ITEM_1 = {
- 'id': '1',
- 'name': 'alpha',
- 'status': 'UP',
-}
-RESP_ITEM_2 = {
- 'id': '2',
- 'name': 'beta',
- 'status': 'DOWN',
-}
-RESP_ITEM_3 = {
- 'id': '3',
- 'name': 'delta',
- 'status': 'UP',
-}
-
-LIST_RESP = [RESP_ITEM_1, RESP_ITEM_2]
-
-LIST_BODY = {
- 'p1': 'xxx',
- 'p2': 'yyy',
-}
-
-
-class TestSession(utils.TestCase):
-
- BASE_URL = 'https://api.example.com:1234/vX'
-
- def setUp(self):
- super(TestSession, self).setUp()
- self.sess = session.Session()
- self.requests_mock = self.useFixture(fixture.Fixture())
+from openstackclient.tests.api import fakes as api_fakes
-class TestKeystoneSession(TestSession):
+class TestKeystoneSession(api_fakes.TestSession):
def setUp(self):
super(TestKeystoneSession, self).setUp()
@@ -68,14 +31,14 @@ class TestKeystoneSession(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json=RESP_ITEM_1,
+ json=api_fakes.RESP_ITEM_1,
status_code=200,
)
ret = self.api._request('GET', '/qaz')
- self.assertEqual(RESP_ITEM_1, ret.json())
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret.json())
-class TestBaseAPI(TestSession):
+class TestBaseAPI(api_fakes.TestSession):
def setUp(self):
super(TestBaseAPI, self).setUp()
@@ -88,21 +51,21 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'POST',
self.BASE_URL + '/qaz',
- json=RESP_ITEM_1,
+ json=api_fakes.RESP_ITEM_1,
status_code=202,
)
ret = self.api.create('qaz')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
def test_create_put(self):
self.requests_mock.register_uri(
'PUT',
self.BASE_URL + '/qaz',
- json=RESP_ITEM_1,
+ json=api_fakes.RESP_ITEM_1,
status_code=202,
)
ret = self.api.create('qaz', method='PUT')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
def test_delete(self):
self.requests_mock.register_uri(
@@ -127,11 +90,11 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?id=1',
- json={'qaz': [RESP_ITEM_1]},
+ json={'qaz': [api_fakes.RESP_ITEM_1]},
status_code=200,
)
ret = self.api.find_attr('qaz', '1')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
# value not found
self.requests_mock.register_uri(
@@ -157,23 +120,23 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?status=UP',
- json={'qaz': [RESP_ITEM_1]},
+ json={'qaz': [api_fakes.RESP_ITEM_1]},
status_code=200,
)
ret = self.api.find_attr('qaz', 'UP', attr='status')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
ret = self.api.find_attr('qaz', value='UP', attr='status')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
def test_find_attr_by_name(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?name=alpha',
- json={'qaz': [RESP_ITEM_1]},
+ json={'qaz': [api_fakes.RESP_ITEM_1]},
status_code=200,
)
ret = self.api.find_attr('qaz', 'alpha')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
# value not found
self.requests_mock.register_uri(
@@ -199,13 +162,13 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?status=UP',
- json={'qaz': [RESP_ITEM_1]},
+ json={'qaz': [api_fakes.RESP_ITEM_1]},
status_code=200,
)
ret = self.api.find_attr('qaz', 'UP', attr='status')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
ret = self.api.find_attr('qaz', value='UP', attr='status')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
def test_find_attr_path_resource(self):
@@ -219,37 +182,37 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/wsx?id=1',
- json={'qaz': [RESP_ITEM_1]},
+ json={'qaz': [api_fakes.RESP_ITEM_1]},
status_code=200,
)
ret = self.api.find_attr('wsx', '1', resource='qaz')
- self.assertEqual(RESP_ITEM_1, ret)
+ self.assertEqual(api_fakes.RESP_ITEM_1, ret)
def test_find_bulk_none(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.find_bulk('qaz')
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_find_bulk_one(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.find_bulk('qaz', id='1')
- self.assertEqual([LIST_RESP[0]], ret)
+ self.assertEqual([api_fakes.LIST_RESP[0]], ret)
ret = self.api.find_bulk('qaz', id='0')
self.assertEqual([], ret)
ret = self.api.find_bulk('qaz', name='beta')
- self.assertEqual([LIST_RESP[1]], ret)
+ self.assertEqual([api_fakes.LIST_RESP[1]], ret)
ret = self.api.find_bulk('qaz', error='bogus')
self.assertEqual([], ret)
@@ -258,11 +221,11 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.find_bulk('qaz', id='1', name='alpha')
- self.assertEqual([LIST_RESP[0]], ret)
+ self.assertEqual([api_fakes.LIST_RESP[0]], ret)
ret = self.api.find_bulk('qaz', id='1', name='beta')
self.assertEqual([], ret)
@@ -274,11 +237,11 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json={'qaz': LIST_RESP},
+ json={'qaz': api_fakes.LIST_RESP},
status_code=200,
)
ret = self.api.find_bulk('qaz', id='1')
- self.assertEqual([LIST_RESP[0]], ret)
+ self.assertEqual([api_fakes.LIST_RESP[0]], ret)
# list tests
@@ -286,77 +249,77 @@ class TestBaseAPI(TestSession):
self.requests_mock.register_uri(
'GET',
self.BASE_URL,
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('')
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('qaz')
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_list_params(self):
params = {'format': 'json'}
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '?format=json',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('', **params)
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?format=json',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('qaz', **params)
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_list_body(self):
self.requests_mock.register_uri(
'POST',
self.BASE_URL + '/qaz',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
- ret = self.api.list('qaz', body=LIST_BODY)
- self.assertEqual(LIST_RESP, ret)
+ ret = self.api.list('qaz', body=api_fakes.LIST_BODY)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_list_detailed(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz/details',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('qaz', detailed=True)
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_list_filtered(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?attr=value',
- json=LIST_RESP,
+ json=api_fakes.LIST_RESP,
status_code=200,
)
ret = self.api.list('qaz', attr='value')
- self.assertEqual(LIST_RESP, ret)
+ self.assertEqual(api_fakes.LIST_RESP, ret)
def test_list_wrapped(self):
self.requests_mock.register_uri(
'GET',
self.BASE_URL + '/qaz?attr=value',
- json={'responses': LIST_RESP},
+ json={'responses': api_fakes.LIST_RESP},
status_code=200,
)
ret = self.api.list('qaz', attr='value')
- self.assertEqual({'responses': LIST_RESP}, ret)
+ self.assertEqual({'responses': api_fakes.LIST_RESP}, ret)