| # vim: tabstop=4 shiftwidth=4 softtabstop=4 |
| |
| # Copyright 2012 OpenStack, LLC |
| # 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. |
| |
| import cStringIO as StringIO |
| |
| from tempest import exceptions |
| from tempest.test import attr |
| from tempest.tests.image import base |
| |
| |
| class CreateRegisterImagesTest(base.BaseV1ImageTest): |
| """Here we test the registration and creation of images.""" |
| |
| @attr(type='negative') |
| def test_register_with_invalid_container_format(self): |
| # Negative tests for invalid data supplied to POST /images |
| self.assertRaises(exceptions.BadRequest, self.client.create_image, |
| 'test', 'wrong', 'vhd') |
| |
| @attr(type='negative') |
| def test_register_with_invalid_disk_format(self): |
| self.assertRaises(exceptions.BadRequest, self.client.create_image, |
| 'test', 'bare', 'wrong') |
| |
| @attr(type='image') |
| def test_register_then_upload(self): |
| # Register, then upload an image |
| properties = {'prop1': 'val1'} |
| resp, body = self.create_image(name='New Name', |
| container_format='bare', |
| disk_format='raw', |
| is_public=True, |
| properties=properties) |
| self.assertTrue('id' in body) |
| image_id = body.get('id') |
| self.created_images.append(image_id) |
| self.assertEqual('New Name', body.get('name')) |
| self.assertTrue(body.get('is_public')) |
| self.assertEqual('queued', body.get('status')) |
| for key, val in properties.items(): |
| self.assertEqual(val, body.get('properties')[key]) |
| |
| # Now try uploading an image file |
| image_file = StringIO.StringIO(('*' * 1024)) |
| resp, body = self.client.update_image(image_id, data=image_file) |
| self.assertTrue('size' in body) |
| self.assertEqual(1024, body.get('size')) |
| |
| @attr(type='image') |
| def test_register_remote_image(self): |
| # Register a new remote image |
| resp, body = self.create_image(name='New Remote Image', |
| container_format='bare', |
| disk_format='raw', is_public=True, |
| location='http://example.com' |
| '/someimage.iso', |
| properties={'key1': 'value1', |
| 'key2': 'value2'}) |
| self.assertTrue('id' in body) |
| image_id = body.get('id') |
| self.created_images.append(image_id) |
| self.assertEqual('New Remote Image', body.get('name')) |
| self.assertTrue(body.get('is_public')) |
| self.assertEqual('active', body.get('status')) |
| properties = body.get('properties') |
| self.assertEqual(properties['key1'], 'value1') |
| self.assertEqual(properties['key2'], 'value2') |
| |
| |
| class ListImagesTest(base.BaseV1ImageTest): |
| |
| """ |
| Here we test the listing of image information |
| """ |
| |
| @classmethod |
| def setUpClass(cls): |
| super(ListImagesTest, cls).setUpClass() |
| |
| # We add a few images here to test the listing functionality of |
| # the images API |
| img1 = cls._create_remote_image('one', 'bare', 'raw') |
| img2 = cls._create_remote_image('two', 'ami', 'ami') |
| img3 = cls._create_remote_image('dup', 'bare', 'raw') |
| img4 = cls._create_remote_image('dup', 'bare', 'raw') |
| img5 = cls._create_standard_image('1', 'ami', 'ami', 42) |
| img6 = cls._create_standard_image('2', 'ami', 'ami', 142) |
| img7 = cls._create_standard_image('33', 'bare', 'raw', 142) |
| img8 = cls._create_standard_image('33', 'bare', 'raw', 142) |
| cls.created_set = set(cls.created_images) |
| # 4x-4x remote image |
| cls.remote_set = set((img1, img2, img3, img4)) |
| cls.standard_set = set((img5, img6, img7, img8)) |
| # 5x bare, 3x ami |
| cls.bare_set = set((img1, img3, img4, img7, img8)) |
| cls.ami_set = set((img2, img5, img6)) |
| # 1x with size 42 |
| cls.size42_set = set((img5,)) |
| # 3x with size 142 |
| cls.size142_set = set((img6, img7, img8)) |
| # dup named |
| cls.dup_set = set((img3, img4)) |
| |
| @classmethod |
| def _create_remote_image(cls, name, container_format, disk_format): |
| """ |
| Create a new remote image and return the ID of the newly-registered |
| image |
| """ |
| name = 'New Remote Image %s' % name |
| location = 'http://example.com/someimage_%s.iso' % name |
| resp, image = cls.create_image(name=name, |
| container_format=container_format, |
| disk_format=disk_format, |
| is_public=True, |
| location=location) |
| image_id = image['id'] |
| return image_id |
| |
| @classmethod |
| def _create_standard_image(cls, name, container_format, |
| disk_format, size): |
| """ |
| Create a new standard image and return the ID of the newly-registered |
| image. Note that the size of the new image is a random number between |
| 1024 and 4096 |
| """ |
| image_file = StringIO.StringIO('*' * size) |
| name = 'New Standard Image %s' % name |
| resp, image = cls.create_image(name=name, |
| container_format=container_format, |
| disk_format=disk_format, |
| is_public=True, data=image_file) |
| image_id = image['id'] |
| return image_id |
| |
| @attr(type='image') |
| def test_index_no_params(self): |
| # Simple test to see all fixture images returned |
| resp, images_list = self.client.image_list() |
| self.assertEqual(resp['status'], '200') |
| image_list = map(lambda x: x['id'], images_list) |
| for image_id in self.created_images: |
| self.assertTrue(image_id in image_list) |
| |
| @attr(type='image') |
| def test_index_disk_format(self): |
| resp, images_list = self.client.image_list(disk_format='ami') |
| self.assertEqual(resp['status'], '200') |
| for image in images_list: |
| self.assertEqual(image['disk_format'], 'ami') |
| result_set = set(map(lambda x: x['id'], images_list)) |
| self.assertTrue(self.ami_set <= result_set) |
| self.assertFalse(self.created_set - self.ami_set <= result_set) |
| |
| @attr(type='image') |
| def test_index_container_format(self): |
| resp, images_list = self.client.image_list(container_format='bare') |
| self.assertEqual(resp['status'], '200') |
| for image in images_list: |
| self.assertEqual(image['container_format'], 'bare') |
| result_set = set(map(lambda x: x['id'], images_list)) |
| self.assertTrue(self.bare_set <= result_set) |
| self.assertFalse(self.created_set - self.bare_set <= result_set) |
| |
| @attr(type='image') |
| def test_index_max_size(self): |
| resp, images_list = self.client.image_list(size_max=42) |
| self.assertEqual(resp['status'], '200') |
| for image in images_list: |
| self.assertTrue(image['size'] <= 42) |
| result_set = set(map(lambda x: x['id'], images_list)) |
| self.assertTrue(self.size42_set <= result_set) |
| self.assertFalse(self.created_set - self.size42_set <= result_set) |
| |
| @attr(type='image') |
| def test_index_min_size(self): |
| resp, images_list = self.client.image_list(size_min=142) |
| self.assertEqual(resp['status'], '200') |
| for image in images_list: |
| self.assertTrue(image['size'] >= 142) |
| result_set = set(map(lambda x: x['id'], images_list)) |
| self.assertTrue(self.size142_set <= result_set) |
| self.assertFalse(self.size42_set <= result_set) |
| |
| @attr(type='image') |
| def test_index_status_active_detail(self): |
| resp, images_list = self.client.image_list_detail(status='active', |
| sort_key='size', |
| sort_dir='desc') |
| self.assertEqual(resp['status'], '200') |
| top_size = images_list[0]['size'] # We have non-zero sized images |
| for image in images_list: |
| size = image['size'] |
| self.assertTrue(size <= top_size) |
| top_size = size |
| self.assertEqual(image['status'], 'active') |
| |
| @attr(type='image') |
| def test_index_name(self): |
| resp, images_list = self.client.image_list_detail( |
| name='New Remote Image dup') |
| self.assertEqual(resp['status'], '200') |
| result_set = set(map(lambda x: x['id'], images_list)) |
| for image in images_list: |
| self.assertEqual(image['name'], 'New Remote Image dup') |
| self.assertTrue(self.dup_set <= result_set) |
| self.assertFalse(self.created_set - self.dup_set <= result_set) |