summaryrefslogtreecommitdiff
path: root/openstackclient/tests/common/test_restapi.py
diff options
context:
space:
mode:
authorDean Troyer <dtroyer@gmail.com>2013-11-25 13:39:30 -0600
committerDean Troyer <dtroyer@gmail.com>2013-12-03 14:26:46 -0600
commitf2dbe2e43716925f592db831d95fc5783abcecc9 (patch)
treec3e15bfeb6819e6f954867d405927840f1aa7d18 /openstackclient/tests/common/test_restapi.py
parent935781fdf961d0501b7400acbe4c86bdd9f284f2 (diff)
downloadpython-openstackclient-f2dbe2e43716925f592db831d95fc5783abcecc9.tar.gz
Bring RESTApi closer to ithe imminent keystoneclient.Session
Prepare to use the (soon to be) common Session from keystoneclient * Rework RESTApi to eventually be a subclass of keystoneclient.Session Change-Id: I68e610f8b19a3f6267a93f7bf3de54a228be68aa
Diffstat (limited to 'openstackclient/tests/common/test_restapi.py')
-rw-r--r--openstackclient/tests/common/test_restapi.py124
1 files changed, 73 insertions, 51 deletions
diff --git a/openstackclient/tests/common/test_restapi.py b/openstackclient/tests/common/test_restapi.py
index 4b83ffa4..c1e02fcb 100644
--- a/openstackclient/tests/common/test_restapi.py
+++ b/openstackclient/tests/common/test_restapi.py
@@ -23,6 +23,8 @@ import requests
from openstackclient.common import restapi
from openstackclient.tests import utils
+fake_user_agent = 'test_rapi'
+
fake_auth = '11223344556677889900'
fake_url = 'http://gopher.com'
fake_key = 'gopher'
@@ -47,6 +49,9 @@ fake_gopher_list = {
fake_gopher_tosh,
]
}
+fake_headers = {
+ 'User-Agent': fake_user_agent,
+}
class FakeResponse(requests.Response):
@@ -68,11 +73,15 @@ class TestRESTApi(utils.TestCase):
request=mock.MagicMock(return_value=resp),
)
- api = restapi.RESTApi()
+ api = restapi.RESTApi(
+ user_agent=fake_user_agent,
+ )
gopher = api.request('GET', fake_url)
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers={},
+ allow_redirects=True,
)
self.assertEqual(gopher.status_code, 200)
self.assertEqual(gopher.json(), fake_gopher_single)
@@ -83,11 +92,15 @@ class TestRESTApi(utils.TestCase):
request=mock.MagicMock(return_value=resp),
)
- api = restapi.RESTApi()
+ api = restapi.RESTApi(
+ user_agent=fake_user_agent,
+ )
gopher = api.request('GET', fake_url)
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers={},
+ allow_redirects=True,
)
self.assertEqual(gopher.status_code, 300)
self.assertEqual(gopher.json(), fake_gopher_single)
@@ -98,11 +111,15 @@ class TestRESTApi(utils.TestCase):
request=mock.MagicMock(return_value=resp),
)
- api = restapi.RESTApi()
+ api = restapi.RESTApi(
+ user_agent=fake_user_agent,
+ )
self.assertRaises(requests.HTTPError, api.request, 'GET', fake_url)
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers={},
+ allow_redirects=True,
)
def test_request_get_auth(self, session_mock):
@@ -112,66 +129,67 @@ class TestRESTApi(utils.TestCase):
headers=mock.MagicMock(return_value={}),
)
- api = restapi.RESTApi(os_auth=fake_auth)
- gopher = api.request('GET', fake_url)
- session_mock.return_value.headers.setdefault.assert_called_with(
- 'X-Auth-Token',
- fake_auth,
+ api = restapi.RESTApi(
+ auth_header=fake_auth,
+ user_agent=fake_user_agent,
)
+ gopher = api.request('GET', fake_url)
+ #session_mock.return_value.headers.setdefault.assert_called_with(
+ # 'X-Auth-Token',
+ # fake_auth,
+ #)
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers={
+ 'X-Auth-Token': fake_auth,
+ },
+ allow_redirects=True,
)
self.assertEqual(gopher.json(), fake_gopher_single)
- def test_request_get_header(self, session_mock):
+ def test_request_post(self, session_mock):
resp = FakeResponse(data=fake_gopher_single)
session_mock.return_value = mock.MagicMock(
request=mock.MagicMock(return_value=resp),
- headers=mock.MagicMock(return_value={}),
)
- api = restapi.RESTApi(user_agent='fake_agent')
- api.set_header('X-Fake-Header', 'wb')
- gopher = api.request('GET', fake_url)
- session_mock.return_value.headers.__setitem__.assert_any_call(
- 'Content-Type',
- 'application/json',
- )
- session_mock.return_value.headers.__setitem__.assert_any_call(
- 'User-Agent',
- 'fake_agent',
- )
- session_mock.return_value.headers.__setitem__.assert_any_call(
- 'X-Fake-Header',
- 'wb',
+ api = restapi.RESTApi(
+ user_agent=fake_user_agent,
)
+ data = fake_gopher_tosh
+ gopher = api.request('POST', fake_url, json=data)
session_mock.return_value.request.assert_called_with(
- 'GET',
+ 'POST',
fake_url,
+ headers={
+ 'Content-Type': 'application/json',
+ },
+ allow_redirects=True,
+ data=json.dumps(data),
)
self.assertEqual(gopher.json(), fake_gopher_single)
- api.set_header('X-Fake-Header', None)
- session_mock.return_value.headers.__delitem__.assert_any_call(
- 'X-Fake-Header',
- )
+ # Methods
+ # TODO(dtroyer): add the other method methods
- def test_request_post(self, session_mock):
- resp = FakeResponse(data=fake_gopher_single)
+ def test_delete(self, session_mock):
+ resp = FakeResponse(status_code=200, data=None)
session_mock.return_value = mock.MagicMock(
request=mock.MagicMock(return_value=resp),
)
api = restapi.RESTApi()
- data = fake_gopher_tosh
- gopher = api.request('POST', fake_url, data=data)
+ gopher = api.delete(fake_url)
session_mock.return_value.request.assert_called_with(
- 'POST',
+ 'DELETE',
fake_url,
- data=json.dumps(data),
+ headers=mock.ANY,
+ allow_redirects=True,
)
- self.assertEqual(gopher.json(), fake_gopher_single)
+ self.assertEqual(gopher.status_code, 200)
+
+ # Commands
def test_create(self, session_mock):
resp = FakeResponse(data=fake_gopher_single)
@@ -187,6 +205,8 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'POST',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
data=json.dumps(data),
)
self.assertEqual(gopher, fake_gopher_single)
@@ -196,24 +216,12 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'POST',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
data=json.dumps(data),
)
self.assertEqual(gopher, fake_gopher_mac)
- def test_delete(self, session_mock):
- resp = FakeResponse(data=None)
- session_mock.return_value = mock.MagicMock(
- request=mock.MagicMock(return_value=resp),
- )
-
- api = restapi.RESTApi()
- gopher = api.delete(fake_url)
- session_mock.return_value.request.assert_called_with(
- 'DELETE',
- fake_url,
- )
- self.assertEqual(gopher, None)
-
def test_list(self, session_mock):
resp = FakeResponse(data=fake_gopher_list)
session_mock.return_value = mock.MagicMock(
@@ -226,6 +234,7 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers=mock.ANY,
allow_redirects=True,
)
self.assertEqual(gopher, [fake_gopher_mac, fake_gopher_tosh])
@@ -237,6 +246,8 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'POST',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
data=json.dumps(data),
)
self.assertEqual(gopher, [fake_gopher_mac, fake_gopher_tosh])
@@ -248,6 +259,7 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers=mock.ANY,
allow_redirects=True,
params=params,
)
@@ -270,7 +282,9 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'PUT',
fake_url,
- data=None,
+ headers=mock.ANY,
+ allow_redirects=True,
+ json=None,
)
self.assertEqual(gopher, None)
@@ -279,6 +293,8 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'PUT',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
data=json.dumps(data),
)
self.assertEqual(gopher, fake_gopher_single)
@@ -291,6 +307,8 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'PUT',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
data=json.dumps(data),
)
self.assertEqual(gopher, fake_gopher_mac)
@@ -308,6 +326,8 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
)
self.assertEqual(gopher, fake_gopher_single)
@@ -316,5 +336,7 @@ class TestRESTApi(utils.TestCase):
session_mock.return_value.request.assert_called_with(
'GET',
fake_url,
+ headers=mock.ANY,
+ allow_redirects=True,
)
self.assertEqual(gopher, fake_gopher_mac)