blob: 5f22d4379a612e71b9fffaed893ba0b66248dc30 [file] [log] [blame]
nayna-patel914b4712013-07-16 08:29:05 +00001# Copyright 2013 OpenStack Foundation
2# All Rights Reserved.
3#
4# Licensed under the Apache License, Version 2.0 (the "License"); you may
5# not use this file except in compliance with the License. You may obtain
6# a copy of the License at
7#
8# http://www.apache.org/licenses/LICENSE-2.0
9#
10# Unless required by applicable law or agreed to in writing, software
11# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13# License for the specific language governing permissions and limitations
14# under the License.
15
16from tempest.api.identity import base
Masayuki Igawa259c1132013-10-31 17:48:44 +090017from tempest.common.utils import data_utils
nayna-patel914b4712013-07-16 08:29:05 +000018from tempest.test import attr
19
20
Matthew Treinishdb2c5972014-01-31 22:18:59 +000021class CredentialsTestJSON(base.BaseIdentityV3AdminTest):
nayna-patel914b4712013-07-16 08:29:05 +000022 _interface = 'json'
23
24 @classmethod
25 def setUpClass(cls):
26 super(CredentialsTestJSON, cls).setUpClass()
27 cls.projects = list()
28 cls.creds_list = [['project_id', 'user_id', 'id'],
29 ['access', 'secret']]
Masayuki Igawa259c1132013-10-31 17:48:44 +090030 u_name = data_utils.rand_name('user-')
nayna-patel914b4712013-07-16 08:29:05 +000031 u_desc = '%s description' % u_name
32 u_email = '%s@testmail.tm' % u_name
Masayuki Igawa259c1132013-10-31 17:48:44 +090033 u_password = data_utils.rand_name('pass-')
nayna-patel914b4712013-07-16 08:29:05 +000034 for i in range(2):
Matthew Treinishdb2c5972014-01-31 22:18:59 +000035 resp, cls.project = cls.client.create_project(
Masayuki Igawa259c1132013-10-31 17:48:44 +090036 data_utils.rand_name('project-'),
37 description=data_utils.rand_name('project-desc-'))
nayna-patel914b4712013-07-16 08:29:05 +000038 assert resp['status'] == '201', "Expected %s" % resp['status']
39 cls.projects.append(cls.project['id'])
40
Matthew Treinishdb2c5972014-01-31 22:18:59 +000041 resp, cls.user_body = cls.client.create_user(
nayna-patel914b4712013-07-16 08:29:05 +000042 u_name, description=u_desc, password=u_password,
43 email=u_email, project_id=cls.projects[0])
44 assert resp['status'] == '201', "Expected: %s" % resp['status']
45
46 @classmethod
47 def tearDownClass(cls):
Matthew Treinishdb2c5972014-01-31 22:18:59 +000048 resp, _ = cls.client.delete_user(cls.user_body['id'])
nayna-patel914b4712013-07-16 08:29:05 +000049 assert resp['status'] == '204', "Expected: %s" % resp['status']
50 for p in cls.projects:
Matthew Treinishdb2c5972014-01-31 22:18:59 +000051 resp, _ = cls.client.delete_project(p)
nayna-patel914b4712013-07-16 08:29:05 +000052 assert resp['status'] == '204', "Expected: %s" % resp['status']
53 super(CredentialsTestJSON, cls).tearDownClass()
54
55 def _delete_credential(self, cred_id):
56 resp, body = self.creds_client.delete_credential(cred_id)
57 self.assertEqual(resp['status'], '204')
58
59 @attr(type='smoke')
60 def test_credentials_create_get_update_delete(self):
Masayuki Igawa259c1132013-10-31 17:48:44 +090061 keys = [data_utils.rand_name('Access-'),
62 data_utils.rand_name('Secret-')]
nayna-patel914b4712013-07-16 08:29:05 +000063 resp, cred = self.creds_client.create_credential(
64 keys[0], keys[1], self.user_body['id'],
65 self.projects[0])
66 self.addCleanup(self._delete_credential, cred['id'])
67 self.assertEqual(resp['status'], '201')
68 for value1 in self.creds_list[0]:
69 self.assertIn(value1, cred)
70 for value2 in self.creds_list[1]:
71 self.assertIn(value2, cred['blob'])
72
Masayuki Igawa259c1132013-10-31 17:48:44 +090073 new_keys = [data_utils.rand_name('NewAccess-'),
74 data_utils.rand_name('NewSecret-')]
nayna-patel914b4712013-07-16 08:29:05 +000075 resp, update_body = self.creds_client.update_credential(
76 cred['id'], access_key=new_keys[0], secret_key=new_keys[1],
77 project_id=self.projects[1])
78 self.assertEqual(resp['status'], '200')
79 self.assertEqual(cred['id'], update_body['id'])
80 self.assertEqual(self.projects[1], update_body['project_id'])
81 self.assertEqual(self.user_body['id'], update_body['user_id'])
82 self.assertEqual(update_body['blob']['access'], new_keys[0])
83 self.assertEqual(update_body['blob']['secret'], new_keys[1])
84
85 resp, get_body = self.creds_client.get_credential(cred['id'])
86 self.assertEqual(resp['status'], '200')
87 for value1 in self.creds_list[0]:
88 self.assertEqual(update_body[value1],
89 get_body[value1])
90 for value2 in self.creds_list[1]:
91 self.assertEqual(update_body['blob'][value2],
92 get_body['blob'][value2])
93
94 @attr(type='smoke')
95 def test_credentials_list_delete(self):
96 created_cred_ids = list()
97 fetched_cred_ids = list()
98
99 for i in range(2):
100 resp, cred = self.creds_client.create_credential(
Masayuki Igawa259c1132013-10-31 17:48:44 +0900101 data_utils.rand_name('Access-'),
102 data_utils.rand_name('Secret-'),
nayna-patel914b4712013-07-16 08:29:05 +0000103 self.user_body['id'], self.projects[0])
104 self.assertEqual(resp['status'], '201')
105 created_cred_ids.append(cred['id'])
106 self.addCleanup(self._delete_credential, cred['id'])
107
108 resp, creds = self.creds_client.list_credentials()
109 self.assertEqual(resp['status'], '200')
110
111 for i in creds:
112 fetched_cred_ids.append(i['id'])
113 missing_creds = [c for c in created_cred_ids
114 if c not in fetched_cred_ids]
115 self.assertEqual(0, len(missing_creds),
116 "Failed to find cred %s in fetched list" %
DennyZhangb432bac2013-09-17 16:24:12 +0000117 ', '.join(m_cred for m_cred in missing_creds))
nayna-patel914b4712013-07-16 08:29:05 +0000118
119
120class CredentialsTestXML(CredentialsTestJSON):
121 _interface = 'xml'