Add deserialization for multiple create and az
We were not deserializing xml values causing the multiple create extension and the availability zone extension to fail with xml. This adds deserialization for these attributes and adds tests Part of bug 1050997 Change-Id: Ic40ce58b0854717dd99dba8ed39c861e31e6bba4
This commit is contained in:
parent
afefc88389
commit
71c9677d80
@ -159,11 +159,16 @@ class CommonDeserializer(wsgi.MetadataXMLDeserializer):
|
|||||||
server_node = self.find_first_child_named(node, 'server')
|
server_node = self.find_first_child_named(node, 'server')
|
||||||
|
|
||||||
attributes = ["name", "imageRef", "flavorRef", "adminPass",
|
attributes = ["name", "imageRef", "flavorRef", "adminPass",
|
||||||
"accessIPv4", "accessIPv6", "key_name"]
|
"accessIPv4", "accessIPv6", "key_name",
|
||||||
|
"availability_zone", "min_count", "max_count"]
|
||||||
for attr in attributes:
|
for attr in attributes:
|
||||||
if server_node.getAttribute(attr):
|
if server_node.getAttribute(attr):
|
||||||
server[attr] = server_node.getAttribute(attr)
|
server[attr] = server_node.getAttribute(attr)
|
||||||
|
|
||||||
|
res_id = server_node.getAttribute('return_reservation_id')
|
||||||
|
if res_id:
|
||||||
|
server['return_reservation_id'] = utils.bool_from_str(res_id)
|
||||||
|
|
||||||
scheduler_hints = self._extract_scheduler_hints(server_node)
|
scheduler_hints = self._extract_scheduler_hints(server_node)
|
||||||
if scheduler_hints:
|
if scheduler_hints:
|
||||||
server['os:scheduler_hints'] = scheduler_hints
|
server['os:scheduler_hints'] = scheduler_hints
|
||||||
|
@ -3256,6 +3256,38 @@ class TestServerCreateRequestXMLDeserializer(test.TestCase):
|
|||||||
}}
|
}}
|
||||||
self.assertEquals(request['body'], expected)
|
self.assertEquals(request['body'], expected)
|
||||||
|
|
||||||
|
def test_request_with_availability_zone(self):
|
||||||
|
serial_request = """
|
||||||
|
<server xmlns="http://docs.openstack.org/compute/api/v2"
|
||||||
|
name="new-server-test" imageRef="1" flavorRef="1"
|
||||||
|
availability_zone="some_zone:some_host">
|
||||||
|
</server>"""
|
||||||
|
request = self.deserializer.deserialize(serial_request)
|
||||||
|
expected = {"server": {
|
||||||
|
"name": "new-server-test",
|
||||||
|
"imageRef": "1",
|
||||||
|
"flavorRef": "1",
|
||||||
|
"availability_zone": "some_zone:some_host",
|
||||||
|
}}
|
||||||
|
self.assertEquals(request['body'], expected)
|
||||||
|
|
||||||
|
def test_request_with_multiple_create_args(self):
|
||||||
|
serial_request = """
|
||||||
|
<server xmlns="http://docs.openstack.org/compute/api/v2"
|
||||||
|
name="new-server-test" imageRef="1" flavorRef="1"
|
||||||
|
min_count="1" max_count="3" return_reservation_id="True">
|
||||||
|
</server>"""
|
||||||
|
request = self.deserializer.deserialize(serial_request)
|
||||||
|
expected = {"server": {
|
||||||
|
"name": "new-server-test",
|
||||||
|
"imageRef": "1",
|
||||||
|
"flavorRef": "1",
|
||||||
|
"min_count": "1",
|
||||||
|
"max_count": "3",
|
||||||
|
"return_reservation_id": True,
|
||||||
|
}}
|
||||||
|
self.assertEquals(request['body'], expected)
|
||||||
|
|
||||||
|
|
||||||
class TestAddressesXMLSerialization(test.TestCase):
|
class TestAddressesXMLSerialization(test.TestCase):
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user