|
1 | 1 | package route53resolver_test
|
2 | 2 |
|
3 | 3 | import (
|
4 |
| - "regexp" |
| 4 | + "fmt" |
5 | 5 | "testing"
|
6 | 6 |
|
7 | 7 | "github.com/aws/aws-sdk-go/service/route53resolver"
|
| 8 | + sdkacctest "github.com/hashicorp/terraform-plugin-sdk/v2/helper/acctest" |
8 | 9 | "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource"
|
9 | 10 | "github.com/hashicorp/terraform-provider-aws/internal/acctest"
|
10 | 11 | )
|
11 | 12 |
|
12 | 13 | func TestAccRoute53ResolverFirewallRuleGroupDataSource_basic(t *testing.T) {
|
| 14 | + rName := sdkacctest.RandomWithPrefix(acctest.ResourcePrefix) |
13 | 15 | dataSourceName := "data.aws_route53_resolver_firewall_rule_group.test"
|
| 16 | + resourceName := "aws_route53_resolver_firewall_rule_group.test" |
14 | 17 |
|
15 | 18 | resource.Test(t, resource.TestCase{
|
16 | 19 | PreCheck: func() { acctest.PreCheck(t); testAccPreCheck(t) },
|
17 | 20 | ErrorCheck: acctest.ErrorCheck(t, route53resolver.EndpointsID),
|
18 | 21 | ProtoV5ProviderFactories: acctest.ProtoV5ProviderFactories,
|
19 | 22 | Steps: []resource.TestStep{
|
20 | 23 | {
|
21 |
| - Config: testAccFirewallRuleGroupDataSourceConfig_basic(), |
22 |
| - Check: resource.ComposeTestCheckFunc( |
23 |
| - resource.TestCheckResourceAttrSet(dataSourceName, "id"), |
24 |
| - acctest.MatchResourceAttrRegionalARN(dataSourceName, "arn", "route53resolver", regexp.MustCompile(`firewall-rule-group/.+`)), |
| 24 | + Config: testAccFirewallRuleGroupDataSourceConfig_basic(rName), |
| 25 | + Check: resource.ComposeAggregateTestCheckFunc( |
| 26 | + resource.TestCheckResourceAttrPair(dataSourceName, "arn", resourceName, "arn"), |
| 27 | + resource.TestCheckResourceAttrPair(dataSourceName, "firewall_rule_group_id", resourceName, "id"), |
25 | 28 | resource.TestCheckResourceAttrSet(dataSourceName, "creation_time"),
|
26 | 29 | resource.TestCheckResourceAttrSet(dataSourceName, "creator_request_id"),
|
27 | 30 | resource.TestCheckResourceAttrSet(dataSourceName, "modification_time"),
|
28 |
| - resource.TestCheckResourceAttrSet(dataSourceName, "name"), |
29 |
| - resource.TestCheckResourceAttrSet(dataSourceName, "owner_id"), |
30 |
| - resource.TestCheckResourceAttrSet(dataSourceName, "rule_count"), |
31 |
| - resource.TestMatchResourceAttr(dataSourceName, "status", regexp.MustCompile(`COMPLETE|DELETING|UPDATING`)), |
32 |
| - resource.TestMatchResourceAttr(dataSourceName, "share_status", regexp.MustCompile(`NOT_SHARED|SHARED_WITH_ME|SHARED_BY_ME`)), |
| 31 | + resource.TestCheckResourceAttrPair(dataSourceName, "name", resourceName, "name"), |
| 32 | + resource.TestCheckResourceAttrPair(dataSourceName, "owner_id", resourceName, "owner_id"), |
| 33 | + resource.TestCheckResourceAttr(dataSourceName, "rule_count", "0"), |
| 34 | + resource.TestCheckResourceAttrPair(dataSourceName, "share_status", resourceName, "share_status"), |
| 35 | + resource.TestCheckResourceAttrSet(dataSourceName, "status"), |
33 | 36 | resource.TestCheckResourceAttrSet(dataSourceName, "status_message"),
|
34 | 37 | ),
|
35 | 38 | },
|
36 | 39 | },
|
37 | 40 | })
|
38 | 41 | }
|
39 | 42 |
|
40 |
| -func testAccFirewallRuleGroupDataSourceConfig_basic() string { |
41 |
| - return ` |
| 43 | +func testAccFirewallRuleGroupDataSourceConfig_basic(rName string) string { |
| 44 | + return fmt.Sprintf(` |
42 | 45 | resource "aws_route53_resolver_firewall_rule_group" "test" {
|
43 |
| - name = "test" |
| 46 | + name = %[1]q |
44 | 47 | }
|
45 | 48 |
|
46 | 49 | data "aws_route53_resolver_firewall_rule_group" "test" {
|
47 |
| - id = aws_route53_resolver_firewall_rule_group.test.id |
| 50 | + firewall_rule_group_id = aws_route53_resolver_firewall_rule_group.test.id |
48 | 51 | }
|
49 |
| -
|
50 |
| -` |
| 52 | +`, rName) |
51 | 53 | }
|
0 commit comments