~ubuntu-branches/ubuntu/trusty/python-keystoneclient/trusty-proposed

« back to all changes in this revision

Viewing changes to tests/v3/test_client.py

  • Committer: Package Import Robot
  • Author(s): Chuck Short, Adam Gandelman, Chuck Short
  • Date: 2013-11-14 10:51:32 UTC
  • mfrom: (1.1.23)
  • Revision ID: package-import@ubuntu.com-20131114105132-p1o428l7fclasv9e
Tags: 1:0.4.1-0ubuntu1
[ Adam Gandelman ]
* debian/patches: Refreshed.
* debian/patches/use-mox-dependency.patch: Use mox instead of mox3
  dependency.

[ Chuck Short ]
* New upstream release.
* debian/control:
  - open icehouse release.
  - Dropped python-d2to1 and python-httplib2 dependency.
* debian/patches/skip-tests-ubuntu.patch: Dropped no longer needed.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
import json
2
 
import mock
3
 
 
4
 
import requests
5
 
 
6
 
from keystoneclient.v3 import client
7
 
 
8
 
from tests import utils
9
 
from tests.v3 import client_fixtures
10
 
 
11
 
 
12
 
class KeystoneClientTest(utils.TestCase):
13
 
    def setUp(self):
14
 
        super(KeystoneClientTest, self).setUp()
15
 
 
16
 
        domain_scoped_fake_resp = utils.TestResponse({
17
 
            "status_code": 200,
18
 
            "text": json.dumps(client_fixtures.DOMAIN_SCOPED_TOKEN),
19
 
            "headers": client_fixtures.AUTH_RESPONSE_HEADERS
20
 
        })
21
 
        self.domain_scoped_mock_req = mock.Mock(
22
 
            return_value=domain_scoped_fake_resp)
23
 
 
24
 
        project_scoped_fake_resp = utils.TestResponse({
25
 
            "status_code": 200,
26
 
            "text": json.dumps(client_fixtures.PROJECT_SCOPED_TOKEN),
27
 
            "headers": client_fixtures.AUTH_RESPONSE_HEADERS
28
 
        })
29
 
        self.project_scoped_mock_req = mock.Mock(
30
 
            return_value=project_scoped_fake_resp)
31
 
 
32
 
        unscoped_fake_resp = utils.TestResponse({
33
 
            "status_code": 200,
34
 
            "text": json.dumps(client_fixtures.UNSCOPED_TOKEN),
35
 
            "headers": client_fixtures.AUTH_RESPONSE_HEADERS
36
 
        })
37
 
        self.unscoped_mock_req = mock.Mock(return_value=unscoped_fake_resp)
38
 
 
39
 
        trust_fake_resp = utils.TestResponse({
40
 
            "status_code": 200,
41
 
            "text": json.dumps(client_fixtures.TRUST_TOKEN),
42
 
            "headers": client_fixtures.AUTH_RESPONSE_HEADERS
43
 
        })
44
 
        self.trust_mock_req = mock.Mock(return_value=trust_fake_resp)
45
 
 
46
 
    def test_unscoped_init(self):
47
 
        with mock.patch.object(requests, "request", self.unscoped_mock_req):
48
 
            c = client.Client(user_domain_name='exampledomain',
49
 
                              username='exampleuser',
50
 
                              password='password',
51
 
                              auth_url='http://somewhere/')
52
 
            self.assertIsNotNone(c.auth_ref)
53
 
            self.assertFalse(c.auth_ref.domain_scoped)
54
 
            self.assertFalse(c.auth_ref.project_scoped)
55
 
            self.assertEquals(c.auth_user_id,
56
 
                              'c4da488862bd435c9e6c0275a0d0e49a')
57
 
 
58
 
    def test_domain_scoped_init(self):
59
 
        with mock.patch.object(requests,
60
 
                               "request",
61
 
                               self.domain_scoped_mock_req):
62
 
            c = client.Client(user_id='c4da488862bd435c9e6c0275a0d0e49a',
63
 
                              password='password',
64
 
                              domain_name='exampledomain',
65
 
                              auth_url='http://somewhere/')
66
 
            self.assertIsNotNone(c.auth_ref)
67
 
            self.assertTrue(c.auth_ref.domain_scoped)
68
 
            self.assertFalse(c.auth_ref.project_scoped)
69
 
            self.assertEquals(c.auth_user_id,
70
 
                              'c4da488862bd435c9e6c0275a0d0e49a')
71
 
            self.assertEquals(c.auth_domain_id,
72
 
                              '8e9283b7ba0b1038840c3842058b86ab')
73
 
 
74
 
    def test_project_scoped_init(self):
75
 
        with mock.patch.object(requests,
76
 
                               "request",
77
 
                               self.project_scoped_mock_req):
78
 
            c = client.Client(user_id='c4da488862bd435c9e6c0275a0d0e49a',
79
 
                              password='password',
80
 
                              user_domain_name='exampledomain',
81
 
                              project_name='exampleproject',
82
 
                              auth_url='http://somewhere/')
83
 
            self.assertIsNotNone(c.auth_ref)
84
 
            self.assertFalse(c.auth_ref.domain_scoped)
85
 
            self.assertTrue(c.auth_ref.project_scoped)
86
 
            self.assertEquals(c.auth_user_id,
87
 
                              'c4da488862bd435c9e6c0275a0d0e49a')
88
 
            self.assertEquals(c.auth_tenant_id,
89
 
                              '225da22d3ce34b15877ea70b2a575f58')
90
 
 
91
 
    def test_auth_ref_load(self):
92
 
        with mock.patch.object(requests,
93
 
                               "request",
94
 
                               self.project_scoped_mock_req):
95
 
            c = client.Client(user_id='c4da488862bd435c9e6c0275a0d0e49a',
96
 
                              password='password',
97
 
                              project_id='225da22d3ce34b15877ea70b2a575f58',
98
 
                              auth_url='http://somewhere/')
99
 
            cache = json.dumps(c.auth_ref)
100
 
            new_client = client.Client(auth_ref=json.loads(cache))
101
 
            self.assertIsNotNone(new_client.auth_ref)
102
 
            self.assertFalse(new_client.auth_ref.domain_scoped)
103
 
            self.assertTrue(new_client.auth_ref.project_scoped)
104
 
            self.assertEquals(new_client.username, 'exampleuser')
105
 
            self.assertIsNone(new_client.password)
106
 
            self.assertEqual(new_client.management_url,
107
 
                             'http://admin:35357/v3')
108
 
 
109
 
    def test_auth_ref_load_with_overridden_arguments(self):
110
 
        with mock.patch.object(requests,
111
 
                               "request",
112
 
                               self.project_scoped_mock_req):
113
 
            c = client.Client(user_id='c4da488862bd435c9e6c0275a0d0e49a',
114
 
                              password='password',
115
 
                              project_id='225da22d3ce34b15877ea70b2a575f58',
116
 
                              auth_url='http://somewhere/')
117
 
            cache = json.dumps(c.auth_ref)
118
 
            new_auth_url = "http://new-public:5000/v3"
119
 
            new_client = client.Client(auth_ref=json.loads(cache),
120
 
                                       auth_url=new_auth_url)
121
 
            self.assertIsNotNone(new_client.auth_ref)
122
 
            self.assertFalse(new_client.auth_ref.domain_scoped)
123
 
            self.assertTrue(new_client.auth_ref.project_scoped)
124
 
            self.assertEquals(new_client.auth_url, new_auth_url)
125
 
            self.assertEquals(new_client.username, 'exampleuser')
126
 
            self.assertIsNone(new_client.password)
127
 
            self.assertEqual(new_client.management_url,
128
 
                             'http://admin:35357/v3')
129
 
 
130
 
    def test_trust_init(self):
131
 
        with mock.patch.object(requests, "request", self.trust_mock_req):
132
 
            c = client.Client(user_domain_name='exampledomain',
133
 
                              username='exampleuser',
134
 
                              password='password',
135
 
                              auth_url='http://somewhere/',
136
 
                              trust_id='fe0aef')
137
 
            self.assertIsNotNone(c.auth_ref)
138
 
            self.assertFalse(c.auth_ref.domain_scoped)
139
 
            self.assertFalse(c.auth_ref.project_scoped)
140
 
            self.assertEqual(c.auth_ref.trust_id, 'fe0aef')
141
 
            self.assertTrue(c.auth_ref.trust_scoped)
142
 
            self.assertEquals(c.auth_user_id, '0ca8f6')