Merge pull request #1230 from JackDanger/jack/implement-elbv2-resourceinuseerror
implement elbv2 ResourceInUseError
This commit is contained in:
		
						commit
						fd134034fa
					
				| @ -152,6 +152,13 @@ class InvalidDescribeRulesRequest(ELBClientError): | |||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | class ResourceInUseError(ELBClientError): | ||||||
|  | 
 | ||||||
|  |     def __init__(self, msg="A specified resource is in use"): | ||||||
|  |         super(ResourceInUseError, self).__init__( | ||||||
|  |             "ResourceInUse", msg) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| class RuleNotFoundError(ELBClientError): | class RuleNotFoundError(ELBClientError): | ||||||
| 
 | 
 | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|  | |||||||
| @ -21,6 +21,7 @@ from .exceptions import ( | |||||||
|     InvalidActionTypeError, |     InvalidActionTypeError, | ||||||
|     ActionTargetGroupNotFoundError, |     ActionTargetGroupNotFoundError, | ||||||
|     InvalidDescribeRulesRequest, |     InvalidDescribeRulesRequest, | ||||||
|  |     ResourceInUseError, | ||||||
|     RuleNotFoundError, |     RuleNotFoundError, | ||||||
|     DuplicatePriorityError, |     DuplicatePriorityError, | ||||||
|     InvalidTargetGroupNameError, |     InvalidTargetGroupNameError, | ||||||
| @ -426,11 +427,18 @@ class ELBv2Backend(BaseBackend): | |||||||
|         # however, boto3 does't raise error even if rule is not found |         # however, boto3 does't raise error even if rule is not found | ||||||
| 
 | 
 | ||||||
|     def delete_target_group(self, target_group_arn): |     def delete_target_group(self, target_group_arn): | ||||||
|         target_group = self.target_groups.pop(target_group_arn, None) |         if target_group_arn not in self.target_groups: | ||||||
|         if target_group: |  | ||||||
|             return target_group |  | ||||||
|             raise TargetGroupNotFoundError() |             raise TargetGroupNotFoundError() | ||||||
| 
 | 
 | ||||||
|  |         target_group = self.target_groups[target_group_arn] | ||||||
|  |         if target_group: | ||||||
|  |             if self._any_listener_using(target_group_arn): | ||||||
|  |                 raise ResourceInUseError( | ||||||
|  |                     "The target group '{}' is currently in use by a listener or a rule".format( | ||||||
|  |                         target_group_arn)) | ||||||
|  |             del self.target_groups[target_group_arn] | ||||||
|  |             return target_group | ||||||
|  | 
 | ||||||
|     def delete_listener(self, listener_arn): |     def delete_listener(self, listener_arn): | ||||||
|         for load_balancer in self.load_balancers.values(): |         for load_balancer in self.load_balancers.values(): | ||||||
|             listener = load_balancer.listeners.pop(listener_arn, None) |             listener = load_balancer.listeners.pop(listener_arn, None) | ||||||
| @ -539,6 +547,15 @@ class ELBv2Backend(BaseBackend): | |||||||
|             modified_rules.append(given_rule) |             modified_rules.append(given_rule) | ||||||
|         return modified_rules |         return modified_rules | ||||||
| 
 | 
 | ||||||
|  |     def _any_listener_using(self, target_group_arn): | ||||||
|  |         for load_balancer in self.load_balancers.values(): | ||||||
|  |             for listener in load_balancer.listeners.values(): | ||||||
|  |                 for rule in listener.rules: | ||||||
|  |                     for action in rule.actions: | ||||||
|  |                         if action.get('target_group_arn') == target_group_arn: | ||||||
|  |                             return True | ||||||
|  |         return False | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| elbv2_backends = {} | elbv2_backends = {} | ||||||
| for region in ec2_backends.keys(): | for region in ec2_backends.keys(): | ||||||
|  | |||||||
| @ -14,10 +14,17 @@ def test_create_load_balancer(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -29,7 +36,8 @@ def test_create_load_balancer(): | |||||||
|     lb = response.get('LoadBalancers')[0] |     lb = response.get('LoadBalancers')[0] | ||||||
| 
 | 
 | ||||||
|     lb.get('DNSName').should.equal("my-lb-1.us-east-1.elb.amazonaws.com") |     lb.get('DNSName').should.equal("my-lb-1.us-east-1.elb.amazonaws.com") | ||||||
|     lb.get('LoadBalancerArn').should.equal('arn:aws:elasticloadbalancing:us-east-1:1:loadbalancer/my-lb/50dc6c495c0c9188') |     lb.get('LoadBalancerArn').should.equal( | ||||||
|  |         'arn:aws:elasticloadbalancing:us-east-1:1:loadbalancer/my-lb/50dc6c495c0c9188') | ||||||
|     lb.get('SecurityGroups').should.equal([security_group.id]) |     lb.get('SecurityGroups').should.equal([security_group.id]) | ||||||
|     lb.get('AvailabilityZones').should.equal([ |     lb.get('AvailabilityZones').should.equal([ | ||||||
|         {'SubnetId': subnet1.id, 'ZoneName': 'us-east-1a'}, |         {'SubnetId': subnet1.id, 'ZoneName': 'us-east-1a'}, | ||||||
| @ -37,7 +45,8 @@ def test_create_load_balancer(): | |||||||
| 
 | 
 | ||||||
|     # Ensure the tags persisted |     # Ensure the tags persisted | ||||||
|     response = conn.describe_tags(ResourceArns=[lb.get('LoadBalancerArn')]) |     response = conn.describe_tags(ResourceArns=[lb.get('LoadBalancerArn')]) | ||||||
|     tags = {d['Key']: d['Value'] for d in response['TagDescriptions'][0]['Tags']} |     tags = {d['Key']: d['Value'] | ||||||
|  |             for d in response['TagDescriptions'][0]['Tags']} | ||||||
|     tags.should.equal({'key_name': 'a_value'}) |     tags.should.equal({'key_name': 'a_value'}) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -47,10 +56,17 @@ def test_describe_load_balancers(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     conn.create_load_balancer( |     conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -65,11 +81,14 @@ def test_describe_load_balancers(): | |||||||
|     lb = response.get('LoadBalancers')[0] |     lb = response.get('LoadBalancers')[0] | ||||||
|     lb.get('LoadBalancerName').should.equal('my-lb') |     lb.get('LoadBalancerName').should.equal('my-lb') | ||||||
| 
 | 
 | ||||||
|     response = conn.describe_load_balancers(LoadBalancerArns=[lb.get('LoadBalancerArn')]) |     response = conn.describe_load_balancers( | ||||||
|     response.get('LoadBalancers')[0].get('LoadBalancerName').should.equal('my-lb') |         LoadBalancerArns=[lb.get('LoadBalancerArn')]) | ||||||
|  |     response.get('LoadBalancers')[0].get( | ||||||
|  |         'LoadBalancerName').should.equal('my-lb') | ||||||
| 
 | 
 | ||||||
|     response = conn.describe_load_balancers(Names=['my-lb']) |     response = conn.describe_load_balancers(Names=['my-lb']) | ||||||
|     response.get('LoadBalancers')[0].get('LoadBalancerName').should.equal('my-lb') |     response.get('LoadBalancers')[0].get( | ||||||
|  |         'LoadBalancerName').should.equal('my-lb') | ||||||
| 
 | 
 | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         conn.describe_load_balancers(LoadBalancerArns=['not-a/real/arn']) |         conn.describe_load_balancers(LoadBalancerArns=['not-a/real/arn']) | ||||||
| @ -84,10 +103,17 @@ def test_add_remove_tags(): | |||||||
| 
 | 
 | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     conn.create_load_balancer( |     conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -197,10 +223,19 @@ def test_create_elb_in_multiple_region(): | |||||||
|         conn = boto3.client('elbv2', region_name=region) |         conn = boto3.client('elbv2', region_name=region) | ||||||
|         ec2 = boto3.resource('ec2', region_name=region) |         ec2 = boto3.resource('ec2', region_name=region) | ||||||
| 
 | 
 | ||||||
|         security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |         security_group = ec2.create_security_group( | ||||||
|         vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |             GroupName='a-security-group', Description='First One') | ||||||
|         subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone=region + 'a') |         vpc = ec2.create_vpc( | ||||||
|         subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone=region + 'b') |             CidrBlock='172.28.7.0/24', | ||||||
|  |             InstanceTenancy='default') | ||||||
|  |         subnet1 = ec2.create_subnet( | ||||||
|  |             VpcId=vpc.id, | ||||||
|  |             CidrBlock='172.28.7.192/26', | ||||||
|  |             AvailabilityZone=region + 'a') | ||||||
|  |         subnet2 = ec2.create_subnet( | ||||||
|  |             VpcId=vpc.id, | ||||||
|  |             CidrBlock='172.28.7.192/26', | ||||||
|  |             AvailabilityZone=region + 'b') | ||||||
| 
 | 
 | ||||||
|         conn.create_load_balancer( |         conn.create_load_balancer( | ||||||
|             Name='my-lb', |             Name='my-lb', | ||||||
| @ -210,10 +245,14 @@ def test_create_elb_in_multiple_region(): | |||||||
|             Tags=[{'Key': 'key_name', 'Value': 'a_value'}]) |             Tags=[{'Key': 'key_name', 'Value': 'a_value'}]) | ||||||
| 
 | 
 | ||||||
|     list( |     list( | ||||||
|         boto3.client('elbv2', region_name='us-west-1').describe_load_balancers().get('LoadBalancers') |         boto3.client( | ||||||
|  |             'elbv2', | ||||||
|  |             region_name='us-west-1').describe_load_balancers().get('LoadBalancers') | ||||||
|     ).should.have.length_of(1) |     ).should.have.length_of(1) | ||||||
|     list( |     list( | ||||||
|         boto3.client('elbv2', region_name='us-west-2').describe_load_balancers().get('LoadBalancers') |         boto3.client( | ||||||
|  |             'elbv2', | ||||||
|  |             region_name='us-west-2').describe_load_balancers().get('LoadBalancers') | ||||||
|     ).should.have.length_of(1) |     ).should.have.length_of(1) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -223,10 +262,17 @@ def test_create_target_group_and_listeners(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -254,7 +300,8 @@ def test_create_target_group_and_listeners(): | |||||||
|     target_group_arn = target_group['TargetGroupArn'] |     target_group_arn = target_group['TargetGroupArn'] | ||||||
| 
 | 
 | ||||||
|     # Add tags to the target group |     # Add tags to the target group | ||||||
|     conn.add_tags(ResourceArns=[target_group_arn], Tags=[{'Key': 'target', 'Value': 'group'}]) |     conn.add_tags(ResourceArns=[target_group_arn], Tags=[ | ||||||
|  |                   {'Key': 'target', 'Value': 'group'}]) | ||||||
|     conn.describe_tags(ResourceArns=[target_group_arn])['TagDescriptions'][0]['Tags'].should.equal( |     conn.describe_tags(ResourceArns=[target_group_arn])['TagDescriptions'][0]['Tags'].should.equal( | ||||||
|         [{'Key': 'target', 'Value': 'group'}]) |         [{'Key': 'target', 'Value': 'group'}]) | ||||||
| 
 | 
 | ||||||
| @ -281,7 +328,8 @@ def test_create_target_group_and_listeners(): | |||||||
|         LoadBalancerArn=load_balancer_arn, |         LoadBalancerArn=load_balancer_arn, | ||||||
|         Protocol='HTTPS', |         Protocol='HTTPS', | ||||||
|         Port=443, |         Port=443, | ||||||
|         Certificates=[{'CertificateArn': 'arn:aws:iam:123456789012:server-certificate/test-cert'}], |         Certificates=[ | ||||||
|  |             {'CertificateArn': 'arn:aws:iam:123456789012:server-certificate/test-cert'}], | ||||||
|         DefaultActions=[{'Type': 'forward', 'TargetGroupArn': target_group.get('TargetGroupArn')}]) |         DefaultActions=[{'Type': 'forward', 'TargetGroupArn': target_group.get('TargetGroupArn')}]) | ||||||
|     listener = response.get('Listeners')[0] |     listener = response.get('Listeners')[0] | ||||||
|     listener.get('Port').should.equal(443) |     listener.get('Port').should.equal(443) | ||||||
| @ -303,9 +351,20 @@ def test_create_target_group_and_listeners(): | |||||||
|     listener.get('Port').should.equal(443) |     listener.get('Port').should.equal(443) | ||||||
|     listener.get('Protocol').should.equal('HTTPS') |     listener.get('Protocol').should.equal('HTTPS') | ||||||
| 
 | 
 | ||||||
|     response = conn.describe_listeners(ListenerArns=[http_listener_arn, https_listener_arn]) |     response = conn.describe_listeners( | ||||||
|  |         ListenerArns=[ | ||||||
|  |             http_listener_arn, | ||||||
|  |             https_listener_arn]) | ||||||
|     response.get('Listeners').should.have.length_of(2) |     response.get('Listeners').should.have.length_of(2) | ||||||
| 
 | 
 | ||||||
|  |     # Try to delete the target group and it fails because there's a | ||||||
|  |     # listener referencing it | ||||||
|  |     with assert_raises(ClientError) as e: | ||||||
|  |         conn.delete_target_group( | ||||||
|  |             TargetGroupArn=target_group.get('TargetGroupArn')) | ||||||
|  |     e.exception.operation_name.should.equal('DeleteTargetGroup') | ||||||
|  |     e.exception.args.should.equal(("An error occurred (ResourceInUse) when calling the DeleteTargetGroup operation: The target group 'arn:aws:elasticloadbalancing:us-east-1:1:targetgroup/a-target/50dc6c495c0c9188' is currently in use by a listener or a rule", ))  # NOQA | ||||||
|  | 
 | ||||||
|     # Delete one listener |     # Delete one listener | ||||||
|     response = conn.describe_listeners(LoadBalancerArn=load_balancer_arn) |     response = conn.describe_listeners(LoadBalancerArn=load_balancer_arn) | ||||||
|     response.get('Listeners').should.have.length_of(2) |     response.get('Listeners').should.have.length_of(2) | ||||||
| @ -321,7 +380,10 @@ def test_create_target_group_and_listeners(): | |||||||
|     response.get('LoadBalancers').should.have.length_of(0) |     response.get('LoadBalancers').should.have.length_of(0) | ||||||
| 
 | 
 | ||||||
|     # And it deleted the remaining listener |     # And it deleted the remaining listener | ||||||
|     response = conn.describe_listeners(ListenerArns=[http_listener_arn, https_listener_arn]) |     response = conn.describe_listeners( | ||||||
|  |         ListenerArns=[ | ||||||
|  |             http_listener_arn, | ||||||
|  |             https_listener_arn]) | ||||||
|     response.get('Listeners').should.have.length_of(0) |     response.get('Listeners').should.have.length_of(0) | ||||||
| 
 | 
 | ||||||
|     # But not the target groups |     # But not the target groups | ||||||
| @ -359,7 +421,13 @@ def test_create_invalid_target_group(): | |||||||
|             UnhealthyThresholdCount=2, |             UnhealthyThresholdCount=2, | ||||||
|             Matcher={'HttpCode': '200'}) |             Matcher={'HttpCode': '200'}) | ||||||
| 
 | 
 | ||||||
|     invalid_names = ['-name', 'name-', '-name-', 'example.com', 'test@test', 'Na--me'] |     invalid_names = [ | ||||||
|  |         '-name', | ||||||
|  |         'name-', | ||||||
|  |         '-name-', | ||||||
|  |         'example.com', | ||||||
|  |         'test@test', | ||||||
|  |         'Na--me'] | ||||||
|     for name in invalid_names: |     for name in invalid_names: | ||||||
|         with assert_raises(ClientError): |         with assert_raises(ClientError): | ||||||
|             conn.create_target_group( |             conn.create_target_group( | ||||||
| @ -399,10 +467,17 @@ def test_describe_paginated_balancers(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     for i in range(51): |     for i in range(51): | ||||||
|         conn.create_load_balancer( |         conn.create_load_balancer( | ||||||
| @ -414,7 +489,8 @@ def test_describe_paginated_balancers(): | |||||||
| 
 | 
 | ||||||
|     resp = conn.describe_load_balancers() |     resp = conn.describe_load_balancers() | ||||||
|     resp['LoadBalancers'].should.have.length_of(50) |     resp['LoadBalancers'].should.have.length_of(50) | ||||||
|     resp['NextMarker'].should.equal(resp['LoadBalancers'][-1]['LoadBalancerName']) |     resp['NextMarker'].should.equal( | ||||||
|  |         resp['LoadBalancers'][-1]['LoadBalancerName']) | ||||||
|     resp2 = conn.describe_load_balancers(Marker=resp['NextMarker']) |     resp2 = conn.describe_load_balancers(Marker=resp['NextMarker']) | ||||||
|     resp2['LoadBalancers'].should.have.length_of(1) |     resp2['LoadBalancers'].should.have.length_of(1) | ||||||
|     assert 'NextToken' not in resp2.keys() |     assert 'NextToken' not in resp2.keys() | ||||||
| @ -426,10 +502,17 @@ def test_delete_load_balancer(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -452,10 +535,17 @@ def test_register_targets(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     conn.create_load_balancer( |     conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -480,7 +570,8 @@ def test_register_targets(): | |||||||
|     target_group = response.get('TargetGroups')[0] |     target_group = response.get('TargetGroups')[0] | ||||||
| 
 | 
 | ||||||
|     # No targets registered yet |     # No targets registered yet | ||||||
|     response = conn.describe_target_health(TargetGroupArn=target_group.get('TargetGroupArn')) |     response = conn.describe_target_health( | ||||||
|  |         TargetGroupArn=target_group.get('TargetGroupArn')) | ||||||
|     response.get('TargetHealthDescriptions').should.have.length_of(0) |     response.get('TargetHealthDescriptions').should.have.length_of(0) | ||||||
| 
 | 
 | ||||||
|     response = ec2.create_instances( |     response = ec2.create_instances( | ||||||
| @ -501,14 +592,16 @@ def test_register_targets(): | |||||||
|             }, |             }, | ||||||
|         ]) |         ]) | ||||||
| 
 | 
 | ||||||
|     response = conn.describe_target_health(TargetGroupArn=target_group.get('TargetGroupArn')) |     response = conn.describe_target_health( | ||||||
|  |         TargetGroupArn=target_group.get('TargetGroupArn')) | ||||||
|     response.get('TargetHealthDescriptions').should.have.length_of(2) |     response.get('TargetHealthDescriptions').should.have.length_of(2) | ||||||
| 
 | 
 | ||||||
|     response = conn.deregister_targets( |     response = conn.deregister_targets( | ||||||
|         TargetGroupArn=target_group.get('TargetGroupArn'), |         TargetGroupArn=target_group.get('TargetGroupArn'), | ||||||
|         Targets=[{'Id': instance_id2}]) |         Targets=[{'Id': instance_id2}]) | ||||||
| 
 | 
 | ||||||
|     response = conn.describe_target_health(TargetGroupArn=target_group.get('TargetGroupArn')) |     response = conn.describe_target_health( | ||||||
|  |         TargetGroupArn=target_group.get('TargetGroupArn')) | ||||||
|     response.get('TargetHealthDescriptions').should.have.length_of(1) |     response.get('TargetHealthDescriptions').should.have.length_of(1) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -518,10 +611,17 @@ def test_target_group_attributes(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -557,9 +657,11 @@ def test_target_group_attributes(): | |||||||
|     target_group_arn = target_group['TargetGroupArn'] |     target_group_arn = target_group['TargetGroupArn'] | ||||||
| 
 | 
 | ||||||
|     # The attributes should start with the two defaults |     # The attributes should start with the two defaults | ||||||
|     response = conn.describe_target_group_attributes(TargetGroupArn=target_group_arn) |     response = conn.describe_target_group_attributes( | ||||||
|  |         TargetGroupArn=target_group_arn) | ||||||
|     response['Attributes'].should.have.length_of(2) |     response['Attributes'].should.have.length_of(2) | ||||||
|     attributes = {attr['Key']: attr['Value'] for attr in response['Attributes']} |     attributes = {attr['Key']: attr['Value'] | ||||||
|  |                   for attr in response['Attributes']} | ||||||
|     attributes['deregistration_delay.timeout_seconds'].should.equal('300') |     attributes['deregistration_delay.timeout_seconds'].should.equal('300') | ||||||
|     attributes['stickiness.enabled'].should.equal('false') |     attributes['stickiness.enabled'].should.equal('false') | ||||||
| 
 | 
 | ||||||
| @ -579,14 +681,17 @@ def test_target_group_attributes(): | |||||||
| 
 | 
 | ||||||
|     # The response should have only the keys updated |     # The response should have only the keys updated | ||||||
|     response['Attributes'].should.have.length_of(2) |     response['Attributes'].should.have.length_of(2) | ||||||
|     attributes = {attr['Key']: attr['Value'] for attr in response['Attributes']} |     attributes = {attr['Key']: attr['Value'] | ||||||
|  |                   for attr in response['Attributes']} | ||||||
|     attributes['stickiness.type'].should.equal('lb_cookie') |     attributes['stickiness.type'].should.equal('lb_cookie') | ||||||
|     attributes['stickiness.enabled'].should.equal('true') |     attributes['stickiness.enabled'].should.equal('true') | ||||||
| 
 | 
 | ||||||
|     # These new values should be in the full attribute list |     # These new values should be in the full attribute list | ||||||
|     response = conn.describe_target_group_attributes(TargetGroupArn=target_group_arn) |     response = conn.describe_target_group_attributes( | ||||||
|  |         TargetGroupArn=target_group_arn) | ||||||
|     response['Attributes'].should.have.length_of(3) |     response['Attributes'].should.have.length_of(3) | ||||||
|     attributes = {attr['Key']: attr['Value'] for attr in response['Attributes']} |     attributes = {attr['Key']: attr['Value'] | ||||||
|  |                   for attr in response['Attributes']} | ||||||
|     attributes['stickiness.type'].should.equal('lb_cookie') |     attributes['stickiness.type'].should.equal('lb_cookie') | ||||||
|     attributes['stickiness.enabled'].should.equal('true') |     attributes['stickiness.enabled'].should.equal('true') | ||||||
| 
 | 
 | ||||||
| @ -597,10 +702,17 @@ def test_handle_listener_rules(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -684,9 +796,8 @@ def test_handle_listener_rules(): | |||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     # test for PriorityInUse |     # test for PriorityInUse | ||||||
|     host2 = 'yyy.example.com' |  | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=priority, |             Priority=priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -703,7 +814,6 @@ def test_handle_listener_rules(): | |||||||
|             }] |             }] | ||||||
|         ) |         ) | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     # test for describe listeners |     # test for describe listeners | ||||||
|     obtained_rules = conn.describe_rules(ListenerArn=http_listener_arn) |     obtained_rules = conn.describe_rules(ListenerArn=http_listener_arn) | ||||||
|     len(obtained_rules['Rules']).should.equal(3) |     len(obtained_rules['Rules']).should.equal(3) | ||||||
| @ -716,15 +826,20 @@ def test_handle_listener_rules(): | |||||||
|     obtained_rules['Rules'].should.equal([first_rule]) |     obtained_rules['Rules'].should.equal([first_rule]) | ||||||
| 
 | 
 | ||||||
|     # test for pagination |     # test for pagination | ||||||
|     obtained_rules = conn.describe_rules(ListenerArn=http_listener_arn, PageSize=1) |     obtained_rules = conn.describe_rules( | ||||||
|  |         ListenerArn=http_listener_arn, PageSize=1) | ||||||
|     len(obtained_rules['Rules']).should.equal(1) |     len(obtained_rules['Rules']).should.equal(1) | ||||||
|     obtained_rules.should.have.key('NextMarker') |     obtained_rules.should.have.key('NextMarker') | ||||||
|     next_marker = obtained_rules['NextMarker'] |     next_marker = obtained_rules['NextMarker'] | ||||||
| 
 | 
 | ||||||
|     following_rules = conn.describe_rules(ListenerArn=http_listener_arn, PageSize=1, Marker=next_marker) |     following_rules = conn.describe_rules( | ||||||
|  |         ListenerArn=http_listener_arn, | ||||||
|  |         PageSize=1, | ||||||
|  |         Marker=next_marker) | ||||||
|     len(following_rules['Rules']).should.equal(1) |     len(following_rules['Rules']).should.equal(1) | ||||||
|     following_rules.should.have.key('NextMarker') |     following_rules.should.have.key('NextMarker') | ||||||
|     following_rules['Rules'][0]['RuleArn'].should_not.equal(obtained_rules['Rules'][0]['RuleArn']) |     following_rules['Rules'][0]['RuleArn'].should_not.equal( | ||||||
|  |         obtained_rules['Rules'][0]['RuleArn']) | ||||||
| 
 | 
 | ||||||
|     # test for invalid describe rule request |     # test for invalid describe rule request | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
| @ -757,12 +872,14 @@ def test_handle_listener_rules(): | |||||||
|     modified_rule.should.equal(obtained_rule) |     modified_rule.should.equal(obtained_rule) | ||||||
|     obtained_rule['Conditions'][0]['Values'][0].should.equal(new_host) |     obtained_rule['Conditions'][0]['Values'][0].should.equal(new_host) | ||||||
|     obtained_rule['Conditions'][1]['Values'][0].should.equal(new_path_pattern) |     obtained_rule['Conditions'][1]['Values'][0].should.equal(new_path_pattern) | ||||||
|     obtained_rule['Actions'][0]['TargetGroupArn'].should.equal(target_group.get('TargetGroupArn')) |     obtained_rule['Actions'][0]['TargetGroupArn'].should.equal( | ||||||
|  |         target_group.get('TargetGroupArn')) | ||||||
| 
 | 
 | ||||||
|     # modify priority |     # modify priority | ||||||
|     conn.set_rule_priorities( |     conn.set_rule_priorities( | ||||||
|         RulePriorities=[ |         RulePriorities=[ | ||||||
|             {'RuleArn': first_rule['RuleArn'], 'Priority': int(first_rule['Priority']) - 1} |             {'RuleArn': first_rule['RuleArn'], | ||||||
|  |              'Priority': int(first_rule['Priority']) - 1} | ||||||
|         ] |         ] | ||||||
|     ) |     ) | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
| @ -782,7 +899,7 @@ def test_handle_listener_rules(): | |||||||
|     # test for invalid action type |     # test for invalid action type | ||||||
|     safe_priority = 2 |     safe_priority = 2 | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=safe_priority, |             Priority=safe_priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -803,7 +920,7 @@ def test_handle_listener_rules(): | |||||||
|     safe_priority = 2 |     safe_priority = 2 | ||||||
|     invalid_target_group_arn = target_group.get('TargetGroupArn') + 'x' |     invalid_target_group_arn = target_group.get('TargetGroupArn') + 'x' | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=safe_priority, |             Priority=safe_priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -823,7 +940,7 @@ def test_handle_listener_rules(): | |||||||
|     # test for invalid condition field_name |     # test for invalid condition field_name | ||||||
|     safe_priority = 2 |     safe_priority = 2 | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=safe_priority, |             Priority=safe_priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -839,7 +956,7 @@ def test_handle_listener_rules(): | |||||||
|     # test for emptry condition value |     # test for emptry condition value | ||||||
|     safe_priority = 2 |     safe_priority = 2 | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=safe_priority, |             Priority=safe_priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -855,7 +972,7 @@ def test_handle_listener_rules(): | |||||||
|     # test for multiple condition value |     # test for multiple condition value | ||||||
|     safe_priority = 2 |     safe_priority = 2 | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|         r = conn.create_rule( |         conn.create_rule( | ||||||
|             ListenerArn=http_listener_arn, |             ListenerArn=http_listener_arn, | ||||||
|             Priority=safe_priority, |             Priority=safe_priority, | ||||||
|             Conditions=[{ |             Conditions=[{ | ||||||
| @ -875,10 +992,17 @@ def test_describe_invalid_target_group(): | |||||||
|     conn = boto3.client('elbv2', region_name='us-east-1') |     conn = boto3.client('elbv2', region_name='us-east-1') | ||||||
|     ec2 = boto3.resource('ec2', region_name='us-east-1') |     ec2 = boto3.resource('ec2', region_name='us-east-1') | ||||||
| 
 | 
 | ||||||
|     security_group = ec2.create_security_group(GroupName='a-security-group', Description='First One') |     security_group = ec2.create_security_group( | ||||||
|  |         GroupName='a-security-group', Description='First One') | ||||||
|     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') |     vpc = ec2.create_vpc(CidrBlock='172.28.7.0/24', InstanceTenancy='default') | ||||||
|     subnet1 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1a') |     subnet1 = ec2.create_subnet( | ||||||
|     subnet2 = ec2.create_subnet(VpcId=vpc.id, CidrBlock='172.28.7.192/26', AvailabilityZone='us-east-1b') |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1a') | ||||||
|  |     subnet2 = ec2.create_subnet( | ||||||
|  |         VpcId=vpc.id, | ||||||
|  |         CidrBlock='172.28.7.192/26', | ||||||
|  |         AvailabilityZone='us-east-1b') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_load_balancer( |     response = conn.create_load_balancer( | ||||||
|         Name='my-lb', |         Name='my-lb', | ||||||
| @ -887,7 +1011,7 @@ def test_describe_invalid_target_group(): | |||||||
|         Scheme='internal', |         Scheme='internal', | ||||||
|         Tags=[{'Key': 'key_name', 'Value': 'a_value'}]) |         Tags=[{'Key': 'key_name', 'Value': 'a_value'}]) | ||||||
| 
 | 
 | ||||||
|     load_balancer_arn = response.get('LoadBalancers')[0].get('LoadBalancerArn') |     response.get('LoadBalancers')[0].get('LoadBalancerArn') | ||||||
| 
 | 
 | ||||||
|     response = conn.create_target_group( |     response = conn.create_target_group( | ||||||
|         Name='a-target', |         Name='a-target', | ||||||
| @ -902,7 +1026,6 @@ def test_describe_invalid_target_group(): | |||||||
|         HealthyThresholdCount=5, |         HealthyThresholdCount=5, | ||||||
|         UnhealthyThresholdCount=2, |         UnhealthyThresholdCount=2, | ||||||
|         Matcher={'HttpCode': '200'}) |         Matcher={'HttpCode': '200'}) | ||||||
|     target_group = response.get('TargetGroups')[0] |  | ||||||
| 
 | 
 | ||||||
|     # Check error raises correctly |     # Check error raises correctly | ||||||
|     with assert_raises(ClientError): |     with assert_raises(ClientError): | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user