From 5c381e75cc0e0f0ca7bb79f15781a99d9b9d723b Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Tue, 10 Dec 2024 00:00:39 -0300 Subject: [PATCH 1/9] Enable run_task command to wait until the executions ends and return the exit code #230 --- .circleci/test-deploy.yml | 21 ++++++++++-- src/commands/run_task.yml | 10 ++++++ src/examples/run_task_and_wait.yml | 27 ++++++++++++++++ src/scripts/run_task.sh | 52 +++++++++++++++++++++++++++--- 4 files changed, 104 insertions(+), 6 deletions(-) create mode 100644 src/examples/run_task_and_wait.yml diff --git a/.circleci/test-deploy.yml b/.circleci/test-deploy.yml index f41ca1a..cf62832 100644 --- a/.circleci/test-deploy.yml +++ b/.circleci/test-deploy.yml @@ -439,7 +439,7 @@ workflows: aws-resource-name-prefix: ${AWS_RESOURCE_NAME_PREFIX_FARGATE} terraform-config-dir: "tests/terraform_setup/fargate" context: [CPE-OIDC] - role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" + role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" - build-test-app: name: fargate_build-test-app docker-image-namespace: "${AWS_ACCOUNT_ID}.dkr.ecr.${AWS_DEFAULT_REGION}.amazonaws.com" @@ -574,11 +574,28 @@ workflows: run_task_output: "run_task_output.json" overrides: '{"containerOverrides":[{"name": "${INTERPOLATION_TEST}", "memory": 512}]}' context: [CPE-OIDC] + - aws-ecs/run_task: + name: ec2_run_task_and_wait-test + auth: + - aws-cli/setup: + role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" + filters: *filters + requires: + - ec2_set-up-run_task-test + cluster: "${AWS_RESOURCE_NAME_PREFIX_EC2}-cluster" + task_definition: "${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360" + launch_type: "EC2" + awsvpc: false + overrides: '{"containerOverrides":[{"name": "${INTERPOLATION_TEST}", "memory": 512}]}' + context: [CPE-OIDC] + wait_task_stopped: true + exit_code_from: sleep - tear-down-run_task-test: name: ec2_tear-down-run_task-test filters: *filters requires: - ec2_run_task-test + - ec2_run_task_and_wait-test family_name: ${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360 context: [CPE-OIDC] role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" @@ -846,7 +863,7 @@ commands: else PORT="<< parameters.port >>" fi - + set -x TARGET_GROUP_ARN=$(aws ecs describe-services --cluster << parameters.cluster >> --services << parameters.service_name >> $PROFILE | jq -r '.services[0].loadBalancers[0].targetGroupArn') ELB_ARN=$(aws elbv2 describe-target-groups --target-group-arns $TARGET_GROUP_ARN $PROFILE | jq -r '.TargetGroups[0].LoadBalancerArns[0]') diff --git a/src/commands/run_task.yml b/src/commands/run_task.yml index 8e1e4de..bc6a3f6 100755 --- a/src/commands/run_task.yml +++ b/src/commands/run_task.yml @@ -128,6 +128,14 @@ parameters: description: AWS region to use. Defaults to AWS_DEFAULT_REGION environment variable. type: string default: $AWS_DEFAULT_REGION + wait_task_stopped: + description: Wait until the task execution ends. Doesn't work with `run_task_output`. + type: boolean + default: false + exit_code_from: + description: Name of the container which exit code will be returned if wait_task_stopped is true. Defaults to the first container. + type: string + default: '' steps: - run: name: Run Task @@ -155,3 +163,5 @@ steps: ORB_STR_CD_CAPACITY_PROVIDER_STRATEGY: <> ORB_STR_PROFILE_NAME: <> ORB_STR_RUN_TASK_OUTPUT: <> + ORB_BOOL_WAIT_TASK_STOPPED: <> + ORB_STR_EXIT_CODE_FROM: <> diff --git a/src/examples/run_task_and_wait.yml b/src/examples/run_task_and_wait.yml new file mode 100644 index 0000000..faf3d24 --- /dev/null +++ b/src/examples/run_task_and_wait.yml @@ -0,0 +1,27 @@ +description: Start the execution of an ECS task and wait until the task is completed. +usage: + version: 2.1 + orbs: + aws-ecs: circleci/aws-ecs@6.0.0 + aws-cli: circleci/aws-cli@5.1.0 + jobs: + run_task: + docker: + - image: cimg/python:3.10 + steps: + - aws-cli/setup: + profile_name: "OIDC-USER" + role_arn: "arn:aws:iam::123456789012:role/VALID_OIDC_ECS_ROLE" + - aws-ecs/run_task: + cluster: $CLUSTER_NAME + launch_type: "" + region: us-east-1 + task_definition: $My_Task_Def + subnet_ids: '$SUBNET_ONE, $SUBNET_TWO' + security_group_ids: $SECURITY_GROUP_IDS_FETCHED\ + wait_task_stopped: true + exit_code_from: app + workflows: + run_task: + jobs: + - run_task diff --git a/src/scripts/run_task.sh b/src/scripts/run_task.sh index 5d90828..6906e1e 100644 --- a/src/scripts/run_task.sh +++ b/src/scripts/run_task.sh @@ -14,6 +14,7 @@ ORB_STR_RUN_TASK_OUTPUT="$(circleci env subst "$ORB_STR_RUN_TASK_OUTPUT")" ORB_STR_PROFILE_NAME="$(circleci env subst "$ORB_STR_PROFILE_NAME")" ORB_STR_ASSIGN_PUB_IP="$(circleci env subst "$ORB_STR_ASSIGN_PUB_IP")" ORB_AWS_REGION="$(circleci env subst "$ORB_AWS_REGION")" +ORB_STR_EXIT_CODE_FROM="$(circleci env subst "$ORB_STR_EXIT_CODE_FROM")" if [[ "$ORB_STR_OVERRIDES" == *"\${"* ]]; then ORB_STR_OVERRIDES="$(echo "${ORB_STR_OVERRIDES}" | circleci env subst)" @@ -77,7 +78,6 @@ if [ -n "$ORB_STR_CD_CAPACITY_PROVIDER_STRATEGY" ]; then # shellcheck disable=SC2086 set -- "$@" --capacity-provider-strategy $ORB_STR_CD_CAPACITY_PROVIDER_STRATEGY fi - if [ -n "$ORB_VAL_LAUNCH_TYPE" ]; then if [ -n "$ORB_STR_CD_CAPACITY_PROVIDER_STRATEGY" ]; then echo "Error: " @@ -88,7 +88,10 @@ if [ -n "$ORB_VAL_LAUNCH_TYPE" ]; then set -- "$@" --launch-type "$ORB_VAL_LAUNCH_TYPE" fi fi - +if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then + echo "Setting query to export taskArn" + set -- "$@" --query 'tasks[].taskArn' --output text +fi echo "Setting --count" set -- "$@" --count "$ORB_INT_COUNT" @@ -99,11 +102,52 @@ set -- "$@" --cluster "$ORB_STR_CLUSTER_NAME" if [ -n "${ORB_STR_RUN_TASK_OUTPUT}" ]; then + if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then + echo "Exporting the run_task_output parameter is not compatible with wait_task_stopped parameter." + exit 1 + fi + set -x aws ecs run-task --profile "${ORB_STR_PROFILE_NAME}" --region "${ORB_AWS_REGION}" "$@" | tee "${ORB_STR_RUN_TASK_OUTPUT}" set +x else - set -x - aws ecs run-task --profile "${ORB_STR_PROFILE_NAME}" --region "${ORB_AWS_REGION}" "$@" + set -x + ORB_STR_TASK_ARN=$(aws ecs run-task --profile "${ORB_STR_PROFILE_NAME}" --region "${ORB_AWS_REGION}" "$@") set +x fi + +if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then + echo "Wait for ECS task $ORB_STR_TASK_ARN to stop..." + + ORB_STR_WAIT_EXIT_CODE=$(aws ecs wait tasks-stopped \ + --profile "${ORB_STR_PROFILE_NAME}" \ + --region "${ORB_AWS_REGION}" \ + --cluster "${ORB_STR_CLUSTER_NAME}" \ + --tasks $ORB_STR_TASK_ARN + ) + + if [ "$ORB_STR_WAIT_EXIT_CODE" != "0" ]; then + echo "Stopped waiting for the task execution to end - please check the status of $ORB_STR_TASK_ARN on the AWS ECS console." + fi + + # Get exit code + if [ -n "$ORB_STR_EXIT_CODE_FROM" ] + ORB_STR_TASK_EXIT_CODE=$(aws ecs describe-tasks \ + --profile "${ORB_STR_PROFILE_NAME}" \ + --region "${ORB_AWS_REGION}" \ + --cluster "${ORB_STR_CLUSTER_NAME}" \ + --tasks $TASK_ARN \ + --query "tasks[0].containers[?name=='$ORB_STR_EXIT_CODE_FROM'].exitCode" \ + --output text) + else + # Assume the first container + ORB_STR_TASK_EXIT_CODE=$(aws ecs describe-tasks \ + --profile "${ORB_STR_PROFILE_NAME}" \ + --region "${ORB_AWS_REGION}" \ + --cluster "${ORB_STR_CLUSTER_NAME}" \ + --tasks $TASK_ARN \ + --query "tasks[0].containers[0].exitCode" \ + --output text) + fi + exit $ORB_STR_TASK_EXIT_CODE +fi From 6fee0fad9a2c7ff6959658126f9fc96567b69286 Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Tue, 10 Dec 2024 11:12:32 -0300 Subject: [PATCH 2/9] Schellcheck fixes --- src/scripts/run_task.sh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/scripts/run_task.sh b/src/scripts/run_task.sh index 6906e1e..548e6d0 100644 --- a/src/scripts/run_task.sh +++ b/src/scripts/run_task.sh @@ -123,7 +123,7 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then --profile "${ORB_STR_PROFILE_NAME}" \ --region "${ORB_AWS_REGION}" \ --cluster "${ORB_STR_CLUSTER_NAME}" \ - --tasks $ORB_STR_TASK_ARN + --tasks "${ORB_STR_TASK_ARN}" ) if [ "$ORB_STR_WAIT_EXIT_CODE" != "0" ]; then @@ -131,12 +131,12 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then fi # Get exit code - if [ -n "$ORB_STR_EXIT_CODE_FROM" ] + if [ -n "$ORB_STR_EXIT_CODE_FROM" ]; then ORB_STR_TASK_EXIT_CODE=$(aws ecs describe-tasks \ --profile "${ORB_STR_PROFILE_NAME}" \ --region "${ORB_AWS_REGION}" \ --cluster "${ORB_STR_CLUSTER_NAME}" \ - --tasks $TASK_ARN \ + --tasks "${ORB_STR_TASK_ARN}" \ --query "tasks[0].containers[?name=='$ORB_STR_EXIT_CODE_FROM'].exitCode" \ --output text) else @@ -145,9 +145,9 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then --profile "${ORB_STR_PROFILE_NAME}" \ --region "${ORB_AWS_REGION}" \ --cluster "${ORB_STR_CLUSTER_NAME}" \ - --tasks $TASK_ARN \ + --tasks "${ORB_STR_TASK_ARN}" \ --query "tasks[0].containers[0].exitCode" \ --output text) fi - exit $ORB_STR_TASK_EXIT_CODE + exit "${ORB_STR_TASK_EXIT_CODE}" fi From 742bb9c34d3a6513bc29f7be50f3f4029b4caa02 Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Tue, 10 Dec 2024 16:24:49 -0300 Subject: [PATCH 3/9] Added parameters to run_task job --- src/jobs/run_task.yml | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/jobs/run_task.yml b/src/jobs/run_task.yml index 0096324..350e802 100755 --- a/src/jobs/run_task.yml +++ b/src/jobs/run_task.yml @@ -153,6 +153,14 @@ parameters: description: The executor to use for this job. By default, this will use the "default" executor provided by this orb. type: executor default: default + wait_task_stopped: + description: Wait until the task execution ends. Doesn't work with `run_task_output`. + type: boolean + default: false + exit_code_from: + description: Name of the container which exit code will be returned if wait_task_stopped is true. Defaults to the first container. + type: string + default: '' executor: << parameters.executor >> steps: - steps: << parameters.auth >> @@ -179,3 +187,5 @@ steps: capacity_provider_strategy: << parameters.capacity_provider_strategy >> profile_name: << parameters.profile_name >> run_task_output: <> + wait_task_stopped: <> + exit_code_from: <> From db67085082f08399041ab44ed521d265d86a69da Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Tue, 10 Dec 2024 17:31:27 -0300 Subject: [PATCH 4/9] fixing typo --- src/jobs/run_task.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/jobs/run_task.yml b/src/jobs/run_task.yml index 350e802..1f65f45 100755 --- a/src/jobs/run_task.yml +++ b/src/jobs/run_task.yml @@ -187,5 +187,5 @@ steps: capacity_provider_strategy: << parameters.capacity_provider_strategy >> profile_name: << parameters.profile_name >> run_task_output: <> - wait_task_stopped: <> - exit_code_from: <> + wait_task_stopped: <> + exit_code_from: <> From 4a42a3ebf1f00f912ddc9869c2a188f0c82e9aaf Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Wed, 11 Dec 2024 23:26:56 -0300 Subject: [PATCH 5/9] Add tests and improved error messages --- .circleci/test-deploy.yml | 32 ++++++++++++++++++++++++++++++++ src/scripts/run_task.sh | 20 ++++++++++++++------ 2 files changed, 46 insertions(+), 6 deletions(-) diff --git a/.circleci/test-deploy.yml b/.circleci/test-deploy.yml index cf62832..ba1a548 100644 --- a/.circleci/test-deploy.yml +++ b/.circleci/test-deploy.yml @@ -590,12 +590,44 @@ workflows: context: [CPE-OIDC] wait_task_stopped: true exit_code_from: sleep + - aws-ecs/run_task: + name: ec2_run_task_and_wait_too_long_task-test + auth: + - aws-cli/setup: + role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" + filters: *filters + requires: + - ec2_set-up-run_task-test + cluster: "${AWS_RESOURCE_NAME_PREFIX_EC2}-cluster" + task_definition: "${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360" + overrides: '{"containerOverrides": [{"name": "sleep","command": ["sleep", "700"]}]}' + launch_type: "EC2" + awsvpc: false + context: [CPE-OIDC] + wait_task_stopped: true + - aws-ecs/run_task: + name: ec2_run_task_and_wait_failure-test + auth: + - aws-cli/setup: + role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" + filters: *filters + requires: + - ec2_set-up-run_task-test + cluster: "${AWS_RESOURCE_NAME_PREFIX_EC2}-cluster" + task_definition: "${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360" + overrides: '{"containerOverrides": [{"name": "sleep","command": ["exit", "127"]}]}' + launch_type: "EC2" + awsvpc: false + context: [CPE-OIDC] + wait_task_stopped: true - tear-down-run_task-test: name: ec2_tear-down-run_task-test filters: *filters requires: - ec2_run_task-test - ec2_run_task_and_wait-test + - ec2_run_task_and_wait_too_long_task-test: failure + - ec2_run_task_and_wait_failure-test: failure family_name: ${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360 context: [CPE-OIDC] role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" diff --git a/src/scripts/run_task.sh b/src/scripts/run_task.sh index 548e6d0..bdbbcfe 100644 --- a/src/scripts/run_task.sh +++ b/src/scripts/run_task.sh @@ -100,7 +100,6 @@ set -- "$@" --task-definition "$ORB_STR_TASK_DEF" echo "Setting --cluster" set -- "$@" --cluster "$ORB_STR_CLUSTER_NAME" - if [ -n "${ORB_STR_RUN_TASK_OUTPUT}" ]; then if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then echo "Exporting the run_task_output parameter is not compatible with wait_task_stopped parameter." @@ -117,17 +116,19 @@ else fi if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then - echo "Wait for ECS task $ORB_STR_TASK_ARN to stop..." + echo "Waiting for ECS task $ORB_STR_TASK_ARN to stop..." ORB_STR_WAIT_EXIT_CODE=$(aws ecs wait tasks-stopped \ --profile "${ORB_STR_PROFILE_NAME}" \ --region "${ORB_AWS_REGION}" \ --cluster "${ORB_STR_CLUSTER_NAME}" \ - --tasks "${ORB_STR_TASK_ARN}" + --tasks "${ORB_STR_TASK_ARN}"; \ + echo $? ) - if [ "$ORB_STR_WAIT_EXIT_CODE" != "0" ]; then - echo "Stopped waiting for the task execution to end - please check the status of $ORB_STR_TASK_ARN on the AWS ECS console." + if [[ "${ORB_STR_WAIT_EXIT_CODE}" -ne 0 ]]; then + echo "Stopped waiting for the task execution to end. Please check the status of $ORB_STR_TASK_ARN on the AWS ECS console." + exit "${ORB_STR_WAIT_EXIT_CODE}" fi # Get exit code @@ -149,5 +150,12 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then --query "tasks[0].containers[0].exitCode" \ --output text) fi - exit "${ORB_STR_TASK_EXIT_CODE}" + + if [ "${ORB_STR_TASK_EXIT_CODE:-1}" -eq 0 ]; then + echo "The task execution ended successfully." + else + echo "The task execution ended with an error, please check the status and logs of $ORB_STR_TASK_ARN on the AWS ECS console." + fi + + exit "${ORB_STR_TASK_EXIT_CODE:-1}" fi From 3ea2e2c5e86a4e509adfd9c48fdae46cc1c2f23e Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Thu, 12 Dec 2024 11:37:08 -0300 Subject: [PATCH 6/9] fixed failed state --- .circleci/test-deploy.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.circleci/test-deploy.yml b/.circleci/test-deploy.yml index ba1a548..7c05afb 100644 --- a/.circleci/test-deploy.yml +++ b/.circleci/test-deploy.yml @@ -626,8 +626,8 @@ workflows: requires: - ec2_run_task-test - ec2_run_task_and_wait-test - - ec2_run_task_and_wait_too_long_task-test: failure - - ec2_run_task_and_wait_failure-test: failure + - ec2_run_task_and_wait_too_long_task-test: failed + - ec2_run_task_and_wait_failure-test: failed family_name: ${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360 context: [CPE-OIDC] role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" From 067b51f3189ab997b76505191ccd8adbf1cc7b7c Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Thu, 12 Dec 2024 19:14:29 -0300 Subject: [PATCH 7/9] test failure modes --- src/scripts/run_task.sh | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/scripts/run_task.sh b/src/scripts/run_task.sh index bdbbcfe..48a977b 100644 --- a/src/scripts/run_task.sh +++ b/src/scripts/run_task.sh @@ -89,7 +89,7 @@ if [ -n "$ORB_VAL_LAUNCH_TYPE" ]; then fi fi if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then - echo "Setting query to export taskArn" + echo "Setting --query to export taskArn" set -- "$@" --query 'tasks[].taskArn' --output text fi @@ -116,6 +116,10 @@ else fi if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then + if [ -z "${ORB_STR_TASK_ARN}" ]; then + exit 1 + fi + echo "Waiting for ECS task $ORB_STR_TASK_ARN to stop..." ORB_STR_WAIT_EXIT_CODE=$(aws ecs wait tasks-stopped \ @@ -151,7 +155,7 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then --output text) fi - if [ "${ORB_STR_TASK_EXIT_CODE:-1}" -eq 0 ]; then + if [ "${ORB_STR_TASK_EXIT_CODE:-1}" != "None" ] || [ "${ORB_STR_TASK_EXIT_CODE:-1}" -eq 0 ]; then echo "The task execution ended successfully." else echo "The task execution ended with an error, please check the status and logs of $ORB_STR_TASK_ARN on the AWS ECS console." From 36d0ed97d03efcc820bfc9c24eac2373648ded9f Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Thu, 12 Dec 2024 20:06:35 -0300 Subject: [PATCH 8/9] fix to solve the possibility that exit code is not a number --- src/scripts/run_task.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/scripts/run_task.sh b/src/scripts/run_task.sh index 48a977b..aac2bc1 100644 --- a/src/scripts/run_task.sh +++ b/src/scripts/run_task.sh @@ -155,7 +155,7 @@ if [ "$ORB_BOOL_WAIT_TASK_STOPPED" == "1" ]; then --output text) fi - if [ "${ORB_STR_TASK_EXIT_CODE:-1}" != "None" ] || [ "${ORB_STR_TASK_EXIT_CODE:-1}" -eq 0 ]; then + if [ "${ORB_STR_TASK_EXIT_CODE:-1}" == "0" ]; then echo "The task execution ended successfully." else echo "The task execution ended with an error, please check the status and logs of $ORB_STR_TASK_ARN on the AWS ECS console." From 1c6a2ed04248b668e22b0294b0e0d9276ec9b1d5 Mon Sep 17 00:00:00 2001 From: Ezequiel Gonzalez Rial Date: Fri, 13 Dec 2024 11:20:55 -0300 Subject: [PATCH 9/9] Remove failing tests --- .circleci/test-deploy.yml | 32 -------------------------------- 1 file changed, 32 deletions(-) diff --git a/.circleci/test-deploy.yml b/.circleci/test-deploy.yml index 7c05afb..cf62832 100644 --- a/.circleci/test-deploy.yml +++ b/.circleci/test-deploy.yml @@ -590,44 +590,12 @@ workflows: context: [CPE-OIDC] wait_task_stopped: true exit_code_from: sleep - - aws-ecs/run_task: - name: ec2_run_task_and_wait_too_long_task-test - auth: - - aws-cli/setup: - role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" - filters: *filters - requires: - - ec2_set-up-run_task-test - cluster: "${AWS_RESOURCE_NAME_PREFIX_EC2}-cluster" - task_definition: "${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360" - overrides: '{"containerOverrides": [{"name": "sleep","command": ["sleep", "700"]}]}' - launch_type: "EC2" - awsvpc: false - context: [CPE-OIDC] - wait_task_stopped: true - - aws-ecs/run_task: - name: ec2_run_task_and_wait_failure-test - auth: - - aws-cli/setup: - role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST" - filters: *filters - requires: - - ec2_set-up-run_task-test - cluster: "${AWS_RESOURCE_NAME_PREFIX_EC2}-cluster" - task_definition: "${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360" - overrides: '{"containerOverrides": [{"name": "sleep","command": ["exit", "127"]}]}' - launch_type: "EC2" - awsvpc: false - context: [CPE-OIDC] - wait_task_stopped: true - tear-down-run_task-test: name: ec2_tear-down-run_task-test filters: *filters requires: - ec2_run_task-test - ec2_run_task_and_wait-test - - ec2_run_task_and_wait_too_long_task-test: failed - - ec2_run_task_and_wait_failure-test: failed family_name: ${AWS_RESOURCE_NAME_PREFIX_EC2}-sleep360 context: [CPE-OIDC] role_arn: "arn:aws:iam::122211685980:role/CPE_ECS_OIDC_TEST"