2017-07-20 22:00:30 +00:00
from __future__ import unicode_literals
2017-10-29 16:06:03 +00:00
import os
2017-07-20 22:00:30 +00:00
import boto3
import botocore
from botocore . exceptions import ClientError
from nose . tools import assert_raises
import sure # noqa
2017-10-29 14:14:17 +00:00
from moto import mock_elbv2 , mock_ec2 , mock_acm
from moto . elbv2 import elbv2_backends
2017-07-20 22:00:30 +00:00
@mock_elbv2
@mock_ec2
def test_create_load_balancer ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
lb = response . get ( ' LoadBalancers ' ) [ 0 ]
lb . get ( ' DNSName ' ) . should . equal ( " my-lb-1.us-east-1.elb.amazonaws.com " )
2017-10-02 19:36:47 +00:00
lb . get ( ' LoadBalancerArn ' ) . should . equal (
' arn:aws:elasticloadbalancing:us-east-1:1:loadbalancer/my-lb/50dc6c495c0c9188 ' )
2017-07-20 22:00:30 +00:00
lb . get ( ' SecurityGroups ' ) . should . equal ( [ security_group . id ] )
lb . get ( ' AvailabilityZones ' ) . should . equal ( [
{ ' SubnetId ' : subnet1 . id , ' ZoneName ' : ' us-east-1a ' } ,
{ ' SubnetId ' : subnet2 . id , ' ZoneName ' : ' us-east-1b ' } ] )
# Ensure the tags persisted
response = conn . describe_tags ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] )
2017-10-02 19:36:47 +00:00
tags = { d [ ' Key ' ] : d [ ' Value ' ]
for d in response [ ' TagDescriptions ' ] [ 0 ] [ ' Tags ' ] }
2017-07-20 22:00:30 +00:00
tags . should . equal ( { ' key_name ' : ' a_value ' } )
@mock_elbv2
@mock_ec2
def test_describe_load_balancers ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
response = conn . describe_load_balancers ( )
response . get ( ' LoadBalancers ' ) . should . have . length_of ( 1 )
lb = response . get ( ' LoadBalancers ' ) [ 0 ]
lb . get ( ' LoadBalancerName ' ) . should . equal ( ' my-lb ' )
2017-10-02 19:36:47 +00:00
response = conn . describe_load_balancers (
LoadBalancerArns = [ lb . get ( ' LoadBalancerArn ' ) ] )
response . get ( ' LoadBalancers ' ) [ 0 ] . get (
' LoadBalancerName ' ) . should . equal ( ' my-lb ' )
2017-07-20 22:00:30 +00:00
response = conn . describe_load_balancers ( Names = [ ' my-lb ' ] )
2017-10-02 19:36:47 +00:00
response . get ( ' LoadBalancers ' ) [ 0 ] . get (
' LoadBalancerName ' ) . should . equal ( ' my-lb ' )
2017-07-20 22:00:30 +00:00
with assert_raises ( ClientError ) :
conn . describe_load_balancers ( LoadBalancerArns = [ ' not-a/real/arn ' ] )
with assert_raises ( ClientError ) :
conn . describe_load_balancers ( Names = [ ' nope ' ] )
@mock_elbv2
@mock_ec2
def test_add_remove_tags ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
lbs = conn . describe_load_balancers ( ) [ ' LoadBalancers ' ]
lbs . should . have . length_of ( 1 )
lb = lbs [ 0 ]
with assert_raises ( ClientError ) :
conn . add_tags ( ResourceArns = [ ' missing-arn ' ] ,
Tags = [ {
' Key ' : ' a ' ,
' Value ' : ' b '
} ] )
conn . add_tags ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ,
Tags = [ {
' Key ' : ' a ' ,
' Value ' : ' b '
} ] )
tags = { d [ ' Key ' ] : d [ ' Value ' ] for d in conn . describe_tags (
ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ) [ ' TagDescriptions ' ] [ 0 ] [ ' Tags ' ] }
tags . should . have . key ( ' a ' ) . which . should . equal ( ' b ' )
conn . add_tags ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ,
Tags = [ {
' Key ' : ' a ' ,
' Value ' : ' b '
} , {
' Key ' : ' b ' ,
' Value ' : ' b '
} , {
' Key ' : ' c ' ,
' Value ' : ' b '
} , {
' Key ' : ' d ' ,
' Value ' : ' b '
} , {
' Key ' : ' e ' ,
' Value ' : ' b '
} , {
' Key ' : ' f ' ,
' Value ' : ' b '
} , {
' Key ' : ' g ' ,
' Value ' : ' b '
} , {
' Key ' : ' h ' ,
' Value ' : ' b '
} , {
' Key ' : ' j ' ,
' Value ' : ' b '
} ] )
conn . add_tags . when . called_with ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ,
Tags = [ {
' Key ' : ' k ' ,
' Value ' : ' b '
} ] ) . should . throw ( botocore . exceptions . ClientError )
conn . add_tags ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ,
Tags = [ {
' Key ' : ' j ' ,
' Value ' : ' c '
} ] )
tags = { d [ ' Key ' ] : d [ ' Value ' ] for d in conn . describe_tags (
ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ) [ ' TagDescriptions ' ] [ 0 ] [ ' Tags ' ] }
tags . should . have . key ( ' a ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' b ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' c ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' d ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' e ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' f ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' g ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' h ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' j ' ) . which . should . equal ( ' c ' )
tags . shouldnt . have . key ( ' k ' )
conn . remove_tags ( ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ,
TagKeys = [ ' a ' ] )
tags = { d [ ' Key ' ] : d [ ' Value ' ] for d in conn . describe_tags (
ResourceArns = [ lb . get ( ' LoadBalancerArn ' ) ] ) [ ' TagDescriptions ' ] [ 0 ] [ ' Tags ' ] }
tags . shouldnt . have . key ( ' a ' )
tags . should . have . key ( ' b ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' c ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' d ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' e ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' f ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' g ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' h ' ) . which . should . equal ( ' b ' )
tags . should . have . key ( ' j ' ) . which . should . equal ( ' c ' )
@mock_elbv2
@mock_ec2
def test_create_elb_in_multiple_region ( ) :
for region in [ ' us-west-1 ' , ' us-west-2 ' ] :
conn = boto3 . client ( ' elbv2 ' , region_name = region )
ec2 = boto3 . resource ( ' ec2 ' , region_name = region )
2017-10-02 19:36:47 +00:00
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 ' )
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 ' )
2017-07-20 22:00:30 +00:00
conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
list (
2017-10-02 19:36:47 +00:00
boto3 . client (
' elbv2 ' ,
region_name = ' us-west-1 ' ) . describe_load_balancers ( ) . get ( ' LoadBalancers ' )
2017-07-20 22:00:30 +00:00
) . should . have . length_of ( 1 )
list (
2017-10-02 19:36:47 +00:00
boto3 . client (
' elbv2 ' ,
region_name = ' us-west-2 ' ) . describe_load_balancers ( ) . get ( ' LoadBalancers ' )
2017-07-20 22:00:30 +00:00
) . should . have . length_of ( 1 )
@mock_elbv2
@mock_ec2
def test_create_target_group_and_listeners ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
load_balancer_arn = response . get ( ' LoadBalancers ' ) [ 0 ] . get ( ' LoadBalancerArn ' )
2017-10-27 01:16:06 +00:00
# Can't create a target group with an invalid protocol
with assert_raises ( ClientError ) :
conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' /HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
2017-07-20 22:00:30 +00:00
response = conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
target_group = response . get ( ' TargetGroups ' ) [ 0 ]
2017-09-17 02:53:09 +00:00
target_group_arn = target_group [ ' TargetGroupArn ' ]
# Add tags to the target group
2017-10-02 19:36:47 +00:00
conn . add_tags ( ResourceArns = [ target_group_arn ] , Tags = [
{ ' Key ' : ' target ' , ' Value ' : ' group ' } ] )
2017-09-17 02:53:09 +00:00
conn . describe_tags ( ResourceArns = [ target_group_arn ] ) [ ' TagDescriptions ' ] [ 0 ] [ ' Tags ' ] . should . equal (
[ { ' Key ' : ' target ' , ' Value ' : ' group ' } ] )
2017-07-20 22:00:30 +00:00
# Check it's in the describe_target_groups response
response = conn . describe_target_groups ( )
response . get ( ' TargetGroups ' ) . should . have . length_of ( 1 )
# Plain HTTP listener
response = conn . create_listener (
LoadBalancerArn = load_balancer_arn ,
Protocol = ' HTTP ' ,
Port = 80 ,
DefaultActions = [ { ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) } ] )
listener = response . get ( ' Listeners ' ) [ 0 ]
listener . get ( ' Port ' ) . should . equal ( 80 )
listener . get ( ' Protocol ' ) . should . equal ( ' HTTP ' )
listener . get ( ' DefaultActions ' ) . should . equal ( [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward ' } ] )
http_listener_arn = listener . get ( ' ListenerArn ' )
# And another with SSL
response = conn . create_listener (
LoadBalancerArn = load_balancer_arn ,
Protocol = ' HTTPS ' ,
Port = 443 ,
2017-10-02 19:36:47 +00:00
Certificates = [
{ ' CertificateArn ' : ' arn:aws:iam:123456789012:server-certificate/test-cert ' } ] ,
2017-07-20 22:00:30 +00:00
DefaultActions = [ { ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) } ] )
listener = response . get ( ' Listeners ' ) [ 0 ]
listener . get ( ' Port ' ) . should . equal ( 443 )
listener . get ( ' Protocol ' ) . should . equal ( ' HTTPS ' )
listener . get ( ' Certificates ' ) . should . equal ( [ {
' CertificateArn ' : ' arn:aws:iam:123456789012:server-certificate/test-cert ' ,
} ] )
listener . get ( ' DefaultActions ' ) . should . equal ( [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward ' } ] )
https_listener_arn = listener . get ( ' ListenerArn ' )
response = conn . describe_listeners ( LoadBalancerArn = load_balancer_arn )
response . get ( ' Listeners ' ) . should . have . length_of ( 2 )
response = conn . describe_listeners ( ListenerArns = [ https_listener_arn ] )
response . get ( ' Listeners ' ) . should . have . length_of ( 1 )
listener = response . get ( ' Listeners ' ) [ 0 ]
listener . get ( ' Port ' ) . should . equal ( 443 )
listener . get ( ' Protocol ' ) . should . equal ( ' HTTPS ' )
2017-10-02 19:36:47 +00:00
response = conn . describe_listeners (
ListenerArns = [
http_listener_arn ,
https_listener_arn ] )
2017-07-20 22:00:30 +00:00
response . get ( ' Listeners ' ) . should . have . length_of ( 2 )
2017-10-02 19:35:52 +00:00
# Try to delete the target group and it fails because there's a
# listener referencing it
with assert_raises ( ClientError ) as e :
2017-10-02 19:36:47 +00:00
conn . delete_target_group (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) )
2017-10-02 19:35:52 +00:00
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
2017-07-20 22:00:30 +00:00
# Delete one listener
response = conn . describe_listeners ( LoadBalancerArn = load_balancer_arn )
response . get ( ' Listeners ' ) . should . have . length_of ( 2 )
conn . delete_listener ( ListenerArn = http_listener_arn )
response = conn . describe_listeners ( LoadBalancerArn = load_balancer_arn )
response . get ( ' Listeners ' ) . should . have . length_of ( 1 )
# Then delete the load balancer
conn . delete_load_balancer ( LoadBalancerArn = load_balancer_arn )
# It's gone
response = conn . describe_load_balancers ( )
response . get ( ' LoadBalancers ' ) . should . have . length_of ( 0 )
# And it deleted the remaining listener
2017-10-02 19:36:47 +00:00
response = conn . describe_listeners (
ListenerArns = [
http_listener_arn ,
https_listener_arn ] )
2017-07-20 22:00:30 +00:00
response . get ( ' Listeners ' ) . should . have . length_of ( 0 )
# But not the target groups
response = conn . describe_target_groups ( )
response . get ( ' TargetGroups ' ) . should . have . length_of ( 1 )
# Which we'll now delete
conn . delete_target_group ( TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) )
response = conn . describe_target_groups ( )
response . get ( ' TargetGroups ' ) . should . have . length_of ( 0 )
2017-08-18 15:16:11 +00:00
@mock_elbv2
@mock_ec2
def test_create_invalid_target_group ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-08-18 14:54:28 +00:00
# Fail to create target group with name which length is 33
long_name = ' A ' * 33
with assert_raises ( ClientError ) :
conn . create_target_group (
Name = long_name ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
2017-10-02 19:36:47 +00:00
invalid_names = [
' -name ' ,
' name- ' ,
' -name- ' ,
' example.com ' ,
' test@test ' ,
' Na--me ' ]
2017-08-18 15:16:11 +00:00
for name in invalid_names :
with assert_raises ( ClientError ) :
conn . create_target_group (
Name = name ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
valid_names = [ ' name ' , ' Name ' , ' 000 ' ]
for name in valid_names :
conn . create_target_group (
Name = name ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
2017-07-20 22:00:30 +00:00
@mock_elbv2
@mock_ec2
def test_describe_paginated_balancers ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
for i in range ( 51 ) :
conn . create_load_balancer (
Name = ' my-lb %d ' % i ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
resp = conn . describe_load_balancers ( )
resp [ ' LoadBalancers ' ] . should . have . length_of ( 50 )
2017-10-02 19:36:47 +00:00
resp [ ' NextMarker ' ] . should . equal (
resp [ ' LoadBalancers ' ] [ - 1 ] [ ' LoadBalancerName ' ] )
2017-07-20 22:00:30 +00:00
resp2 = conn . describe_load_balancers ( Marker = resp [ ' NextMarker ' ] )
resp2 [ ' LoadBalancers ' ] . should . have . length_of ( 1 )
assert ' NextToken ' not in resp2 . keys ( )
@mock_elbv2
@mock_ec2
def test_delete_load_balancer ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
response . get ( ' LoadBalancers ' ) . should . have . length_of ( 1 )
lb = response . get ( ' LoadBalancers ' ) [ 0 ]
conn . delete_load_balancer ( LoadBalancerArn = lb . get ( ' LoadBalancerArn ' ) )
balancers = conn . describe_load_balancers ( ) . get ( ' LoadBalancers ' )
balancers . should . have . length_of ( 0 )
@mock_ec2
@mock_elbv2
def test_register_targets ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-07-20 22:00:30 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-07-20 22:00:30 +00:00
conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
response = conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
target_group = response . get ( ' TargetGroups ' ) [ 0 ]
# No targets registered yet
2017-10-02 19:36:47 +00:00
response = conn . describe_target_health (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) )
2017-07-20 22:00:30 +00:00
response . get ( ' TargetHealthDescriptions ' ) . should . have . length_of ( 0 )
response = ec2 . create_instances (
ImageId = ' ami-1234abcd ' , MinCount = 2 , MaxCount = 2 )
instance_id1 = response [ 0 ] . id
instance_id2 = response [ 1 ] . id
response = conn . register_targets (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) ,
Targets = [
{
' Id ' : instance_id1 ,
' Port ' : 5060 ,
} ,
{
' Id ' : instance_id2 ,
' Port ' : 4030 ,
} ,
] )
2017-10-02 19:36:47 +00:00
response = conn . describe_target_health (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) )
2017-07-20 22:00:30 +00:00
response . get ( ' TargetHealthDescriptions ' ) . should . have . length_of ( 2 )
response = conn . deregister_targets (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) ,
Targets = [ { ' Id ' : instance_id2 } ] )
2017-10-02 19:36:47 +00:00
response = conn . describe_target_health (
TargetGroupArn = target_group . get ( ' TargetGroupArn ' ) )
2017-07-20 22:00:30 +00:00
response . get ( ' TargetHealthDescriptions ' ) . should . have . length_of ( 1 )
2017-08-02 22:57:15 +00:00
@mock_ec2
@mock_elbv2
def test_target_group_attributes ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-08-02 22:57:15 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-08-02 22:57:15 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
response = conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
target_group = response . get ( ' TargetGroups ' ) [ 0 ]
# Check it's in the describe_target_groups response
response = conn . describe_target_groups ( )
response . get ( ' TargetGroups ' ) . should . have . length_of ( 1 )
target_group_arn = target_group [ ' TargetGroupArn ' ]
2017-08-18 06:56:53 +00:00
# check if Names filter works
response = conn . describe_target_groups ( Names = [ ] )
response = conn . describe_target_groups ( Names = [ ' a-target ' ] )
response . get ( ' TargetGroups ' ) . should . have . length_of ( 1 )
target_group_arn = target_group [ ' TargetGroupArn ' ]
2017-08-02 22:57:15 +00:00
# The attributes should start with the two defaults
2017-10-02 19:36:47 +00:00
response = conn . describe_target_group_attributes (
TargetGroupArn = target_group_arn )
2017-08-02 22:57:15 +00:00
response [ ' Attributes ' ] . should . have . length_of ( 2 )
2017-10-02 19:36:47 +00:00
attributes = { attr [ ' Key ' ] : attr [ ' Value ' ]
for attr in response [ ' Attributes ' ] }
2017-08-02 22:57:15 +00:00
attributes [ ' deregistration_delay.timeout_seconds ' ] . should . equal ( ' 300 ' )
attributes [ ' stickiness.enabled ' ] . should . equal ( ' false ' )
2017-08-02 22:58:32 +00:00
# Add cookie stickiness
2017-08-02 22:57:15 +00:00
response = conn . modify_target_group_attributes (
TargetGroupArn = target_group_arn ,
Attributes = [
{
' Key ' : ' stickiness.enabled ' ,
' Value ' : ' true ' ,
} ,
{
' Key ' : ' stickiness.type ' ,
' Value ' : ' lb_cookie ' ,
} ,
] )
2017-08-02 22:58:32 +00:00
# The response should have only the keys updated
2017-08-02 22:57:15 +00:00
response [ ' Attributes ' ] . should . have . length_of ( 2 )
2017-10-02 19:36:47 +00:00
attributes = { attr [ ' Key ' ] : attr [ ' Value ' ]
for attr in response [ ' Attributes ' ] }
2017-08-02 22:57:15 +00:00
attributes [ ' stickiness.type ' ] . should . equal ( ' lb_cookie ' )
attributes [ ' stickiness.enabled ' ] . should . equal ( ' true ' )
# These new values should be in the full attribute list
2017-10-02 19:36:47 +00:00
response = conn . describe_target_group_attributes (
TargetGroupArn = target_group_arn )
2017-08-02 22:57:15 +00:00
response [ ' Attributes ' ] . should . have . length_of ( 3 )
2017-10-02 19:36:47 +00:00
attributes = { attr [ ' Key ' ] : attr [ ' Value ' ]
for attr in response [ ' Attributes ' ] }
2017-08-02 22:57:15 +00:00
attributes [ ' stickiness.type ' ] . should . equal ( ' lb_cookie ' )
attributes [ ' stickiness.enabled ' ] . should . equal ( ' true ' )
2017-08-16 12:09:14 +00:00
@mock_elbv2
@mock_ec2
2017-08-16 19:28:32 +00:00
def test_handle_listener_rules ( ) :
2017-08-16 12:09:14 +00:00
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-08-16 12:09:14 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-08-16 12:09:14 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
load_balancer_arn = response . get ( ' LoadBalancers ' ) [ 0 ] . get ( ' LoadBalancerArn ' )
2017-10-27 01:16:06 +00:00
# Can't create a target group with an invalid protocol
with assert_raises ( ClientError ) :
conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' /HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
2017-08-16 12:09:14 +00:00
response = conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
target_group = response . get ( ' TargetGroups ' ) [ 0 ]
# Plain HTTP listener
response = conn . create_listener (
LoadBalancerArn = load_balancer_arn ,
Protocol = ' HTTP ' ,
Port = 80 ,
DefaultActions = [ { ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) } ] )
listener = response . get ( ' Listeners ' ) [ 0 ]
listener . get ( ' Port ' ) . should . equal ( 80 )
listener . get ( ' Protocol ' ) . should . equal ( ' HTTP ' )
listener . get ( ' DefaultActions ' ) . should . equal ( [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward ' } ] )
http_listener_arn = listener . get ( ' ListenerArn ' )
# create first rule
priority = 100
host = ' xxx.example.com '
path_pattern = ' foobar '
2017-08-16 17:29:49 +00:00
created_rule = conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 12:09:14 +00:00
} ,
2017-10-02 19:36:47 +00:00
{
2017-08-16 12:09:14 +00:00
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ path_pattern ]
2017-08-16 12:09:14 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
2017-08-16 17:29:49 +00:00
) [ ' Rules ' ] [ 0 ]
created_rule [ ' Priority ' ] . should . equal ( ' 100 ' )
2017-08-16 12:09:14 +00:00
# check if rules is sorted by priority
priority = 50
host = ' yyy.example.com '
path_pattern = ' foobar '
rules = conn . create_rule (
ListenerArn = http_listener_arn ,
Priority = priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 12:09:14 +00:00
} ,
2017-10-02 19:36:47 +00:00
{
2017-08-16 12:09:14 +00:00
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ path_pattern ]
2017-08-16 12:09:14 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
)
2017-08-16 18:10:26 +00:00
# test for PriorityInUse
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 18:10:26 +00:00
ListenerArn = http_listener_arn ,
Priority = priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 18:10:26 +00:00
} ,
2017-10-02 19:36:47 +00:00
{
2017-08-16 18:10:26 +00:00
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ path_pattern ]
2017-08-16 18:10:26 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
)
2017-08-16 16:57:02 +00:00
# test for describe listeners
obtained_rules = conn . describe_rules ( ListenerArn = http_listener_arn )
2017-08-16 17:29:49 +00:00
len ( obtained_rules [ ' Rules ' ] ) . should . equal ( 3 )
priorities = [ rule [ ' Priority ' ] for rule in obtained_rules [ ' Rules ' ] ]
priorities . should . equal ( [ ' 50 ' , ' 100 ' , ' default ' ] )
2017-08-16 16:57:02 +00:00
2017-08-16 17:25:39 +00:00
first_rule = obtained_rules [ ' Rules ' ] [ 0 ]
2017-08-16 18:10:26 +00:00
second_rule = obtained_rules [ ' Rules ' ] [ 1 ]
2017-08-16 16:57:02 +00:00
obtained_rules = conn . describe_rules ( RuleArns = [ first_rule [ ' RuleArn ' ] ] )
obtained_rules [ ' Rules ' ] . should . equal ( [ first_rule ] )
# test for pagination
2017-10-02 19:36:47 +00:00
obtained_rules = conn . describe_rules (
ListenerArn = http_listener_arn , PageSize = 1 )
2017-08-16 16:57:02 +00:00
len ( obtained_rules [ ' Rules ' ] ) . should . equal ( 1 )
obtained_rules . should . have . key ( ' NextMarker ' )
2017-08-16 19:37:42 +00:00
next_marker = obtained_rules [ ' NextMarker ' ]
2017-10-02 19:36:47 +00:00
following_rules = conn . describe_rules (
ListenerArn = http_listener_arn ,
PageSize = 1 ,
Marker = next_marker )
2017-08-16 19:37:42 +00:00
len ( following_rules [ ' Rules ' ] ) . should . equal ( 1 )
following_rules . should . have . key ( ' NextMarker ' )
2017-10-02 19:36:47 +00:00
following_rules [ ' Rules ' ] [ 0 ] [ ' RuleArn ' ] . should_not . equal (
obtained_rules [ ' Rules ' ] [ 0 ] [ ' RuleArn ' ] )
2017-08-16 16:57:02 +00:00
# test for invalid describe rule request
with assert_raises ( ClientError ) :
conn . describe_rules ( )
with assert_raises ( ClientError ) :
conn . describe_rules ( RuleArns = [ ] )
with assert_raises ( ClientError ) :
conn . describe_rules (
ListenerArn = http_listener_arn ,
RuleArns = [ first_rule [ ' RuleArn ' ] ]
)
2017-08-21 19:28:58 +00:00
# modify rule partially
2017-08-16 17:25:39 +00:00
new_host = ' new.example.com '
new_path_pattern = ' new_path '
modified_rule = conn . modify_rule (
RuleArn = first_rule [ ' RuleArn ' ] ,
Conditions = [ {
2017-10-02 19:36:47 +00:00
' Field ' : ' host-header ' ,
' Values ' : [ new_host ]
} ,
2017-08-16 17:25:39 +00:00
{
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ new_path_pattern ]
} ]
2017-08-16 17:25:39 +00:00
) [ ' Rules ' ] [ 0 ]
2017-08-21 19:28:58 +00:00
2017-08-16 17:25:39 +00:00
rules = conn . describe_rules ( ListenerArn = http_listener_arn )
2017-08-21 19:28:58 +00:00
obtained_rule = rules [ ' Rules ' ] [ 0 ]
modified_rule . should . equal ( obtained_rule )
obtained_rule [ ' Conditions ' ] [ 0 ] [ ' Values ' ] [ 0 ] . should . equal ( new_host )
obtained_rule [ ' Conditions ' ] [ 1 ] [ ' Values ' ] [ 0 ] . should . equal ( new_path_pattern )
2017-10-02 19:36:47 +00:00
obtained_rule [ ' Actions ' ] [ 0 ] [ ' TargetGroupArn ' ] . should . equal (
target_group . get ( ' TargetGroupArn ' ) )
2017-08-16 17:25:39 +00:00
2017-08-16 18:10:26 +00:00
# modify priority
conn . set_rule_priorities (
RulePriorities = [
2017-10-02 19:36:47 +00:00
{ ' RuleArn ' : first_rule [ ' RuleArn ' ] ,
' Priority ' : int ( first_rule [ ' Priority ' ] ) - 1 }
2017-08-16 18:10:26 +00:00
]
)
with assert_raises ( ClientError ) :
conn . set_rule_priorities (
RulePriorities = [
{ ' RuleArn ' : first_rule [ ' RuleArn ' ] , ' Priority ' : 999 } ,
{ ' RuleArn ' : second_rule [ ' RuleArn ' ] , ' Priority ' : 999 }
]
)
2017-08-16 16:57:02 +00:00
# delete
arn = first_rule [ ' RuleArn ' ]
2017-08-16 15:35:45 +00:00
conn . delete_rule ( RuleArn = arn )
2017-08-21 19:30:03 +00:00
rules = conn . describe_rules ( ListenerArn = http_listener_arn ) [ ' Rules ' ]
len ( rules ) . should . equal ( 2 )
2017-08-16 15:35:45 +00:00
2017-08-16 12:09:14 +00:00
# test for invalid action type
safe_priority = 2
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = safe_priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 12:09:14 +00:00
} ,
2017-10-02 19:36:47 +00:00
{
2017-08-16 12:09:14 +00:00
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ path_pattern ]
2017-08-16 12:09:14 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward2 '
} ]
)
# test for invalid action type
safe_priority = 2
invalid_target_group_arn = target_group . get ( ' TargetGroupArn ' ) + ' x '
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = safe_priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 12:09:14 +00:00
} ,
2017-10-02 19:36:47 +00:00
{
2017-08-16 12:09:14 +00:00
' Field ' : ' path-pattern ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ path_pattern ]
2017-08-16 12:09:14 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : invalid_target_group_arn ,
' Type ' : ' forward '
} ]
)
# test for invalid condition field_name
safe_priority = 2
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = safe_priority ,
Conditions = [ {
' Field ' : ' xxxxxxx ' ,
2017-10-02 19:36:47 +00:00
' Values ' : [ host ]
2017-08-16 12:09:14 +00:00
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
)
# test for emptry condition value
safe_priority = 2
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = safe_priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
' Values ' : [ ]
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
)
# test for multiple condition value
safe_priority = 2
with assert_raises ( ClientError ) :
2017-10-02 19:38:36 +00:00
conn . create_rule (
2017-08-16 12:09:14 +00:00
ListenerArn = http_listener_arn ,
Priority = safe_priority ,
Conditions = [ {
' Field ' : ' host-header ' ,
' Values ' : [ host , host ]
} ] ,
Actions = [ {
' TargetGroupArn ' : target_group . get ( ' TargetGroupArn ' ) ,
' Type ' : ' forward '
} ]
)
2017-09-07 18:25:59 +00:00
@mock_elbv2
@mock_ec2
def test_describe_invalid_target_group ( ) :
conn = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
2017-10-02 19:36:47 +00:00
security_group = ec2 . create_security_group (
GroupName = ' a-security-group ' , Description = ' First One ' )
2017-09-07 18:25:59 +00:00
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
2017-10-02 19:36:47 +00:00
subnet1 = ec2 . create_subnet (
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 ' )
2017-09-07 18:25:59 +00:00
response = conn . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
2017-10-02 19:38:36 +00:00
response . get ( ' LoadBalancers ' ) [ 0 ] . get ( ' LoadBalancerArn ' )
2017-09-07 18:25:59 +00:00
response = conn . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
# Check error raises correctly
with assert_raises ( ClientError ) :
conn . describe_target_groups ( Names = [ ' invalid ' ] )
2017-10-29 14:14:17 +00:00
@mock_elbv2
def test_describe_account_limits ( ) :
client = boto3 . client ( ' elbv2 ' , region_name = ' eu-central-1 ' )
resp = client . describe_account_limits ( )
resp [ ' Limits ' ] [ 0 ] . should . contain ( ' Name ' )
resp [ ' Limits ' ] [ 0 ] . should . contain ( ' Max ' )
@mock_elbv2
def test_describe_ssl_policies ( ) :
client = boto3 . client ( ' elbv2 ' , region_name = ' eu-central-1 ' )
resp = client . describe_ssl_policies ( )
len ( resp [ ' SslPolicies ' ] ) . should . equal ( 5 )
resp = client . describe_ssl_policies ( Names = [ ' ELBSecurityPolicy-TLS-1-2-2017-01 ' , ' ELBSecurityPolicy-2016-08 ' ] )
len ( resp [ ' SslPolicies ' ] ) . should . equal ( 2 )
@mock_elbv2
@mock_ec2
def test_set_ip_address_type ( ) :
client = boto3 . client ( ' elbv2 ' , 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 ' )
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 ' )
subnet2 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' us-east-1b ' )
response = client . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
arn = response [ ' LoadBalancers ' ] [ 0 ] [ ' LoadBalancerArn ' ]
# Internal LBs cant be dualstack yet
with assert_raises ( ClientError ) :
client . set_ip_address_type (
LoadBalancerArn = arn ,
IpAddressType = ' dualstack '
)
# Create internet facing one
response = client . create_load_balancer (
Name = ' my-lb2 ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internet-facing ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
arn = response [ ' LoadBalancers ' ] [ 0 ] [ ' LoadBalancerArn ' ]
client . set_ip_address_type (
LoadBalancerArn = arn ,
IpAddressType = ' dualstack '
)
@mock_elbv2
@mock_ec2
def test_set_security_groups ( ) :
client = boto3 . client ( ' elbv2 ' , 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_group2 = ec2 . create_security_group (
GroupName = ' b-security-group ' , Description = ' Second One ' )
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 ' )
subnet2 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' us-east-1b ' )
response = client . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
arn = response [ ' LoadBalancers ' ] [ 0 ] [ ' LoadBalancerArn ' ]
client . set_security_groups (
LoadBalancerArn = arn ,
SecurityGroups = [ security_group . id , security_group2 . id ]
)
resp = client . describe_load_balancers ( LoadBalancerArns = [ arn ] )
len ( resp [ ' LoadBalancers ' ] [ 0 ] [ ' SecurityGroups ' ] ) . should . equal ( 2 )
with assert_raises ( ClientError ) :
client . set_security_groups (
LoadBalancerArn = arn ,
SecurityGroups = [ ' non_existant ' ]
)
@mock_elbv2
@mock_ec2
def test_set_subnets ( ) :
client = boto3 . client ( ' elbv2 ' , 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 ' )
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 ' )
subnet2 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' us-east-1b ' )
subnet3 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' us-east-1c ' )
response = client . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
arn = response [ ' LoadBalancers ' ] [ 0 ] [ ' LoadBalancerArn ' ]
client . set_subnets (
LoadBalancerArn = arn ,
Subnets = [ subnet1 . id , subnet2 . id , subnet3 . id ]
)
resp = client . describe_load_balancers ( LoadBalancerArns = [ arn ] )
len ( resp [ ' LoadBalancers ' ] [ 0 ] [ ' AvailabilityZones ' ] ) . should . equal ( 3 )
# Only 1 AZ
with assert_raises ( ClientError ) :
client . set_subnets (
LoadBalancerArn = arn ,
Subnets = [ subnet1 . id ]
)
# Multiple subnets in same AZ
with assert_raises ( ClientError ) :
client . set_subnets (
LoadBalancerArn = arn ,
Subnets = [ subnet1 . id , subnet2 . id , subnet2 . id ]
)
@mock_elbv2
@mock_ec2
def test_set_subnets ( ) :
client = boto3 . client ( ' elbv2 ' , 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 ' )
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 ' )
subnet2 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' us-east-1b ' )
response = client . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
arn = response [ ' LoadBalancers ' ] [ 0 ] [ ' LoadBalancerArn ' ]
client . modify_load_balancer_attributes (
LoadBalancerArn = arn ,
Attributes = [ { ' Key ' : ' idle_timeout.timeout_seconds ' , ' Value ' : ' 600 ' } ]
)
# Check its 600 not 60
response = client . describe_load_balancer_attributes (
LoadBalancerArn = arn
)
idle_timeout = list ( filter ( lambda item : item [ ' Key ' ] == ' idle_timeout.timeout_seconds ' , response [ ' Attributes ' ] ) ) [ 0 ]
idle_timeout [ ' Value ' ] . should . equal ( ' 600 ' )
@mock_elbv2
@mock_ec2
def test_modify_target_group ( ) :
client = boto3 . client ( ' elbv2 ' , region_name = ' us-east-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' us-east-1 ' )
vpc = ec2 . create_vpc ( CidrBlock = ' 172.28.7.0/24 ' , InstanceTenancy = ' default ' )
response = client . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
arn = response . get ( ' TargetGroups ' ) [ 0 ] [ ' TargetGroupArn ' ]
client . modify_target_group (
TargetGroupArn = arn ,
HealthCheckProtocol = ' HTTPS ' ,
HealthCheckPort = ' 8081 ' ,
HealthCheckPath = ' /status ' ,
HealthCheckIntervalSeconds = 10 ,
HealthCheckTimeoutSeconds = 10 ,
HealthyThresholdCount = 10 ,
UnhealthyThresholdCount = 4 ,
Matcher = { ' HttpCode ' : ' 200-399 ' }
)
response = client . describe_target_groups (
TargetGroupArns = [ arn ]
)
response [ ' TargetGroups ' ] [ 0 ] [ ' Matcher ' ] [ ' HttpCode ' ] . should . equal ( ' 200-399 ' )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthCheckIntervalSeconds ' ] . should . equal ( 10 )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthCheckPath ' ] . should . equal ( ' /status ' )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthCheckPort ' ] . should . equal ( ' 8081 ' )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthCheckProtocol ' ] . should . equal ( ' HTTPS ' )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthCheckTimeoutSeconds ' ] . should . equal ( 10 )
response [ ' TargetGroups ' ] [ 0 ] [ ' HealthyThresholdCount ' ] . should . equal ( 10 )
response [ ' TargetGroups ' ] [ 0 ] [ ' UnhealthyThresholdCount ' ] . should . equal ( 4 )
@mock_elbv2
@mock_ec2
@mock_acm
def test_modify_listener_http_to_https ( ) :
client = boto3 . client ( ' elbv2 ' , region_name = ' eu-central-1 ' )
acm = boto3 . client ( ' acm ' , region_name = ' eu-central-1 ' )
ec2 = boto3 . resource ( ' ec2 ' , region_name = ' eu-central-1 ' )
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 ' )
subnet1 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' eu-central-1a ' )
subnet2 = ec2 . create_subnet (
VpcId = vpc . id ,
CidrBlock = ' 172.28.7.192/26 ' ,
AvailabilityZone = ' eu-central-1b ' )
response = client . create_load_balancer (
Name = ' my-lb ' ,
Subnets = [ subnet1 . id , subnet2 . id ] ,
SecurityGroups = [ security_group . id ] ,
Scheme = ' internal ' ,
Tags = [ { ' Key ' : ' key_name ' , ' Value ' : ' a_value ' } ] )
load_balancer_arn = response . get ( ' LoadBalancers ' ) [ 0 ] . get ( ' LoadBalancerArn ' )
response = client . create_target_group (
Name = ' a-target ' ,
Protocol = ' HTTP ' ,
Port = 8080 ,
VpcId = vpc . id ,
HealthCheckProtocol = ' HTTP ' ,
HealthCheckPort = ' 8080 ' ,
HealthCheckPath = ' / ' ,
HealthCheckIntervalSeconds = 5 ,
HealthCheckTimeoutSeconds = 5 ,
HealthyThresholdCount = 5 ,
UnhealthyThresholdCount = 2 ,
Matcher = { ' HttpCode ' : ' 200 ' } )
target_group = response . get ( ' TargetGroups ' ) [ 0 ]
target_group_arn = target_group [ ' TargetGroupArn ' ]
# Plain HTTP listener
response = client . create_listener (
LoadBalancerArn = load_balancer_arn ,
Protocol = ' HTTP ' ,
Port = 80 ,
DefaultActions = [ { ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group_arn } ]
)
listener_arn = response [ ' Listeners ' ] [ 0 ] [ ' ListenerArn ' ]
response = acm . request_certificate (
DomainName = ' google.com ' ,
SubjectAlternativeNames = [ ' google.com ' , ' www.google.com ' , ' mail.google.com ' ] ,
)
google_arn = response [ ' CertificateArn ' ]
response = acm . request_certificate (
DomainName = ' yahoo.com ' ,
SubjectAlternativeNames = [ ' yahoo.com ' , ' www.yahoo.com ' , ' mail.yahoo.com ' ] ,
)
yahoo_arn = response [ ' CertificateArn ' ]
response = client . modify_listener (
ListenerArn = listener_arn ,
Port = 443 ,
Protocol = ' HTTPS ' ,
SslPolicy = ' ELBSecurityPolicy-TLS-1-2-2017-01 ' ,
Certificates = [
{ ' CertificateArn ' : google_arn , ' IsDefault ' : False } ,
{ ' CertificateArn ' : yahoo_arn , ' IsDefault ' : True }
] ,
DefaultActions = [
{ ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group_arn }
]
)
response [ ' Listeners ' ] [ 0 ] [ ' Port ' ] . should . equal ( 443 )
response [ ' Listeners ' ] [ 0 ] [ ' Protocol ' ] . should . equal ( ' HTTPS ' )
response [ ' Listeners ' ] [ 0 ] [ ' SslPolicy ' ] . should . equal ( ' ELBSecurityPolicy-TLS-1-2-2017-01 ' )
len ( response [ ' Listeners ' ] [ 0 ] [ ' Certificates ' ] ) . should . equal ( 2 )
2017-10-29 16:06:03 +00:00
# Check default cert, can't do this in server mode
if os . environ . get ( ' TEST_SERVER_MODE ' , ' false ' ) . lower ( ) == ' false ' :
listener = elbv2_backends [ ' eu-central-1 ' ] . load_balancers [ load_balancer_arn ] . listeners [ listener_arn ]
listener . certificate . should . equal ( yahoo_arn )
2017-10-29 14:14:17 +00:00
# No default cert
with assert_raises ( ClientError ) :
client . modify_listener (
ListenerArn = listener_arn ,
Port = 443 ,
Protocol = ' HTTPS ' ,
SslPolicy = ' ELBSecurityPolicy-TLS-1-2-2017-01 ' ,
Certificates = [
{ ' CertificateArn ' : google_arn , ' IsDefault ' : False }
] ,
DefaultActions = [
{ ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group_arn }
]
)
# Bad cert
with assert_raises ( ClientError ) :
client . modify_listener (
ListenerArn = listener_arn ,
Port = 443 ,
Protocol = ' HTTPS ' ,
SslPolicy = ' ELBSecurityPolicy-TLS-1-2-2017-01 ' ,
Certificates = [
{ ' CertificateArn ' : ' lalala ' , ' IsDefault ' : True }
] ,
DefaultActions = [
{ ' Type ' : ' forward ' , ' TargetGroupArn ' : target_group_arn }
]
)