Last task necessary to stop users from easily obtaining OS objects.
[snaps.git] / snaps / openstack / tests / create_user_tests.py
1 # Copyright (c) 2017 Cable Television Laboratories, Inc. ("CableLabs")
2 #                    and others.  All rights reserved.
3 #
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain 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,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
15 import unittest
16 import uuid
17
18 from snaps.openstack.create_user import OpenStackUser, UserSettings
19 from snaps.openstack.tests.os_source_file_test import OSComponentTestCase
20 from snaps.openstack.utils import keystone_utils
21
22 __author__ = 'spisarski'
23
24
25 class UserSettingsUnitTests(unittest.TestCase):
26     """
27     Tests the construction of the UserSettings class
28     """
29
30     def test_no_params(self):
31         with self.assertRaises(Exception):
32             UserSettings()
33
34     def test_empty_config(self):
35         with self.assertRaises(Exception):
36             UserSettings(**dict())
37
38     def test_name_only(self):
39         with self.assertRaises(Exception):
40             UserSettings(name='foo')
41
42     def test_config_with_name_only(self):
43         with self.assertRaises(Exception):
44             UserSettings(**{'name': 'foo'})
45
46     def test_name_pass_enabled_str(self):
47         with self.assertRaises(Exception):
48             UserSettings(name='foo', password='bar', enabled='true')
49
50     def test_config_with_name_pass_enabled_str(self):
51         with self.assertRaises(Exception):
52             UserSettings(
53                 **{'name': 'foo', 'password': 'bar', 'enabled': 'true'})
54
55     def test_name_pass_only(self):
56         settings = UserSettings(name='foo', password='bar')
57         self.assertEqual('foo', settings.name)
58         self.assertEqual('bar', settings.password)
59         self.assertIsNone(settings.project_name)
60         self.assertIsNone(settings.email)
61         self.assertTrue(settings.enabled)
62
63     def test_config_with_name_pass_only(self):
64         settings = UserSettings(**{'name': 'foo', 'password': 'bar'})
65         self.assertEqual('foo', settings.name)
66         self.assertEqual('bar', settings.password)
67         self.assertIsNone(settings.project_name)
68         self.assertIsNone(settings.email)
69         self.assertTrue(settings.enabled)
70
71     def test_all(self):
72         settings = UserSettings(name='foo', password='bar',
73                                 project_name='proj-foo', email='foo@bar.com',
74                                 enabled=False)
75         self.assertEqual('foo', settings.name)
76         self.assertEqual('bar', settings.password)
77         self.assertEqual('proj-foo', settings.project_name)
78         self.assertEqual('foo@bar.com', settings.email)
79         self.assertFalse(settings.enabled)
80
81     def test_config_all(self):
82         settings = UserSettings(**{'name': 'foo', 'password': 'bar',
83                                    'project_name': 'proj-foo',
84                                    'email': 'foo@bar.com',
85                                    'enabled': False})
86         self.assertEqual('foo', settings.name)
87         self.assertEqual('bar', settings.password)
88         self.assertEqual('proj-foo', settings.project_name)
89         self.assertEqual('foo@bar.com', settings.email)
90         self.assertFalse(settings.enabled)
91
92
93 class CreateUserSuccessTests(OSComponentTestCase):
94     """
95     Test for the CreateImage class defined in create_image.py
96     """
97
98     def setUp(self):
99         """
100         Instantiates the CreateImage object that is responsible for downloading
101         and creating an OS image file within OpenStack
102         """
103         guid = str(uuid.uuid4())[:-19]
104         guid = self.__class__.__name__ + '-' + guid
105         self.user_settings = UserSettings(name=guid + '-name',
106                                           password=guid + '-password',
107                                           roles={'admin': 'admin'})
108
109         self.keystone = keystone_utils.keystone_client(self.os_creds)
110
111         # Initialize for cleanup
112         self.user_creator = None
113
114     def tearDown(self):
115         """
116         Cleans the image and downloaded image file
117         """
118         if self.user_creator:
119             self.user_creator.clean()
120
121     def test_create_user(self):
122         """
123         Tests the creation of an OpenStack user.
124         """
125         self.user_creator = OpenStackUser(self.os_creds, self.user_settings)
126         created_user = self.user_creator.create()
127         self.assertIsNotNone(created_user)
128
129         retrieved_user = keystone_utils.get_user(self.keystone,
130                                                  self.user_settings.name)
131         self.assertIsNotNone(retrieved_user)
132         self.assertEqual(created_user, retrieved_user)
133
134     def test_create_user_2x(self):
135         """
136         Tests the creation of an OpenStack user twice to ensure it only creates
137         one.
138         """
139         self.user_creator = OpenStackUser(self.os_creds, self.user_settings)
140         created_user = self.user_creator.create()
141         self.assertIsNotNone(created_user)
142
143         retrieved_user = keystone_utils.get_user(self.keystone,
144                                                  self.user_settings.name)
145         self.assertIsNotNone(retrieved_user)
146         self.assertEqual(created_user, retrieved_user)
147
148         # Create user for the second time to ensure it is the same
149         user2 = OpenStackUser(self.os_creds, self.user_settings).create()
150         self.assertEqual(retrieved_user, user2)
151
152     def test_create_delete_user(self):
153         """
154         Tests the creation of an OpenStack user then delete.
155         """
156         # Create Image
157         self.user_creator = OpenStackUser(self.os_creds, self.user_settings)
158         created_user = self.user_creator.create()
159         self.assertIsNotNone(created_user)
160
161         keystone_utils.delete_user(self.keystone, created_user)
162
163         # Delete user
164         self.user_creator.clean()
165         self.assertIsNone(self.user_creator.get_user())
166
167     def test_create_admin_user(self):
168         """
169         Tests the creation of an OpenStack user.
170         """
171         self.user_creator = OpenStackUser(self.os_creds, self.user_settings)
172         created_user = self.user_creator.create()
173         self.assertIsNotNone(created_user)
174
175         retrieved_user = keystone_utils.get_user(self.keystone,
176                                                  self.user_settings.name)
177         self.assertIsNotNone(retrieved_user)
178         self.assertEqual(created_user, retrieved_user)
179
180         role = keystone_utils.get_role_by_name(self.keystone, 'admin')
181         self.assertIsNotNone(role)
182
183         os_proj = keystone_utils.get_project(
184             keystone=self.keystone, project_name=self.os_creds.project_name)
185         user_roles = keystone_utils.get_roles_by_user(
186             self.keystone, retrieved_user, os_proj)
187         self.assertIsNotNone(user_roles)
188         self.assertEqual(1, len(user_roles))
189         self.assertEqual(role.id, user_roles[0].id)