adding Address reallocate capability for EIP
This commit is contained in:
parent
cb364eedc6
commit
12188733b7
@ -3159,7 +3159,10 @@ class SpotFleetBackend(object):
|
|||||||
|
|
||||||
|
|
||||||
class ElasticAddress(object):
|
class ElasticAddress(object):
|
||||||
def __init__(self, domain):
|
def __init__(self, domain, address=None):
|
||||||
|
if address:
|
||||||
|
self.public_ip = address
|
||||||
|
else:
|
||||||
self.public_ip = random_ip()
|
self.public_ip = random_ip()
|
||||||
self.allocation_id = random_eip_allocation_id() if domain == "vpc" else None
|
self.allocation_id = random_eip_allocation_id() if domain == "vpc" else None
|
||||||
self.domain = domain
|
self.domain = domain
|
||||||
@ -3222,10 +3225,12 @@ class ElasticAddressBackend(object):
|
|||||||
self.addresses = []
|
self.addresses = []
|
||||||
super(ElasticAddressBackend, self).__init__()
|
super(ElasticAddressBackend, self).__init__()
|
||||||
|
|
||||||
def allocate_address(self, domain):
|
def allocate_address(self, domain, address=None):
|
||||||
if domain not in ['standard', 'vpc']:
|
if domain not in ['standard', 'vpc']:
|
||||||
raise InvalidDomainError(domain)
|
raise InvalidDomainError(domain)
|
||||||
|
if address:
|
||||||
|
address = ElasticAddress(domain, address)
|
||||||
|
else:
|
||||||
address = ElasticAddress(domain)
|
address = ElasticAddress(domain)
|
||||||
self.addresses.append(address)
|
self.addresses.append(address)
|
||||||
return address
|
return address
|
||||||
|
@ -7,7 +7,12 @@ class ElasticIPAddresses(BaseResponse):
|
|||||||
|
|
||||||
def allocate_address(self):
|
def allocate_address(self):
|
||||||
domain = self._get_param('Domain', if_none='standard')
|
domain = self._get_param('Domain', if_none='standard')
|
||||||
|
reallocate_address = self._get_param('Address', if_none=None)
|
||||||
if self.is_not_dryrun('AllocateAddress'):
|
if self.is_not_dryrun('AllocateAddress'):
|
||||||
|
if reallocate_address:
|
||||||
|
address = self.ec2_backend.allocate_address(
|
||||||
|
domain, address=reallocate_address)
|
||||||
|
else:
|
||||||
address = self.ec2_backend.allocate_address(domain)
|
address = self.ec2_backend.allocate_address(domain)
|
||||||
template = self.response_template(ALLOCATE_ADDRESS_RESPONSE)
|
template = self.response_template(ALLOCATE_ADDRESS_RESPONSE)
|
||||||
return template.render(address=address)
|
return template.render(address=address)
|
||||||
|
@ -62,6 +62,17 @@ def test_eip_allocate_vpc():
|
|||||||
logging.debug("vpc alloc_id:".format(vpc.allocation_id))
|
logging.debug("vpc alloc_id:".format(vpc.allocation_id))
|
||||||
vpc.release()
|
vpc.release()
|
||||||
|
|
||||||
|
@mock_ec2
|
||||||
|
def test_specific_eip_allocate_vpc():
|
||||||
|
"""Allocate VPC EIP with specific address"""
|
||||||
|
service = boto3.resource('ec2', region_name='us-west-1')
|
||||||
|
client = boto3.client('ec2', region_name='us-west-1')
|
||||||
|
|
||||||
|
vpc = client.allocate_address(Domain="vpc", Address="127.38.43.222")
|
||||||
|
vpc['Domain'].should.be.equal("vpc")
|
||||||
|
vpc['PublicIp'].should.be.equal("127.38.43.222")
|
||||||
|
logging.debug("vpc alloc_id:".format(vpc['AllocationId']))
|
||||||
|
|
||||||
|
|
||||||
@mock_ec2_deprecated
|
@mock_ec2_deprecated
|
||||||
def test_eip_allocate_invalid_domain():
|
def test_eip_allocate_invalid_domain():
|
||||||
|
Loading…
Reference in New Issue
Block a user