| # Copyright 2012 OpenStack Foundation |
| # Copyright 2013 IBM Corp |
| # All Rights Reserved. |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); you may |
| # not use this file except in compliance with the License. You may obtain |
| # a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| # WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| # License for the specific language governing permissions and limitations |
| # under the License. |
| |
| from tempest_lib import exceptions as lib_exc |
| |
| from tempest.api.compute import base |
| from tempest.common.utils import data_utils |
| from tempest import test |
| |
| |
| class KeyPairsNegativeTestJSON(base.BaseV2ComputeTest): |
| |
| @classmethod |
| def setup_clients(cls): |
| super(KeyPairsNegativeTestJSON, cls).setup_clients() |
| cls.client = cls.keypairs_client |
| |
| def _create_keypair(self, keypair_name, pub_key=None): |
| self.client.create_keypair(keypair_name, pub_key) |
| self.addCleanup(self.client.delete_keypair, keypair_name) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('29cca892-46ae-4d48-bc32-8fe7e731eb81') |
| def test_keypair_create_with_invalid_pub_key(self): |
| # Keypair should not be created with a non RSA public key |
| k_name = data_utils.rand_name('keypair') |
| pub_key = "ssh-rsa JUNK nova@ubuntu" |
| self.assertRaises(lib_exc.BadRequest, |
| self._create_keypair, k_name, pub_key) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('7cc32e47-4c42-489d-9623-c5e2cb5a2fa5') |
| def test_keypair_delete_nonexistent_key(self): |
| # Non-existent key deletion should throw a proper error |
| k_name = data_utils.rand_name("keypair-non-existent") |
| self.assertRaises(lib_exc.NotFound, self.client.delete_keypair, |
| k_name) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('dade320e-69ca-42a9-ba4a-345300f127e0') |
| def test_create_keypair_with_empty_public_key(self): |
| # Keypair should not be created with an empty public key |
| k_name = data_utils.rand_name("keypair") |
| pub_key = ' ' |
| self.assertRaises(lib_exc.BadRequest, self._create_keypair, |
| k_name, pub_key) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('fc100c19-2926-4b9c-8fdc-d0589ee2f9ff') |
| def test_create_keypair_when_public_key_bits_exceeds_maximum(self): |
| # Keypair should not be created when public key bits are too long |
| k_name = data_utils.rand_name("keypair") |
| pub_key = 'ssh-rsa ' + 'A' * 2048 + ' openstack@ubuntu' |
| self.assertRaises(lib_exc.BadRequest, self._create_keypair, |
| k_name, pub_key) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('0359a7f1-f002-4682-8073-0c91e4011b7c') |
| def test_create_keypair_with_duplicate_name(self): |
| # Keypairs with duplicate names should not be created |
| k_name = data_utils.rand_name('keypair') |
| self.client.create_keypair(k_name) |
| # Now try the same keyname to create another key |
| self.assertRaises(lib_exc.Conflict, self._create_keypair, |
| k_name) |
| self.client.delete_keypair(k_name) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('1398abe1-4a84-45fb-9294-89f514daff00') |
| def test_create_keypair_with_empty_name_string(self): |
| # Keypairs with name being an empty string should not be created |
| self.assertRaises(lib_exc.BadRequest, self._create_keypair, |
| '') |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('3faa916f-779f-4103-aca7-dc3538eee1b7') |
| def test_create_keypair_with_long_keynames(self): |
| # Keypairs with name longer than 255 chars should not be created |
| k_name = 'keypair-'.ljust(260, '0') |
| self.assertRaises(lib_exc.BadRequest, self._create_keypair, |
| k_name) |
| |
| @test.attr(type=['negative']) |
| @test.idempotent_id('45fbe5e0-acb5-49aa-837a-ff8d0719db91') |
| def test_create_keypair_invalid_name(self): |
| # Keypairs with name being an invalid name should not be created |
| k_name = 'key_/.\@:' |
| self.assertRaises(lib_exc.BadRequest, self._create_keypair, |
| k_name) |