From 4054a8e2ac91eee6cbc0c63094016068bdbe62b8 Mon Sep 17 00:00:00 2001 From: Girish Shilamkar Date: Thu, 25 Jul 2013 01:52:26 -0400 Subject: [PATCH] CLOUDSTACK-3454: Fix test_portable_publicip Added isportable param to associateIP API. Fixed base class for PortableIP tio call portableip APIs. Removed test_createPortablePublicIPAcquire from basic zone run requires additional network creation handling which can be done in component tests. Signed-off-by: Prasanna Santhanam --- test/integration/smoke/test_portable_publicip.py | 8 +++++--- tools/marvin/marvin/integration/lib/base.py | 7 +++++-- 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/test/integration/smoke/test_portable_publicip.py b/test/integration/smoke/test_portable_publicip.py index 9a3a398c17a..73f745cfa4a 100644 --- a/test/integration/smoke/test_portable_publicip.py +++ b/test/integration/smoke/test_portable_publicip.py @@ -219,7 +219,7 @@ class TestPortablePublicIPAcquire(cloudstackTestCase): raise Exception("Warning: Exception during cleanup : %s" % e) return - @attr(tags = ["simulator", "basic", "advanced", "portablepublicip"]) + @attr(tags = ["simulator", "advanced", "portablepublicip"]) def test_createPortablePublicIPAcquire(self): """ Test to acquire a provisioned public ip range """ @@ -229,7 +229,9 @@ class TestPortablePublicIPAcquire(cloudstackTestCase): self.services ) - ip_address = PublicIPAddress.create(self.api_client, self.account.name, self.zone.id, self.account.domainid) + ip_address = PublicIPAddress.create(self.api_client, self.account.name, + self.zone.id, self.account.domainid, True) + ip_address.delete(self.api_client) self.portable_ip_range.delete(self.apiclient) - return \ No newline at end of file + return diff --git a/tools/marvin/marvin/integration/lib/base.py b/tools/marvin/marvin/integration/lib/base.py index 2f834be188c..b552aba068c 100755 --- a/tools/marvin/marvin/integration/lib/base.py +++ b/tools/marvin/marvin/integration/lib/base.py @@ -1074,7 +1074,7 @@ class PublicIPAddress: @classmethod def create(cls, apiclient, accountid=None, zoneid=None, domainid=None, - services=None, networkid=None, projectid=None, vpcid=None): + isportable=None, services=None, networkid=None, projectid=None, vpcid=None): """Associate Public IP address""" cmd = associateIpAddress.associateIpAddressCmd() @@ -1093,6 +1093,9 @@ class PublicIPAddress: elif "domainid" in services: cmd.domainid = services["domainid"] + if isportable: + cmd.isportable = isportable + if networkid: cmd.networkid = networkid @@ -2271,7 +2274,7 @@ class PortablePublicIpRange: cmd.regionid = services["regionid"] cmd.vlan = services["vlan"] - return PortablePublicIpRange(apiclient.createVlanIpRange(cmd).__dict__) + return PortablePublicIpRange(apiclient.createPortableIpRange(cmd).__dict__) def delete(self, apiclient): """Delete portable IpRange"""