Jay Pipes | 13b479b | 2012-06-11 14:52:27 -0400 | [diff] [blame] | 1 | # vim: tabstop=4 shiftwidth=4 softtabstop=4 |
| 2 | |
| 3 | # Copyright 2012 OpenStack, LLC |
| 4 | # All Rights Reserved. |
| 5 | # |
| 6 | # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| 7 | # not use this file except in compliance with the License. You may obtain |
| 8 | # a copy of the License at |
| 9 | # |
| 10 | # http://www.apache.org/licenses/LICENSE-2.0 |
| 11 | # |
| 12 | # Unless required by applicable law or agreed to in writing, software |
| 13 | # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| 14 | # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| 15 | # License for the specific language governing permissions and limitations |
| 16 | # under the License. |
| 17 | |
Sean Dague | 1937d09 | 2013-05-17 16:36:38 -0400 | [diff] [blame] | 18 | from tempest.api.compute import base |
Jay Pipes | 13b479b | 2012-06-11 14:52:27 -0400 | [diff] [blame] | 19 | from tempest.common.utils.data_utils import rand_name |
Matthew Treinish | a83a16e | 2012-12-07 13:44:02 -0500 | [diff] [blame] | 20 | from tempest import exceptions |
Chris Yeoh | 9465b0b | 2013-02-09 22:19:15 +1030 | [diff] [blame] | 21 | from tempest.test import attr |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 22 | |
| 23 | |
Attila Fazekas | 19044d5 | 2013-02-16 07:35:06 +0100 | [diff] [blame] | 24 | class KeyPairsTestJSON(base.BaseComputeTest): |
| 25 | _interface = 'json' |
| 26 | |
| 27 | @classmethod |
| 28 | def setUpClass(cls): |
| 29 | super(KeyPairsTestJSON, cls).setUpClass() |
| 30 | cls.client = cls.keypairs_client |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 31 | |
Giulio Fidente | ba3985a | 2013-05-29 01:46:36 +0200 | [diff] [blame] | 32 | @attr(type='gate') |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 33 | def test_keypairs_create_list_delete(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 34 | # Keypairs created should be available in the response list |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 35 | # Create 3 keypairs |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 36 | key_list = list() |
| 37 | for i in range(3): |
| 38 | k_name = rand_name('keypair-') |
| 39 | resp, keypair = self.client.create_keypair(k_name) |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 40 | # Need to pop these keys so that our compare doesn't fail later, |
| 41 | # as the keypair dicts from list API doesn't have them. |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 42 | keypair.pop('private_key') |
| 43 | keypair.pop('user_id') |
| 44 | self.assertEqual(200, resp.status) |
| 45 | key_list.append(keypair) |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 46 | # Fetch all keypairs and verify the list |
| 47 | # has all created keypairs |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 48 | resp, fetched_list = self.client.list_keypairs() |
| 49 | self.assertEqual(200, resp.status) |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 50 | # We need to remove the extra 'keypair' element in the |
| 51 | # returned dict. See comment in keypairs_client.list_keypairs() |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 52 | new_list = list() |
| 53 | for keypair in fetched_list: |
| 54 | new_list.append(keypair['keypair']) |
| 55 | fetched_list = new_list |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 56 | # Now check if all the created keypairs are in the fetched list |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 57 | missing_kps = [kp for kp in key_list if kp not in fetched_list] |
| 58 | self.assertFalse(missing_kps, |
| 59 | "Failed to find keypairs %s in fetched list" |
| 60 | % ', '.join(m_key['name'] for m_key in missing_kps)) |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 61 | # Delete all the keypairs created |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 62 | for keypair in key_list: |
| 63 | resp, _ = self.client.delete_keypair(keypair['name']) |
| 64 | self.assertEqual(202, resp.status) |
| 65 | |
Giulio Fidente | ba3985a | 2013-05-29 01:46:36 +0200 | [diff] [blame] | 66 | @attr(type='gate') |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 67 | def test_keypair_create_delete(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 68 | # Keypair should be created, verified and deleted |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 69 | k_name = rand_name('keypair-') |
| 70 | resp, keypair = self.client.create_keypair(k_name) |
| 71 | self.assertEqual(200, resp.status) |
| 72 | private_key = keypair['private_key'] |
| 73 | key_name = keypair['name'] |
| 74 | self.assertEqual(key_name, k_name, |
Zhongyue Luo | 79d8d36 | 2012-09-25 13:49:27 +0800 | [diff] [blame] | 75 | "The created keypair name is not equal " |
| 76 | "to the requested name") |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 77 | self.assertTrue(private_key is not None, |
Zhongyue Luo | 79d8d36 | 2012-09-25 13:49:27 +0800 | [diff] [blame] | 78 | "Field private_key is empty or not found.") |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 79 | resp, _ = self.client.delete_keypair(k_name) |
| 80 | self.assertEqual(202, resp.status) |
| 81 | |
Giulio Fidente | ba3985a | 2013-05-29 01:46:36 +0200 | [diff] [blame] | 82 | @attr(type='gate') |
rajalakshmi-ganesan | b74a11a | 2012-05-16 10:37:58 +0530 | [diff] [blame] | 83 | def test_get_keypair_detail(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 84 | # Keypair should be created, Got details by name and deleted |
rajalakshmi-ganesan | b74a11a | 2012-05-16 10:37:58 +0530 | [diff] [blame] | 85 | k_name = rand_name('keypair-') |
| 86 | resp, keypair = self.client.create_keypair(k_name) |
Giulio Fidente | 2732fca | 2013-08-29 13:40:22 +0200 | [diff] [blame^] | 87 | self.addCleanup(self.client.delete_keypair, k_name) |
Giulio Fidente | 92f7719 | 2013-08-26 17:13:28 +0200 | [diff] [blame] | 88 | resp, keypair_detail = self.client.get_keypair(k_name) |
| 89 | self.assertEqual(200, resp.status) |
Giulio Fidente | 92f7719 | 2013-08-26 17:13:28 +0200 | [diff] [blame] | 90 | self.assertIn('name', keypair_detail) |
| 91 | self.assertIn('public_key', keypair_detail) |
| 92 | self.assertEqual(keypair_detail['name'], k_name, |
| 93 | "The created keypair name is not equal " |
| 94 | "to requested name") |
| 95 | public_key = keypair_detail['public_key'] |
| 96 | self.assertTrue(public_key is not None, |
| 97 | "Field public_key is empty or not found.") |
rajalakshmi-ganesan | b74a11a | 2012-05-16 10:37:58 +0530 | [diff] [blame] | 98 | |
Giulio Fidente | ba3985a | 2013-05-29 01:46:36 +0200 | [diff] [blame] | 99 | @attr(type='gate') |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 100 | def test_keypair_create_with_pub_key(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 101 | # Keypair should be created with a given public key |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 102 | k_name = rand_name('keypair-') |
| 103 | pub_key = ("ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCs" |
| 104 | "Ne3/1ILNCqFyfYWDeTKLD6jEXC2OQHLmietMWW+/vd" |
| 105 | "aZq7KZEwO0jhglaFjU1mpqq4Gz5RX156sCTNM9vRbw" |
| 106 | "KAxfsdF9laBYVsex3m3Wmui3uYrKyumsoJn2g9GNnG1P" |
| 107 | "I1mrVjZ61i0GY3khna+wzlTpCCmy5HNlrmbj3XLqBUpip" |
| 108 | "TOXmsnr4sChzC53KCd8LXuwc1i/CZPvF+3XipvAgFSE53pCt" |
| 109 | "LOeB1kYMOBaiUPLQTWXR3JpckqFIQwhIH0zoHlJvZE8hh90" |
| 110 | "XcPojYN56tI0OlrGqojbediJYD0rUsJu4weZpbn8vilb3JuDY+jws" |
| 111 | "snSA8wzBx3A/8y9Pp1B nova@ubuntu") |
| 112 | resp, keypair = self.client.create_keypair(k_name, pub_key) |
| 113 | self.assertEqual(200, resp.status) |
| 114 | self.assertFalse('private_key' in keypair, |
Zhongyue Luo | 79d8d36 | 2012-09-25 13:49:27 +0800 | [diff] [blame] | 115 | "Field private_key is not empty!") |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 116 | key_name = keypair['name'] |
| 117 | self.assertEqual(key_name, k_name, |
Zhongyue Luo | 79d8d36 | 2012-09-25 13:49:27 +0800 | [diff] [blame] | 118 | "The created keypair name is not equal " |
| 119 | "to the requested name!") |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 120 | resp, _ = self.client.delete_keypair(k_name) |
| 121 | self.assertEqual(202, resp.status) |
| 122 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 123 | @attr(type=['negative', 'gate']) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 124 | def test_keypair_create_with_invalid_pub_key(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 125 | # Keypair should not be created with a non RSA public key |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 126 | k_name = rand_name('keypair-') |
| 127 | pub_key = "ssh-rsa JUNK nova@ubuntu" |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 128 | self.assertRaises(exceptions.BadRequest, |
| 129 | self.client.create_keypair, k_name, pub_key) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 130 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 131 | @attr(type=['negative', 'gate']) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 132 | def test_keypair_delete_nonexistant_key(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 133 | # Non-existant key deletion should throw a proper error |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 134 | k_name = rand_name("keypair-non-existant-") |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 135 | self.assertRaises(exceptions.NotFound, self.client.delete_keypair, |
| 136 | k_name) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 137 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 138 | @attr(type=['negative', 'gate']) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 139 | def test_create_keypair_with_empty_public_key(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 140 | # Keypair should not be created with an empty public key |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 141 | k_name = rand_name("keypair-") |
| 142 | pub_key = ' ' |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 143 | self.assertRaises(exceptions.BadRequest, self.client.create_keypair, |
| 144 | k_name, pub_key) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 145 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 146 | @attr(type=['negative', 'gate']) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 147 | def test_create_keypair_when_public_key_bits_exceeds_maximum(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 148 | # Keypair should not be created when public key bits are too long |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 149 | k_name = rand_name("keypair-") |
| 150 | pub_key = 'ssh-rsa ' + 'A' * 2048 + ' openstack@ubuntu' |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 151 | self.assertRaises(exceptions.BadRequest, self.client.create_keypair, |
| 152 | k_name, pub_key) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 153 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 154 | @attr(type=['negative', 'gate']) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 155 | def test_create_keypair_with_duplicate_name(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 156 | # Keypairs with duplicate names should not be created |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 157 | k_name = rand_name('keypair-') |
| 158 | resp, _ = self.client.create_keypair(k_name) |
| 159 | self.assertEqual(200, resp.status) |
Attila Fazekas | f7f34f9 | 2013-08-01 17:01:44 +0200 | [diff] [blame] | 160 | # Now try the same keyname to ceate another key |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 161 | self.assertRaises(exceptions.Duplicate, self.client.create_keypair, |
| 162 | k_name) |
David Kranz | 5a23d86 | 2012-02-14 09:48:55 -0500 | [diff] [blame] | 163 | resp, _ = self.client.delete_keypair(k_name) |
| 164 | self.assertEqual(202, resp.status) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 165 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 166 | @attr(type=['negative', 'gate']) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 167 | def test_create_keypair_with_empty_name_string(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 168 | # Keypairs with name being an empty string should not be created |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 169 | self.assertRaises(exceptions.BadRequest, self.client.create_keypair, |
| 170 | '') |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 171 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 172 | @attr(type=['negative', 'gate']) |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 173 | def test_create_keypair_with_long_keynames(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 174 | # Keypairs with name longer than 255 chars should not be created |
kavan-patil | 2eb350f | 2012-01-19 11:17:26 +0000 | [diff] [blame] | 175 | k_name = 'keypair-'.ljust(260, '0') |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 176 | self.assertRaises(exceptions.BadRequest, self.client.create_keypair, |
| 177 | k_name) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 178 | |
Giampaolo Lauria | e9c7702 | 2013-05-22 01:23:58 -0400 | [diff] [blame] | 179 | @attr(type=['negative', 'gate']) |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 180 | def test_create_keypair_invalid_name(self): |
Sean Dague | 4dd2c0b | 2013-01-03 17:50:28 -0500 | [diff] [blame] | 181 | # Keypairs with name being an invalid name should not be created |
Rohit Karajgi | b4825c3 | 2012-04-24 13:52:34 -0700 | [diff] [blame] | 182 | k_name = 'key_/.\@:' |
Chris Yeoh | e04628e | 2013-02-25 17:12:21 +1030 | [diff] [blame] | 183 | self.assertRaises(exceptions.BadRequest, self.client.create_keypair, |
| 184 | k_name) |
Mauro S. M. Rodrigues | a636f53 | 2012-08-21 11:07:53 -0400 | [diff] [blame] | 185 | |
| 186 | |
Attila Fazekas | 19044d5 | 2013-02-16 07:35:06 +0100 | [diff] [blame] | 187 | class KeyPairsTestXML(KeyPairsTestJSON): |
| 188 | _interface = 'xml' |