mirror of
https://github.com/opentofu/opentofu.git
synced 2025-02-25 18:45:20 -06:00
added test
This commit is contained in:
parent
14b7dd3477
commit
7f9c4e45ea
@ -97,6 +97,7 @@ func Provider() terraform.ResourceProvider {
|
|||||||
"aws_ecs_task_definition": resourceAwsEcsTaskDefinition(),
|
"aws_ecs_task_definition": resourceAwsEcsTaskDefinition(),
|
||||||
"aws_eip": resourceAwsEip(),
|
"aws_eip": resourceAwsEip(),
|
||||||
"aws_elasticache_cluster": resourceAwsElasticacheCluster(),
|
"aws_elasticache_cluster": resourceAwsElasticacheCluster(),
|
||||||
|
"aws_elasticache_parameter_group": resourceAwsElasticacheParameterGroup(),
|
||||||
"aws_elasticache_security_group": resourceAwsElasticacheSecurityGroup(),
|
"aws_elasticache_security_group": resourceAwsElasticacheSecurityGroup(),
|
||||||
"aws_elasticache_subnet_group": resourceAwsElasticacheSubnetGroup(),
|
"aws_elasticache_subnet_group": resourceAwsElasticacheSubnetGroup(),
|
||||||
"aws_elb": resourceAwsElb(),
|
"aws_elb": resourceAwsElb(),
|
||||||
|
@ -4,7 +4,6 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"strings"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/hashicorp/terraform/helper/hashcode"
|
"github.com/hashicorp/terraform/helper/hashcode"
|
||||||
@ -52,19 +51,6 @@ func resourceAwsElasticacheParameterGroup() *schema.Resource {
|
|||||||
Type: schema.TypeString,
|
Type: schema.TypeString,
|
||||||
Required: true,
|
Required: true,
|
||||||
},
|
},
|
||||||
"apply_method": &schema.Schema{
|
|
||||||
Type: schema.TypeString,
|
|
||||||
Optional: true,
|
|
||||||
Default: "immediate",
|
|
||||||
// this parameter is not actually state, but a
|
|
||||||
// meta-parameter describing how the RDS API call
|
|
||||||
// to modify the parameter group should be made.
|
|
||||||
// Future reads of the resource from AWS don't tell
|
|
||||||
// us what we used for apply_method previously, so
|
|
||||||
// by squashing state to an empty string we avoid
|
|
||||||
// needing to do an update for every future run.
|
|
||||||
StateFunc: func(interface{}) string { return "" },
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Set: resourceAwsElasticacheParameterHash,
|
Set: resourceAwsElasticacheParameterHash,
|
||||||
@ -222,8 +208,7 @@ func resourceAwsElasticacheParameterHash(v interface{}) int {
|
|||||||
var buf bytes.Buffer
|
var buf bytes.Buffer
|
||||||
m := v.(map[string]interface{})
|
m := v.(map[string]interface{})
|
||||||
buf.WriteString(fmt.Sprintf("%s-", m["name"].(string)))
|
buf.WriteString(fmt.Sprintf("%s-", m["name"].(string)))
|
||||||
// Store the value as a lower case string, to match how we store them in flattenParameters
|
buf.WriteString(fmt.Sprintf("%s-", m["value"].(string)))
|
||||||
buf.WriteString(fmt.Sprintf("%s-", strings.ToLower(m["value"].(string))))
|
|
||||||
|
|
||||||
return hashcode.String(buf.String())
|
return hashcode.String(buf.String())
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,210 @@
|
|||||||
|
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/elasticache"
|
||||||
|
"github.com/hashicorp/terraform/helper/resource"
|
||||||
|
"github.com/hashicorp/terraform/terraform"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestAccAWSElasticacheParameterGroup_basic(t *testing.T) {
|
||||||
|
var v elasticache.CacheParameterGroup
|
||||||
|
|
||||||
|
resource.Test(t, resource.TestCase{
|
||||||
|
PreCheck: func() { testAccPreCheck(t) },
|
||||||
|
Providers: testAccProviders,
|
||||||
|
CheckDestroy: testAccCheckAWSElasticacheParameterGroupDestroy,
|
||||||
|
Steps: []resource.TestStep{
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccAWSElasticacheParameterGroupConfig,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckAWSElasticacheParameterGroupExists("aws_elasticache_parameter_group.bar", &v),
|
||||||
|
testAccCheckAWSElasticacheParameterGroupAttributes(&v),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "name", "parameter-group-test-terraform"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "family", "redis2.8"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "description", "Test parameter group for terraform"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.283487565.name", "appendonly"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.283487565.value", "yes"),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccAWSElasticacheParameterGroupAddParametersConfig,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckAWSElasticacheParameterGroupExists("aws_elasticache_parameter_group.bar", &v),
|
||||||
|
testAccCheckAWSElasticacheParameterGroupAttributes(&v),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "name", "parameter-group-test-terraform"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "family", "redis2.8"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "description", "Test parameter group for terraform"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.283487565.name", "appendonly"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.283487565.value", "yes"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.2196914567.name", "appendfsync"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "parameter.2196914567.value", "always"),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestAccAWSElasticacheParameterGroupOnly(t *testing.T) {
|
||||||
|
var v elasticache.CacheParameterGroup
|
||||||
|
|
||||||
|
resource.Test(t, resource.TestCase{
|
||||||
|
PreCheck: func() { testAccPreCheck(t) },
|
||||||
|
Providers: testAccProviders,
|
||||||
|
CheckDestroy: testAccCheckAWSElasticacheParameterGroupDestroy,
|
||||||
|
Steps: []resource.TestStep{
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccAWSElasticacheParameterGroupOnlyConfig,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckAWSElasticacheParameterGroupExists("aws_elasticache_parameter_group.bar", &v),
|
||||||
|
testAccCheckAWSElasticacheParameterGroupAttributes(&v),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "name", "parameter-group-test-terraform"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "family", "redis2.8"),
|
||||||
|
resource.TestCheckResourceAttr(
|
||||||
|
"aws_elasticache_parameter_group.bar", "description", "Test parameter group for terraform"),
|
||||||
|
),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckAWSElasticacheParameterGroupDestroy(s *terraform.State) error {
|
||||||
|
conn := testAccProvider.Meta().(*AWSClient).elasticacheconn
|
||||||
|
|
||||||
|
for _, rs := range s.RootModule().Resources {
|
||||||
|
if rs.Type != "aws_elasticache_parameter_group" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
// Try to find the Group
|
||||||
|
resp, err := conn.DescribeCacheParameterGroups(
|
||||||
|
&elasticache.DescribeCacheParameterGroupsInput{
|
||||||
|
CacheParameterGroupName: aws.String(rs.Primary.ID),
|
||||||
|
})
|
||||||
|
|
||||||
|
if err == nil {
|
||||||
|
if len(resp.CacheParameterGroups) != 0 &&
|
||||||
|
*resp.CacheParameterGroups[0].CacheParameterGroupName == rs.Primary.ID {
|
||||||
|
return fmt.Errorf("Cache Parameter Group still exists")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Verify the error
|
||||||
|
newerr, ok := err.(awserr.Error)
|
||||||
|
if !ok {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if newerr.Code() != "InvalidCacheParameterGroup.NotFound" {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckAWSElasticacheParameterGroupAttributes(v *elasticache.CacheParameterGroup) resource.TestCheckFunc {
|
||||||
|
return func(s *terraform.State) error {
|
||||||
|
|
||||||
|
if *v.CacheParameterGroupName != "parameter-group-test-terraform" {
|
||||||
|
return fmt.Errorf("bad name: %#v", v.CacheParameterGroupName)
|
||||||
|
}
|
||||||
|
|
||||||
|
if *v.CacheParameterGroupFamily != "redis2.8" {
|
||||||
|
return fmt.Errorf("bad family: %#v", v.CacheParameterGroupFamily)
|
||||||
|
}
|
||||||
|
|
||||||
|
if *v.Description != "Test parameter group for terraform" {
|
||||||
|
return fmt.Errorf("bad description: %#v", v.Description)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func testAccCheckAWSElasticacheParameterGroupExists(n string, v *elasticache.CacheParameterGroup) 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 Cache Parameter Group ID is set")
|
||||||
|
}
|
||||||
|
|
||||||
|
conn := testAccProvider.Meta().(*AWSClient).elasticacheconn
|
||||||
|
|
||||||
|
opts := elasticache.DescribeCacheParameterGroupsInput{
|
||||||
|
CacheParameterGroupName: aws.String(rs.Primary.ID),
|
||||||
|
}
|
||||||
|
|
||||||
|
resp, err := conn.DescribeCacheParameterGroups(&opts)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(resp.CacheParameterGroups) != 1 ||
|
||||||
|
*resp.CacheParameterGroups[0].CacheParameterGroupName != rs.Primary.ID {
|
||||||
|
return fmt.Errorf("Cache Parameter Group not found")
|
||||||
|
}
|
||||||
|
|
||||||
|
*v = *resp.CacheParameterGroups[0]
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const testAccAWSElasticacheParameterGroupConfig = `
|
||||||
|
resource "aws_elasticache_parameter_group" "bar" {
|
||||||
|
name = "parameter-group-test-terraform"
|
||||||
|
family = "redis2.8"
|
||||||
|
description = "Test parameter group for terraform"
|
||||||
|
parameter {
|
||||||
|
name = "appendonly"
|
||||||
|
value = "yes"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
const testAccAWSElasticacheParameterGroupAddParametersConfig = `
|
||||||
|
resource "aws_elasticache_parameter_group" "bar" {
|
||||||
|
name = "parameter-group-test-terraform"
|
||||||
|
family = "redis2.8"
|
||||||
|
description = "Test parameter group for terraform"
|
||||||
|
parameter {
|
||||||
|
name = "appendonly"
|
||||||
|
value = "yes"
|
||||||
|
}
|
||||||
|
parameter {
|
||||||
|
name = "appendfsync"
|
||||||
|
value = "always"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
const testAccAWSElasticacheParameterGroupOnlyConfig = `
|
||||||
|
resource "aws_elasticache_parameter_group" "bar" {
|
||||||
|
name = "parameter-group-test-terraform"
|
||||||
|
family = "redis2.8"
|
||||||
|
description = "Test parameter group for terraform"
|
||||||
|
}
|
||||||
|
`
|
Loading…
Reference in New Issue
Block a user