mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-09 23:54:17 -06:00
2505b2e35f
* Add support for Kinesis streams shard-level metrics * Add test case for flattenKinesisShardLevelMetrics * Document new shard_level_metrics field
308 lines
8.6 KiB
Go
308 lines
8.6 KiB
Go
package aws
|
|
|
|
import (
|
|
"fmt"
|
|
"math/rand"
|
|
"strconv"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/aws/aws-sdk-go/aws"
|
|
"github.com/aws/aws-sdk-go/service/kinesis"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
)
|
|
|
|
func TestAccAWSKinesisStream_basic(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
config := fmt.Sprintf(testAccKinesisStreamConfig, rand.New(rand.NewSource(time.Now().UnixNano())).Int())
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
resource.TestStep{
|
|
Config: config,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccAWSKinesisStream_shardCount(t *testing.T) {
|
|
var stream kinesis.StreamDescription
|
|
|
|
ri := rand.New(rand.NewSource(time.Now().UnixNano())).Int()
|
|
config := fmt.Sprintf(testAccKinesisStreamConfig, ri)
|
|
updateConfig := fmt.Sprintf(testAccKinesisStreamConfigUpdateShardCount, ri)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
resource.TestStep{
|
|
Config: config,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_count", "2"),
|
|
),
|
|
},
|
|
|
|
resource.TestStep{
|
|
Config: updateConfig,
|
|
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
|
|
|
|
ri := rand.New(rand.NewSource(time.Now().UnixNano())).Int()
|
|
config := fmt.Sprintf(testAccKinesisStreamConfig, ri)
|
|
updateConfig := fmt.Sprintf(testAccKinesisStreamConfigUpdateRetentionPeriod, ri)
|
|
decreaseConfig := fmt.Sprintf(testAccKinesisStreamConfigDecreaseRetentionPeriod, ri)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
resource.TestStep{
|
|
Config: config,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "retention_period", "24"),
|
|
),
|
|
},
|
|
|
|
resource.TestStep{
|
|
Config: updateConfig,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "retention_period", "100"),
|
|
),
|
|
},
|
|
|
|
resource.TestStep{
|
|
Config: decreaseConfig,
|
|
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
|
|
|
|
ri := rand.New(rand.NewSource(time.Now().UnixNano())).Int()
|
|
config := fmt.Sprintf(testAccKinesisStreamConfig, ri)
|
|
allConfig := fmt.Sprintf(testAccKinesisStreamConfigAllShardLevelMetrics, ri)
|
|
singleConfig := fmt.Sprintf(testAccKinesisStreamConfigSingleShardLevelMetric, ri)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccCheckKinesisStreamDestroy,
|
|
Steps: []resource.TestStep{
|
|
resource.TestStep{
|
|
Config: config,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_level_metrics.#", ""),
|
|
),
|
|
},
|
|
|
|
resource.TestStep{
|
|
Config: allConfig,
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckKinesisStreamExists("aws_kinesis_stream.test_stream", &stream),
|
|
testAccCheckAWSKinesisStreamAttributes(&stream),
|
|
resource.TestCheckResourceAttr(
|
|
"aws_kinesis_stream.test_stream", "shard_level_metrics.#", "7"),
|
|
),
|
|
},
|
|
|
|
resource.TestStep{
|
|
Config: singleConfig,
|
|
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
|
|
}
|
|
|
|
var testAccKinesisStreamConfig = `
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}
|
|
`
|
|
|
|
var testAccKinesisStreamConfigUpdateShardCount = `
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 4
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}
|
|
`
|
|
|
|
var testAccKinesisStreamConfigUpdateRetentionPeriod = `
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
retention_period = 100
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}
|
|
`
|
|
|
|
var testAccKinesisStreamConfigDecreaseRetentionPeriod = `
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
retention_period = 28
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
}
|
|
`
|
|
|
|
var testAccKinesisStreamConfigAllShardLevelMetrics = `
|
|
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"
|
|
]
|
|
}
|
|
`
|
|
|
|
var testAccKinesisStreamConfigSingleShardLevelMetric = `
|
|
resource "aws_kinesis_stream" "test_stream" {
|
|
name = "terraform-kinesis-test-%d"
|
|
shard_count = 2
|
|
tags {
|
|
Name = "tf-test"
|
|
}
|
|
shard_level_metrics = [
|
|
"IncomingBytes"
|
|
]
|
|
}
|
|
`
|