mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-08 15:13:56 -06:00
221a88610b
Fixes: #14260 ``` % make testacc TEST=./builtin/providers/aws TESTARGS='-run=TestAccAWSKinesisStream_import' ==> Checking that code complies with gofmt requirements... go generate $(go list ./... | grep -v /terraform/vendor/) 2017/05/08 10:32:47 Generated command/internal_plugin_list.go TF_ACC=1 go test ./builtin/providers/aws -v -run=TestAccAWSKinesisStream_import -timeout 120m === RUN TestAccAWSKinesisStream_importBasic --- PASS: TestAccAWSKinesisStream_importBasic (101.93s) PASS ok github.com/hashicorp/terraform/builtin/providers/aws 101.978s ```
329 lines
8.9 KiB
Go
329 lines
8.9 KiB
Go
package aws
|
|
|
|
import (
|
|
"fmt"
|
|
"strconv"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
"github.com/aws/aws-sdk-go/service/kinesis"
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func TestAccAWSKinesisStream_basic(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
rInt := acctest.RandInt()
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccKinesisStreamConfig(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSKinesisStream_importBasic(t *testing.T) {
|
|
rInt := acctest.RandInt()
|
|
resourceName := "aws_kinesis_stream.test_stream"
|
|
streamName := fmt.Sprintf("terraform-kinesis-test-%d", rInt)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccKinesisStreamConfig(rInt),
|
|
},
|
|
|
|
{
|
|
ResourceName: resourceName,
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
ImportStateId: streamName,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSKinesisStream_shardCount(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
rInt := acctest.RandInt()
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccKinesisStreamConfig(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_count", "2"),
|
|
),
|
|
},
|
|
|
|
{
|
|
Config: testAccKinesisStreamConfigUpdateShardCount(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_count", "4"),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSKinesisStream_retentionPeriod(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
rInt := acctest.RandInt()
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccKinesisStreamConfig(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "retention_period", "24"),
|
|
),
|
|
},
|
|
|
|
{
|
|
Config: testAccKinesisStreamConfigUpdateRetentionPeriod(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "retention_period", "100"),
|
|
),
|
|
},
|
|
|
|
{
|
|
Config: testAccKinesisStreamConfigDecreaseRetentionPeriod(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "retention_period", "28"),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSKinesisStream_shardLevelMetrics(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
rInt := acctest.RandInt()
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
{
|
|
Config: testAccKinesisStreamConfig(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckNoResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_level_metrics"),
|
|
),
|
|
},
|
|
|
|
{
|
|
Config: testAccKinesisStreamConfigAllShardLevelMetrics(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_level_metrics.#", "7"),
|
|
),
|
|
},
|
|
|
|
{
|
|
Config: testAccKinesisStreamConfigSingleShardLevelMetric(rInt),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_level_metrics.#", "1"),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func testAccCheckKinesisStreamExists(n string, stream *kinesis.StreamDescription) 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 Kinesis ID is set")
|
|
}
|
|
|
|
conn := testAccProvider.Meta().(*AWSClient).kinesisconn
|
|
describeOpts := &kinesis.DescribeStreamInput{
|
|
StreamName: aws.String(rs.Primary.Attributes["name"]),
|
|
}
|
|
resp, err := conn.DescribeStream(describeOpts)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
*stream = *resp.StreamDescription
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccCheckAWSKinesisStreamAttributes(stream *kinesis.StreamDescription) resource.TestCheckFunc {
|
|
return func(s *terraform.State) error {
|
|
if !strings.HasPrefix(*stream.StreamName, "terraform-kinesis-test") {
|
|
return fmt.Errorf("Bad Stream name: %s", *stream.StreamName)
|
|
}
|
|
for _, rs := range s.RootModule().Resources {
|
|
if rs.Type != "aws_kinesis_stream" {
|
|
continue
|
|
}
|
|
if *stream.StreamARN != rs.Primary.Attributes["arn"] {
|
|
return fmt.Errorf("Bad Stream ARN\n\t expected: %s\n\tgot: %s\n", rs.Primary.Attributes["arn"], *stream.StreamARN)
|
|
}
|
|
shard_count := strconv.Itoa(len(stream.Shards))
|
|
if shard_count != rs.Primary.Attributes["shard_count"] {
|
|
return fmt.Errorf("Bad Stream Shard Count\n\t expected: %s\n\tgot: %s\n", rs.Primary.Attributes["shard_count"], shard_count)
|
|
}
|
|
}
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func testAccCheckKinesisStreamDestroy(s *terraform.State) error {
|
|
for _, rs := range s.RootModule().Resources {
|
|
if rs.Type != "aws_kinesis_stream" {
|
|
continue
|
|
}
|
|
conn := testAccProvider.Meta().(*AWSClient).kinesisconn
|
|
describeOpts := &kinesis.DescribeStreamInput{
|
|
StreamName: aws.String(rs.Primary.Attributes["name"]),
|
|
}
|
|
resp, err := conn.DescribeStream(describeOpts)
|
|
if err == nil {
|
|
if resp.StreamDescription != nil && *resp.StreamDescription.StreamStatus != "DELETING" {
|
|
return fmt.Errorf("Error: Stream still exists")
|
|
}
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func testAccKinesisStreamConfig(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}`, rInt)
|
|
}
|
|
|
|
func testAccKinesisStreamConfigUpdateShardCount(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 4
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}`, rInt)
|
|
}
|
|
|
|
func testAccKinesisStreamConfigUpdateRetentionPeriod(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
retention_period = 100
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}`, rInt)
|
|
}
|
|
|
|
func testAccKinesisStreamConfigDecreaseRetentionPeriod(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
retention_period = 28
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}`, rInt)
|
|
}
|
|
|
|
func testAccKinesisStreamConfigAllShardLevelMetrics(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
shard_level_metrics = [
|
|
"IncomingBytes",
|
|
"IncomingRecords",
|
|
"OutgoingBytes",
|
|
"OutgoingRecords",
|
|
"WriteProvisionedThroughputExceeded",
|
|
"ReadProvisionedThroughputExceeded",
|
|
"IteratorAgeMilliseconds"
|
|
]
|
|
}`, rInt)
|
|
}
|
|
|
|
func testAccKinesisStreamConfigSingleShardLevelMetric(rInt int) string {
|
|
return fmt.Sprintf(`
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
shard_level_metrics = [
|
|
"IncomingBytes"
|
|
]
|
|
}`, rInt)
|
|
}
|