Adds disk_format and container_format to Image, and
removes the type column. Needs migrate script, but having trouble getting sqlalchemy migrate to work with any call to drop_column(). :(
This commit is contained in:
parent
2201bf2106
commit
1550ea4c20
@ -40,7 +40,8 @@ BASE = models.BASE
|
|||||||
BASE_MODEL_ATTRS = set(['id', 'created_at', 'updated_at', 'deleted_at',
|
BASE_MODEL_ATTRS = set(['id', 'created_at', 'updated_at', 'deleted_at',
|
||||||
'deleted'])
|
'deleted'])
|
||||||
|
|
||||||
IMAGE_ATTRS = BASE_MODEL_ATTRS | set(['name', 'type', 'status', 'size',
|
IMAGE_ATTRS = BASE_MODEL_ATTRS | set(['name', 'status', 'size',
|
||||||
|
'disk_format', 'container_format',
|
||||||
'is_public', 'location'])
|
'is_public', 'location'])
|
||||||
|
|
||||||
|
|
||||||
@ -152,14 +153,7 @@ def validate_image(values):
|
|||||||
:param values: Mapping of image metadata to check
|
:param values: Mapping of image metadata to check
|
||||||
"""
|
"""
|
||||||
|
|
||||||
type = values.get('type', None)
|
status = values.get('status')
|
||||||
if not type:
|
|
||||||
msg = "Image type is required."
|
|
||||||
raise exception.Invalid(msg)
|
|
||||||
if type not in ('machine', 'kernel', 'ramdisk', 'raw', 'vhd'):
|
|
||||||
msg = "Invalid image type '%s' for image." % type
|
|
||||||
raise exception.Invalid(msg)
|
|
||||||
status = values.get('status', None)
|
|
||||||
if not status:
|
if not status:
|
||||||
msg = "Image status is required."
|
msg = "Image status is required."
|
||||||
raise exception.Invalid(msg)
|
raise exception.Invalid(msg)
|
||||||
@ -167,6 +161,16 @@ def validate_image(values):
|
|||||||
msg = "Invalid image status '%s' for image." % status
|
msg = "Invalid image status '%s' for image." % status
|
||||||
raise exception.Invalid(msg)
|
raise exception.Invalid(msg)
|
||||||
|
|
||||||
|
disk_format = values.get('disk_format')
|
||||||
|
if not disk_format in ('vmdk', 'ami', 'raw', 'vhd'):
|
||||||
|
msg = "Invalid disk format '%s' for image." % disk_format
|
||||||
|
raise exception.Invalid(msg)
|
||||||
|
|
||||||
|
container_format = values.get('container_format')
|
||||||
|
if not container_format in ('ami', 'ovf'):
|
||||||
|
msg = "Invalid container format '%s' for image." % container_format
|
||||||
|
raise exception.Invalid(msg)
|
||||||
|
|
||||||
|
|
||||||
def _image_update(context, values, image_id):
|
def _image_update(context, values, image_id):
|
||||||
"""Used internally by image_create and image_update
|
"""Used internally by image_create and image_update
|
||||||
|
@ -36,7 +36,8 @@ def define_images_table(meta):
|
|||||||
Column('deleted_at', DateTime()),
|
Column('deleted_at', DateTime()),
|
||||||
Column('deleted', Boolean(), nullable=False, default=False,
|
Column('deleted', Boolean(), nullable=False, default=False,
|
||||||
index=True),
|
index=True),
|
||||||
mysql_engine='InnoDB')
|
mysql_engine='InnoDB',
|
||||||
|
useexisting=True)
|
||||||
|
|
||||||
return images
|
return images
|
||||||
|
|
||||||
|
@ -41,7 +41,8 @@ def define_image_properties_table(meta):
|
|||||||
Column('deleted', Boolean(), nullable=False, default=False,
|
Column('deleted', Boolean(), nullable=False, default=False,
|
||||||
index=True),
|
index=True),
|
||||||
UniqueConstraint('image_id', 'key'),
|
UniqueConstraint('image_id', 'key'),
|
||||||
mysql_engine='InnoDB')
|
mysql_engine='InnoDB',
|
||||||
|
useexisting=True)
|
||||||
|
|
||||||
Index('ix_image_properties_image_id_key', image_properties.c.image_id,
|
Index('ix_image_properties_image_id_key', image_properties.c.image_id,
|
||||||
image_properties.c.key)
|
image_properties.c.key)
|
||||||
|
@ -95,7 +95,8 @@ class Image(BASE, ModelBase):
|
|||||||
|
|
||||||
id = Column(Integer, primary_key=True)
|
id = Column(Integer, primary_key=True)
|
||||||
name = Column(String(255))
|
name = Column(String(255))
|
||||||
type = Column(String(30))
|
disk_format = Column(String(20))
|
||||||
|
container_format = Column(String(20))
|
||||||
size = Column(Integer)
|
size = Column(Integer)
|
||||||
status = Column(String(30), nullable=False)
|
status = Column(String(30), nullable=False)
|
||||||
is_public = Column(Boolean, nullable=False, default=False)
|
is_public = Column(Boolean, nullable=False, default=False)
|
||||||
|
@ -55,7 +55,6 @@ class Controller(wsgi.Controller):
|
|||||||
images = db_api.image_get_all_public(None)
|
images = db_api.image_get_all_public(None)
|
||||||
image_dicts = [dict(id=i['id'],
|
image_dicts = [dict(id=i['id'],
|
||||||
name=i['name'],
|
name=i['name'],
|
||||||
type=i['type'],
|
|
||||||
size=i['size']) for i in images]
|
size=i['size']) for i in images]
|
||||||
return dict(images=image_dicts)
|
return dict(images=image_dicts)
|
||||||
|
|
||||||
|
@ -82,7 +82,6 @@ class Controller(wsgi.Controller):
|
|||||||
* id -- The opaque image identifier
|
* id -- The opaque image identifier
|
||||||
* name -- The name of the image
|
* name -- The name of the image
|
||||||
* size -- Size of image data in bytes
|
* size -- Size of image data in bytes
|
||||||
* type -- One of 'kernel', 'ramdisk', 'raw', or 'machine'
|
|
||||||
|
|
||||||
:param request: The WSGI/Webob Request object
|
:param request: The WSGI/Webob Request object
|
||||||
:retval The response body is a mapping of the following form::
|
:retval The response body is a mapping of the following form::
|
||||||
@ -90,8 +89,7 @@ class Controller(wsgi.Controller):
|
|||||||
{'images': [
|
{'images': [
|
||||||
{'id': <ID>,
|
{'id': <ID>,
|
||||||
'name': <NAME>,
|
'name': <NAME>,
|
||||||
'size': <SIZE>,
|
'size': <SIZE>}, ...
|
||||||
'type': <TYPE>}, ...
|
|
||||||
]}
|
]}
|
||||||
"""
|
"""
|
||||||
images = registry.get_images_list(self.options)
|
images = registry.get_images_list(self.options)
|
||||||
@ -108,7 +106,8 @@ class Controller(wsgi.Controller):
|
|||||||
{'id': <ID>,
|
{'id': <ID>,
|
||||||
'name': <NAME>,
|
'name': <NAME>,
|
||||||
'size': <SIZE>,
|
'size': <SIZE>,
|
||||||
'type': <TYPE>,
|
'disk_format': <DISK_FORMAT>,
|
||||||
|
'container_format': <CONTAINER_FORMAT>,
|
||||||
'store': <STORE>,
|
'store': <STORE>,
|
||||||
'status': <STATUS>,
|
'status': <STATUS>,
|
||||||
'created_at': <TIMESTAMP>,
|
'created_at': <TIMESTAMP>,
|
||||||
|
@ -340,7 +340,8 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
{'id': 1,
|
{'id': 1,
|
||||||
'name': 'fake image #1',
|
'name': 'fake image #1',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'type': 'kernel',
|
'disk_format': 'ami',
|
||||||
|
'container_format': 'ami',
|
||||||
'is_public': False,
|
'is_public': False,
|
||||||
'created_at': datetime.datetime.utcnow(),
|
'created_at': datetime.datetime.utcnow(),
|
||||||
'updated_at': datetime.datetime.utcnow(),
|
'updated_at': datetime.datetime.utcnow(),
|
||||||
@ -348,11 +349,14 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
'deleted': False,
|
'deleted': False,
|
||||||
'size': 13,
|
'size': 13,
|
||||||
'location': "swift://user:passwd@acct/container/obj.tar.0",
|
'location': "swift://user:passwd@acct/container/obj.tar.0",
|
||||||
'properties': []},
|
'properties': [{'key': 'type',
|
||||||
|
'value': 'kernel',
|
||||||
|
'deleted': False}]},
|
||||||
{'id': 2,
|
{'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'created_at': datetime.datetime.utcnow(),
|
'created_at': datetime.datetime.utcnow(),
|
||||||
'updated_at': datetime.datetime.utcnow(),
|
'updated_at': datetime.datetime.utcnow(),
|
||||||
@ -362,8 +366,6 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
'properties': []}]
|
'properties': []}]
|
||||||
|
|
||||||
VALID_STATUSES = ('active', 'killed', 'queued', 'saving')
|
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.images = FakeDatastore.FIXTURES
|
self.images = FakeDatastore.FIXTURES
|
||||||
self.next_id = 3
|
self.next_id = 3
|
||||||
@ -376,12 +378,7 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
raise exception.Duplicate("Duplicate image id: %s" %
|
raise exception.Duplicate("Duplicate image id: %s" %
|
||||||
values['id'])
|
values['id'])
|
||||||
|
|
||||||
if 'status' not in values.keys():
|
glance.registry.db.api.validate_image(values)
|
||||||
values['status'] = 'active'
|
|
||||||
else:
|
|
||||||
if not values['status'] in self.VALID_STATUSES:
|
|
||||||
raise exception.Invalid("Invalid status '%s' for image" %
|
|
||||||
values['status'])
|
|
||||||
|
|
||||||
values['size'] = values.get('size', 0)
|
values['size'] = values.get('size', 0)
|
||||||
values['deleted'] = False
|
values['deleted'] = False
|
||||||
@ -393,7 +390,7 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
props = []
|
props = []
|
||||||
|
|
||||||
if 'properties' in values.keys():
|
if 'properties' in values.keys():
|
||||||
for k, v in values['properties'].iteritems():
|
for k, v in values['properties'].items():
|
||||||
p = {}
|
p = {}
|
||||||
p['key'] = k
|
p['key'] = k
|
||||||
p['value'] = v
|
p['value'] = v
|
||||||
@ -414,7 +411,7 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
props = []
|
props = []
|
||||||
|
|
||||||
if 'properties' in values.keys():
|
if 'properties' in values.keys():
|
||||||
for k, v in values['properties'].iteritems():
|
for k, v in values['properties'].items():
|
||||||
p = {}
|
p = {}
|
||||||
p['key'] = k
|
p['key'] = k
|
||||||
p['value'] = v
|
p['value'] = v
|
||||||
@ -439,9 +436,8 @@ def stub_out_registry_db_image_api(stubs):
|
|||||||
images = [i for i in self.images if str(i['id']) == str(image_id)]
|
images = [i for i in self.images if str(i['id']) == str(image_id)]
|
||||||
|
|
||||||
if len(images) != 1 or images[0]['deleted']:
|
if len(images) != 1 or images[0]['deleted']:
|
||||||
new_exc = exception.NotFound("No model for id %s %s" %
|
raise exception.NotFound("No model for id %s %s" %
|
||||||
(image_id, str(self.images)))
|
(image_id, str(self.images)))
|
||||||
raise new_exc.__class__, new_exc, sys.exc_info()[2]
|
|
||||||
else:
|
else:
|
||||||
return images[0]
|
return images[0]
|
||||||
|
|
||||||
|
@ -85,7 +85,8 @@ class TestRegistryAPI(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'active'}
|
'status': 'active'}
|
||||||
|
|
||||||
req = webob.Request.blank('/images/detail')
|
req = webob.Request.blank('/images/detail')
|
||||||
@ -103,7 +104,8 @@ class TestRegistryAPI(unittest.TestCase):
|
|||||||
"""Tests that the /images POST registry API creates the image"""
|
"""Tests that the /images POST registry API creates the image"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel'}
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf'}
|
||||||
|
|
||||||
req = webob.Request.blank('/images')
|
req = webob.Request.blank('/images')
|
||||||
|
|
||||||
@ -130,7 +132,8 @@ class TestRegistryAPI(unittest.TestCase):
|
|||||||
fixture = {'id': 3,
|
fixture = {'id': 3,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status'}
|
'status': 'bad status'}
|
||||||
|
|
||||||
req = webob.Request.blank('/images')
|
req = webob.Request.blank('/images')
|
||||||
@ -144,7 +147,7 @@ class TestRegistryAPI(unittest.TestCase):
|
|||||||
def test_update_image(self):
|
def test_update_image(self):
|
||||||
"""Tests that the /images PUT registry API updates the image"""
|
"""Tests that the /images PUT registry API updates the image"""
|
||||||
fixture = {'name': 'fake public image #2',
|
fixture = {'name': 'fake public image #2',
|
||||||
'type': 'ramdisk'}
|
'disk_format': 'raw'}
|
||||||
|
|
||||||
req = webob.Request.blank('/images/2')
|
req = webob.Request.blank('/images/2')
|
||||||
|
|
||||||
@ -166,7 +169,8 @@ class TestRegistryAPI(unittest.TestCase):
|
|||||||
fixture = {'id': 3,
|
fixture = {'id': 3,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status'}
|
'status': 'bad status'}
|
||||||
|
|
||||||
req = webob.Request.blank('/images/3')
|
req = webob.Request.blank('/images/3')
|
||||||
@ -242,7 +246,9 @@ class TestGlanceAPI(unittest.TestCase):
|
|||||||
def test_add_image_no_location_no_image_as_body(self):
|
def test_add_image_no_location_no_image_as_body(self):
|
||||||
"""Tests creates a queued image for no body and no loc header"""
|
"""Tests creates a queued image for no body and no loc header"""
|
||||||
fixture_headers = {'x-image-meta-store': 'file',
|
fixture_headers = {'x-image-meta-store': 'file',
|
||||||
'x-image-meta-name': 'fake image #3'}
|
'x-image-meta-disk-format': 'vhd',
|
||||||
|
'x-image-meta-container-format': 'ovf',
|
||||||
|
'x-image-meta-name': 'fake image #3'}
|
||||||
|
|
||||||
req = webob.Request.blank("/images")
|
req = webob.Request.blank("/images")
|
||||||
req.method = 'POST'
|
req.method = 'POST'
|
||||||
@ -270,8 +276,10 @@ class TestGlanceAPI(unittest.TestCase):
|
|||||||
self.assertEquals(res.status_int, webob.exc.HTTPBadRequest.code)
|
self.assertEquals(res.status_int, webob.exc.HTTPBadRequest.code)
|
||||||
|
|
||||||
def test_add_image_basic_file_store(self):
|
def test_add_image_basic_file_store(self):
|
||||||
"""Tests raises BadRequest for invalid store header"""
|
"""Tests to add a basic image in the file store"""
|
||||||
fixture_headers = {'x-image-meta-store': 'file',
|
fixture_headers = {'x-image-meta-store': 'file',
|
||||||
|
'x-image-meta-disk-format': 'vhd',
|
||||||
|
'x-image-meta-container-format': 'ovf',
|
||||||
'x-image-meta-name': 'fake image #3'}
|
'x-image-meta-name': 'fake image #3'}
|
||||||
|
|
||||||
req = webob.Request.blank("/images")
|
req = webob.Request.blank("/images")
|
||||||
|
@ -66,7 +66,7 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
images = self.client.get_images()
|
images = self.client.get_images()
|
||||||
self.assertEquals(len(images), 1)
|
self.assertEquals(len(images), 1)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, images[0][k])
|
self.assertEquals(v, images[0][k])
|
||||||
|
|
||||||
def test_get_image_details(self):
|
def test_get_image_details(self):
|
||||||
@ -74,16 +74,8 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
'status': 'active',
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
|
||||||
'location': "file:///tmp/glance-tests/2",
|
|
||||||
'properties': {}}
|
|
||||||
|
|
||||||
expected = {'id': 2,
|
|
||||||
'name': 'fake image #2',
|
|
||||||
'is_public': True,
|
|
||||||
'type': 'kernel',
|
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -92,33 +84,28 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
images = self.client.get_images_detailed()
|
images = self.client.get_images_detailed()
|
||||||
self.assertEquals(len(images), 1)
|
self.assertEquals(len(images), 1)
|
||||||
|
|
||||||
for k, v in expected.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, images[0][k])
|
self.assertEquals(v, images[0][k])
|
||||||
|
|
||||||
def test_get_image(self):
|
def test_get_image(self):
|
||||||
"""Tests that the detailed info about an image returned"""
|
"""Tests that the detailed info about an image returned"""
|
||||||
fixture = {'id': 2,
|
fixture = {'id': 1,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #1',
|
||||||
'is_public': True,
|
'is_public': False,
|
||||||
'type': 'kernel',
|
'disk_format': 'ami',
|
||||||
|
'container_format': 'ami',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 13,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "swift://user:passwd@acct/container/obj.tar.0",
|
||||||
'properties': {}}
|
'properties': {'type': 'kernel'}}
|
||||||
|
|
||||||
expected = {'id': 2,
|
data = self.client.get_image(1)
|
||||||
'name': 'fake image #2',
|
|
||||||
'is_public': True,
|
|
||||||
'type': 'kernel',
|
|
||||||
'status': 'active',
|
|
||||||
'size': 19,
|
|
||||||
'location': "file:///tmp/glance-tests/2",
|
|
||||||
'properties': {}}
|
|
||||||
|
|
||||||
data = self.client.get_image(2)
|
for k, v in fixture.items():
|
||||||
|
el = data[k]
|
||||||
for k, v in expected.iteritems():
|
self.assertEquals(v, data[k],
|
||||||
self.assertEquals(v, data[k])
|
"Failed v != data[k] where v = %(v)s and "
|
||||||
|
"k = %(k)s and data[k] = %(el)s" % locals())
|
||||||
|
|
||||||
def test_get_image_non_existing(self):
|
def test_get_image_non_existing(self):
|
||||||
"""Tests that NotFound is raised when getting a non-existing image"""
|
"""Tests that NotFound is raised when getting a non-existing image"""
|
||||||
@ -131,7 +118,8 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
"""Tests that we can add image metadata and returns the new id"""
|
"""Tests that we can add image metadata and returns the new id"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vmdk',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/acct/3.gz.0",
|
'location': "file:///tmp/glance-tests/acct/3.gz.0",
|
||||||
}
|
}
|
||||||
@ -144,7 +132,7 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
# Test all other attributes set
|
# Test all other attributes set
|
||||||
data = self.client.get_image(3)
|
data = self.client.get_image(3)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
# Test status was updated properly
|
# Test status was updated properly
|
||||||
@ -155,23 +143,18 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
"""Tests that we can add image metadata with properties"""
|
"""Tests that we can add image metadata with properties"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vmdk',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'}}
|
'properties': {'distro': 'Ubuntu 10.04 LTS'}}
|
||||||
expected = {'name': 'fake public image',
|
|
||||||
'is_public': True,
|
|
||||||
'type': 'kernel',
|
|
||||||
'size': 19,
|
|
||||||
'location': "file:///tmp/glance-tests/2",
|
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'}}
|
|
||||||
|
|
||||||
new_image = self.client.add_image(fixture)
|
new_image = self.client.add_image(fixture)
|
||||||
|
|
||||||
# Test ID auto-assigned properly
|
# Test ID auto-assigned properly
|
||||||
self.assertEquals(3, new_image['id'])
|
self.assertEquals(3, new_image['id'])
|
||||||
|
|
||||||
for k, v in expected.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, new_image[k])
|
self.assertEquals(v, new_image[k])
|
||||||
|
|
||||||
# Test status was updated properly
|
# Test status was updated properly
|
||||||
@ -183,7 +166,8 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vmdk',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -198,7 +182,8 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
fixture = {'id': 3,
|
fixture = {'id': 3,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vmdk',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -211,14 +196,14 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
def test_update_image(self):
|
def test_update_image(self):
|
||||||
"""Tests that the /images PUT registry API updates the image"""
|
"""Tests that the /images PUT registry API updates the image"""
|
||||||
fixture = {'name': 'fake public image #2',
|
fixture = {'name': 'fake public image #2',
|
||||||
'type': 'ramdisk'}
|
'disk_format': 'vmdk'}
|
||||||
|
|
||||||
self.assertTrue(self.client.update_image(2, fixture))
|
self.assertTrue(self.client.update_image(2, fixture))
|
||||||
|
|
||||||
# Test all other attributes set
|
# Test all other attributes set
|
||||||
data = self.client.get_image(2)
|
data = self.client.get_image(2)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
def test_update_image_not_existing(self):
|
def test_update_image_not_existing(self):
|
||||||
@ -226,7 +211,8 @@ class TestRegistryClient(unittest.TestCase):
|
|||||||
fixture = {'id': 3,
|
fixture = {'id': 3,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vmdk',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -283,7 +269,8 @@ class TestClient(unittest.TestCase):
|
|||||||
expected_meta = {'id': 2,
|
expected_meta = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -295,7 +282,7 @@ class TestClient(unittest.TestCase):
|
|||||||
image_data += image_chunk
|
image_data += image_chunk
|
||||||
|
|
||||||
self.assertEquals(expected_image, image_data)
|
self.assertEquals(expected_image, image_data)
|
||||||
for k, v in expected_meta.iteritems():
|
for k, v in expected_meta.items():
|
||||||
self.assertEquals(v, meta[k])
|
self.assertEquals(v, meta[k])
|
||||||
|
|
||||||
def test_get_image_not_existing(self):
|
def test_get_image_not_existing(self):
|
||||||
@ -312,7 +299,7 @@ class TestClient(unittest.TestCase):
|
|||||||
images = self.client.get_images()
|
images = self.client.get_images()
|
||||||
self.assertEquals(len(images), 1)
|
self.assertEquals(len(images), 1)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, images[0][k])
|
self.assertEquals(v, images[0][k])
|
||||||
|
|
||||||
def test_get_image_details(self):
|
def test_get_image_details(self):
|
||||||
@ -320,7 +307,8 @@ class TestClient(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -329,7 +317,8 @@ class TestClient(unittest.TestCase):
|
|||||||
expected = {'id': 2,
|
expected = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -338,7 +327,7 @@ class TestClient(unittest.TestCase):
|
|||||||
images = self.client.get_images_detailed()
|
images = self.client.get_images_detailed()
|
||||||
self.assertEquals(len(images), 1)
|
self.assertEquals(len(images), 1)
|
||||||
|
|
||||||
for k, v in expected.iteritems():
|
for k, v in expected.items():
|
||||||
self.assertEquals(v, images[0][k])
|
self.assertEquals(v, images[0][k])
|
||||||
|
|
||||||
def test_get_image_meta(self):
|
def test_get_image_meta(self):
|
||||||
@ -346,16 +335,8 @@ class TestClient(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake image #2',
|
'name': 'fake image #2',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
'status': 'active',
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
|
||||||
'location': "file:///tmp/glance-tests/2",
|
|
||||||
'properties': {}}
|
|
||||||
|
|
||||||
expected = {'id': 2,
|
|
||||||
'name': 'fake image #2',
|
|
||||||
'is_public': True,
|
|
||||||
'type': 'kernel',
|
|
||||||
'status': 'active',
|
'status': 'active',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -363,7 +344,7 @@ class TestClient(unittest.TestCase):
|
|||||||
|
|
||||||
data = self.client.get_image_meta(2)
|
data = self.client.get_image_meta(2)
|
||||||
|
|
||||||
for k, v in expected.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
def test_get_image_non_existing(self):
|
def test_get_image_non_existing(self):
|
||||||
@ -377,7 +358,8 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests client returns image as queued"""
|
"""Tests client returns image as queued"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
}
|
}
|
||||||
image_meta = self.client.add_image(fixture)
|
image_meta = self.client.add_image(fixture)
|
||||||
self.assertEquals('queued', image_meta['status'])
|
self.assertEquals('queued', image_meta['status'])
|
||||||
@ -387,7 +369,8 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests that we can add image metadata and returns the new id"""
|
"""Tests that we can add image metadata and returns the new id"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
}
|
}
|
||||||
@ -400,7 +383,7 @@ class TestClient(unittest.TestCase):
|
|||||||
# Test all other attributes set
|
# Test all other attributes set
|
||||||
data = self.client.get_image_meta(3)
|
data = self.client.get_image_meta(3)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
# Test status was updated properly
|
# Test status was updated properly
|
||||||
@ -411,18 +394,12 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests that we can add image metadata with properties"""
|
"""Tests that we can add image metadata with properties"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
||||||
}
|
}
|
||||||
expected = {'name': 'fake public image',
|
|
||||||
'is_public': True,
|
|
||||||
'type': 'kernel',
|
|
||||||
'size': 19,
|
|
||||||
'location': "file:///tmp/glance-tests/2",
|
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
|
||||||
}
|
|
||||||
new_image = self.client.add_image(fixture)
|
new_image = self.client.add_image(fixture)
|
||||||
new_image_id = new_image['id']
|
new_image_id = new_image['id']
|
||||||
|
|
||||||
@ -432,7 +409,7 @@ class TestClient(unittest.TestCase):
|
|||||||
# Test all other attributes set
|
# Test all other attributes set
|
||||||
data = self.client.get_image_meta(3)
|
data = self.client.get_image_meta(3)
|
||||||
|
|
||||||
for k, v in expected.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
# Test status was updated properly
|
# Test status was updated properly
|
||||||
@ -444,7 +421,8 @@ class TestClient(unittest.TestCase):
|
|||||||
fixture = {'id': 2,
|
fixture = {'id': 2,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -458,7 +436,8 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests a bad status is set to a proper one by server"""
|
"""Tests a bad status is set to a proper one by server"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'location': "file:///tmp/glance-tests/2",
|
'location': "file:///tmp/glance-tests/2",
|
||||||
@ -471,7 +450,8 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests can add image by passing image data as string"""
|
"""Tests can add image by passing image data as string"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
||||||
}
|
}
|
||||||
@ -489,14 +469,15 @@ class TestClient(unittest.TestCase):
|
|||||||
new_image_data += image_chunk
|
new_image_data += image_chunk
|
||||||
|
|
||||||
self.assertEquals(image_data_fixture, new_image_data)
|
self.assertEquals(image_data_fixture, new_image_data)
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, new_meta[k])
|
self.assertEquals(v, new_meta[k])
|
||||||
|
|
||||||
def test_add_image_with_image_data_as_file(self):
|
def test_add_image_with_image_data_as_file(self):
|
||||||
"""Tests can add image by passing image data as file"""
|
"""Tests can add image by passing image data as file"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
||||||
}
|
}
|
||||||
@ -526,14 +507,15 @@ class TestClient(unittest.TestCase):
|
|||||||
new_image_data += image_chunk
|
new_image_data += image_chunk
|
||||||
|
|
||||||
self.assertEquals(image_data_fixture, new_image_data)
|
self.assertEquals(image_data_fixture, new_image_data)
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, new_meta[k])
|
self.assertEquals(v, new_meta[k])
|
||||||
|
|
||||||
def test_add_image_with_image_data_as_string_and_no_size(self):
|
def test_add_image_with_image_data_as_string_and_no_size(self):
|
||||||
"""Tests add image by passing image data as string w/ no size attr"""
|
"""Tests add image by passing image data as string w/ no size attr"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,7 +532,7 @@ class TestClient(unittest.TestCase):
|
|||||||
new_image_data += image_chunk
|
new_image_data += image_chunk
|
||||||
|
|
||||||
self.assertEquals(image_data_fixture, new_image_data)
|
self.assertEquals(image_data_fixture, new_image_data)
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, new_meta[k])
|
self.assertEquals(v, new_meta[k])
|
||||||
|
|
||||||
self.assertEquals(19, new_meta['size'])
|
self.assertEquals(19, new_meta['size'])
|
||||||
@ -559,7 +541,8 @@ class TestClient(unittest.TestCase):
|
|||||||
"""Tests BadRequest raised when supplying bad store name in meta"""
|
"""Tests BadRequest raised when supplying bad store name in meta"""
|
||||||
fixture = {'name': 'fake public image',
|
fixture = {'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'size': 19,
|
'size': 19,
|
||||||
'store': 'bad',
|
'store': 'bad',
|
||||||
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
'properties': {'distro': 'Ubuntu 10.04 LTS'},
|
||||||
@ -575,15 +558,14 @@ class TestClient(unittest.TestCase):
|
|||||||
def test_update_image(self):
|
def test_update_image(self):
|
||||||
"""Tests that the /images PUT registry API updates the image"""
|
"""Tests that the /images PUT registry API updates the image"""
|
||||||
fixture = {'name': 'fake public image #2',
|
fixture = {'name': 'fake public image #2',
|
||||||
'type': 'ramdisk',
|
'disk_format': 'vmdk'}
|
||||||
}
|
|
||||||
|
|
||||||
self.assertTrue(self.client.update_image(2, fixture))
|
self.assertTrue(self.client.update_image(2, fixture))
|
||||||
|
|
||||||
# Test all other attributes set
|
# Test all other attributes set
|
||||||
data = self.client.get_image_meta(2)
|
data = self.client.get_image_meta(2)
|
||||||
|
|
||||||
for k, v in fixture.iteritems():
|
for k, v in fixture.items():
|
||||||
self.assertEquals(v, data[k])
|
self.assertEquals(v, data[k])
|
||||||
|
|
||||||
def test_update_image_not_existing(self):
|
def test_update_image_not_existing(self):
|
||||||
@ -591,7 +573,8 @@ class TestClient(unittest.TestCase):
|
|||||||
fixture = {'id': 3,
|
fixture = {'id': 3,
|
||||||
'name': 'fake public image',
|
'name': 'fake public image',
|
||||||
'is_public': True,
|
'is_public': True,
|
||||||
'type': 'kernel',
|
'disk_format': 'vhd',
|
||||||
|
'container_format': 'ovf',
|
||||||
'status': 'bad status',
|
'status': 'bad status',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,8 @@ class TestMigrations(unittest.TestCase):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.db_path = "glance_test_migration.sqlite"
|
self.db_path = "glance_test_migration.sqlite"
|
||||||
|
if os.path.exists(self.db_path):
|
||||||
|
os.unlink(self.db_path)
|
||||||
self.options = dict(sql_connection="sqlite:///%s" % self.db_path,
|
self.options = dict(sql_connection="sqlite:///%s" % self.db_path,
|
||||||
verbose=False)
|
verbose=False)
|
||||||
config.setup_logging(self.options)
|
config.setup_logging(self.options)
|
||||||
|
@ -149,8 +149,8 @@ sql_idle_timeout = 3600
|
|||||||
"-dinvalid http://0.0.0.0:%d/images" % api_port
|
"-dinvalid http://0.0.0.0:%d/images" % api_port
|
||||||
ignored, out, err = execute(cmd)
|
ignored, out, err = execute(cmd)
|
||||||
|
|
||||||
self.assertTrue('Image type is required' in out,
|
self.assertTrue('Invalid disk format' in out,
|
||||||
"Could not find 'Image type is required' "
|
"Could not find 'Invalid disk format' "
|
||||||
"in output: %s" % out)
|
"in output: %s" % out)
|
||||||
|
|
||||||
cmd = "./bin/glance-upload --port=%(api_port)d "\
|
cmd = "./bin/glance-upload --port=%(api_port)d "\
|
||||||
@ -164,7 +164,7 @@ sql_idle_timeout = 3600
|
|||||||
ignored, out, err = execute(cmd)
|
ignored, out, err = execute(cmd)
|
||||||
except RuntimeError, e:
|
except RuntimeError, e:
|
||||||
hit_exception = True
|
hit_exception = True
|
||||||
self.assertTrue('Invalid image type' in str(e))
|
self.assertTrue('Invalid disk format' in str(e))
|
||||||
self.assertTrue(hit_exception)
|
self.assertTrue(hit_exception)
|
||||||
|
|
||||||
# Spin down the API and default registry server
|
# Spin down the API and default registry server
|
||||||
|
Loading…
Reference in New Issue
Block a user