opentofu/builtin/providers/aws/resource_aws_sfn_state_machine_test.go
Gauthier Wallet 4da1451971 Added Step Function resources (State Machine & Activity) (#11420)
* Added Step Function Activity & Step Function State Machine

* Added SFN State Machine documentation

* Added aws_sfn_activity & documentation

* Allowed import of sfn resources

* Added more checks on tests, fixed documentation

* Handled the update case of a SFN function (might be already deleting)

* Removed the State Machine import test file

* Fixed the eventual consistency of the read after delete for SFN functions
2017-01-31 20:17:38 +00:00

202 lines
4.6 KiB
Go

package aws
import (
"fmt"
"testing"
"github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/awserr"
"github.com/aws/aws-sdk-go/service/sfn"
"github.com/hashicorp/terraform/helper/acctest"
"github.com/hashicorp/terraform/helper/resource"
"github.com/hashicorp/terraform/terraform"
)
func TestAccAWSSfnStateMachine_basic(t *testing.T) {
name := acctest.RandString(10)
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccCheckAWSSfnStateMachineDestroy,
Steps: []resource.TestStep{
{
Config: testAccAWSSfnStateMachineBasicConfig(name),
Check: resource.ComposeTestCheckFunc(
testAccCheckAWSSfnExists("aws_sfn_state_machine.foo"),
resource.TestCheckResourceAttr("aws_sfn_state_machine.foo", "status", sfn.StateMachineStatusActive),
resource.TestCheckResourceAttrSet("aws_sfn_state_machine.foo", "name"),
resource.TestCheckResourceAttrSet("aws_sfn_state_machine.foo", "creation_date"),
resource.TestCheckResourceAttrSet("aws_sfn_state_machine.foo", "definition"),
resource.TestCheckResourceAttrSet("aws_sfn_state_machine.foo", "role_arn"),
),
},
},
})
}
func testAccCheckAWSSfnExists(n string) resource.TestCheckFunc {
return func(s *terraform.State) error {
rs, ok := s.RootModule().Resources[n]
if !ok {
return fmt.Errorf("Not found: %s", n)
}
if rs.Primary.ID == "" {
return fmt.Errorf("No Step Function ID set")
}
conn := testAccProvider.Meta().(*AWSClient).sfnconn
_, err := conn.DescribeStateMachine(&sfn.DescribeStateMachineInput{
StateMachineArn: aws.String(rs.Primary.ID),
})
if err != nil {
return err
}
return nil
}
}
func testAccCheckAWSSfnStateMachineDestroy(s *terraform.State) error {
conn := testAccProvider.Meta().(*AWSClient).sfnconn
for _, rs := range s.RootModule().Resources {
if rs.Type != "aws_sfn_state_machine" {
continue
}
out, err := conn.DescribeStateMachine(&sfn.DescribeStateMachineInput{
StateMachineArn: aws.String(rs.Primary.ID),
})
if err != nil {
if wserr, ok := err.(awserr.Error); ok && wserr.Code() == "StateMachineDoesNotExist" {
return nil
}
return err
}
if out != nil && *out.Status != sfn.StateMachineStatusDeleting {
return fmt.Errorf("Expected AWS Step Function State Machine to be destroyed, but was still found")
}
return nil
}
return fmt.Errorf("Default error in Step Function Test")
}
func testAccAWSSfnStateMachineBasicConfig(rName string) string {
return fmt.Sprintf(`
data "aws_region" "current" {
current = true
}
resource "aws_iam_role_policy" "iam_policy_for_lambda" {
name = "iam_policy_for_lambda_%s"
role = "${aws_iam_role.iam_for_lambda.id}"
policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [{
"Effect": "Allow",
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Resource": "arn:aws:logs:*:*:*"
}]
}
EOF
}
resource "aws_iam_role" "iam_for_lambda" {
name = "iam_for_lambda_%s"
assume_role_policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Action": "sts:AssumeRole",
"Principal": {
"Service": "lambda.amazonaws.com"
},
"Effect": "Allow",
"Sid": ""
}
]
}
EOF
}
resource "aws_iam_role_policy" "iam_policy_for_sfn" {
name = "iam_policy_for_sfn_%s"
role = "${aws_iam_role.iam_for_sfn.id}"
policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"lambda:InvokeFunction"
],
"Resource": "*"
}
]
}
EOF
}
resource "aws_iam_role" "iam_for_sfn" {
name = "iam_for_sfn_%s"
assume_role_policy = <<EOF
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Service": "states.${data.aws_region.current.name}.amazonaws.com"
},
"Action": "sts:AssumeRole"
}
]
}
EOF
}
resource "aws_lambda_function" "lambda_function_test" {
filename = "test-fixtures/lambdatest.zip"
function_name = "sfn-%s"
role = "${aws_iam_role.iam_for_lambda.arn}"
handler = "exports.example"
runtime = "nodejs4.3"
}
resource "aws_sfn_state_machine" "foo" {
name = "test_sfn_%s"
role_arn = "${aws_iam_role.iam_for_sfn.arn}"
definition = <<EOF
{
"Comment": "A Hello World example of the Amazon States Language using an AWS Lambda Function",
"StartAt": "HelloWorld",
"States": {
"HelloWorld": {
"Type": "Task",
"Resource": "${aws_lambda_function.lambda_function_test.arn}",
"End": true
}
}
}
EOF
}
`, rName, rName, rName, rName, rName, rName)
}