From 67edcff7688f6163ac1051c8b7b09c2d164f6989 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gon=C3=A9ri=20Le=20Bouder?= Date: Tue, 16 Mar 2021 14:48:00 -0400 Subject: [PATCH] elb_application_lb: test a rule based on http-header (#347) * elb_application_lb: test a rule based on http-header This should initially fail and be fixed the day https://github.com/ansible-collections/amazon.aws/pull/188 is merged. See: https://github.com/ansible-collections/amazon.aws/pull/187 See: https://github.com/ansible-collections/community.aws/issues/117 Co-authored-by: Mark Chappell --- .../tasks/test_multiple_actions.yml | 64 +++++++++++++++---- 1 file changed, 50 insertions(+), 14 deletions(-) diff --git a/tests/integration/targets/elb_application_lb/tasks/test_multiple_actions.yml b/tests/integration/targets/elb_application_lb/tasks/test_multiple_actions.yml index 26bcf2c28f1..da56a98716b 100644 --- a/tests/integration/targets/elb_application_lb/tasks/test_multiple_actions.yml +++ b/tests/integration/targets/elb_application_lb/tasks/test_multiple_actions.yml @@ -159,11 +159,27 @@ - Type: fixed-response FixedResponseConfig: "{{ FixedResponseActionConfig }}" Rules: + - Conditions: + - Field: http-header + HttpHeaderConfig: + HttpHeaderName: 'User-Agent' + Values: ['*Trident/7:0*rv:*'] + - Field: http-header + HttpHeaderConfig: + HttpHeaderName: 'X-Something' + Values: ['foobar'] + Priority: '1' + Actions: + - Type: fixed-response + FixedResponseConfig: + StatusCode: "200" + ContentType: "text/html" + MessageBody: "Hello World!" - Conditions: - Field: path-pattern Values: - "/forward-path/*" - Priority: 1 + Priority: 2 Actions: - Type: forward TargetGroupName: "{{ tg_name }}" @@ -171,7 +187,7 @@ - Field: path-pattern Values: - "/redirect-path/*" - Priority: 2 + Priority: 3 Actions: - Type: redirect RedirectConfig: "{{ RedirectActionConfig }}" @@ -179,7 +195,7 @@ - Field: path-pattern Values: - "/fixed-response-path/" - Priority: 3 + Priority: 4 Actions: - Type: fixed-response FixedResponseConfig: "{{ FixedResponseActionConfig }}" @@ -189,13 +205,15 @@ that: - alb.changed - alb.listeners|length == 1 - - alb.listeners[0].rules|length == 4 ## defaultactions is included as a rule + - alb.listeners[0].rules|length == 5 ## defaultactions is included as a rule - alb.listeners[0].rules[0].actions|length == 1 - - alb.listeners[0].rules[0].actions[0].type == "forward" + - alb.listeners[0].rules[0].actions[0].type == "fixed-response" - alb.listeners[0].rules[1].actions|length == 1 - - alb.listeners[0].rules[1].actions[0].type == "redirect" + - alb.listeners[0].rules[1].actions[0].type == "forward" - alb.listeners[0].rules[2].actions|length == 1 - - alb.listeners[0].rules[2].actions[0].type == "fixed-response" + - alb.listeners[0].rules[2].actions[0].type == "redirect" + - alb.listeners[0].rules[3].actions|length == 1 + - alb.listeners[0].rules[3].actions[0].type == "fixed-response" - name: test idempotence multiple non-default rules elb_application_lb: @@ -210,11 +228,27 @@ - Type: fixed-response FixedResponseConfig: "{{ FixedResponseActionConfig }}" Rules: + - Conditions: + - Field: http-header + HttpHeaderConfig: + HttpHeaderName: 'User-Agent' + Values: ['*Trident/7:0*rv:*'] + - Field: http-header + HttpHeaderConfig: + HttpHeaderName: 'X-Something' + Values: ['foobar'] + Priority: '1' + Actions: + - Type: fixed-response + FixedResponseConfig: + StatusCode: "200" + ContentType: "text/html" + MessageBody: "Hello World!" - Conditions: - Field: path-pattern Values: - "/forward-path/*" - Priority: 1 + Priority: 2 Actions: - Type: forward TargetGroupName: "{{ tg_name }}" @@ -222,7 +256,7 @@ - Field: path-pattern Values: - "/redirect-path/*" - Priority: 2 + Priority: 3 Actions: - Type: redirect RedirectConfig: "{{ RedirectActionConfig }}" @@ -230,7 +264,7 @@ - Field: path-pattern Values: - "/fixed-response-path/" - Priority: 3 + Priority: 4 Actions: - Type: fixed-response FixedResponseConfig: "{{ FixedResponseActionConfig }}" @@ -240,13 +274,15 @@ that: - not alb.changed - alb.listeners|length == 1 - - alb.listeners[0].rules|length == 4 ## defaultactions is included as a rule + - alb.listeners[0].rules|length == 5 ## defaultactions is included as a rule - alb.listeners[0].rules[0].actions|length == 1 - - alb.listeners[0].rules[0].actions[0].type == "forward" + - alb.listeners[0].rules[0].actions[0].type == "fixed-response" - alb.listeners[0].rules[1].actions|length == 1 - - alb.listeners[0].rules[1].actions[0].type == "redirect" + - alb.listeners[0].rules[1].actions[0].type == "forward" - alb.listeners[0].rules[2].actions|length == 1 - - alb.listeners[0].rules[2].actions[0].type == "fixed-response" + - alb.listeners[0].rules[2].actions[0].type == "redirect" + - alb.listeners[0].rules[3].actions|length == 1 + - alb.listeners[0].rules[3].actions[0].type == "fixed-response" # - name: test creating ALB with a default listener with multiple actions