From 076ebcc6af190b6e3f60cb0480eabf30300d762d Mon Sep 17 00:00:00 2001 From: Kobi Samoray Date: Tue, 28 Feb 2023 10:24:46 +0200 Subject: [PATCH] Randomize FQDN --- ...licy_context_profile_custom_attribute_test.go | 16 ++++++++++++++-- .../resource_nsxt_policy_context_profile_test.go | 10 +++++++--- nsxt/utils_test.go | 10 ++++++++++ .../docs/r/policy_context_profile.html.markdown | 2 +- 4 files changed, 32 insertions(+), 6 deletions(-) diff --git a/nsxt/resource_nsxt_policy_context_profile_custom_attribute_test.go b/nsxt/resource_nsxt_policy_context_profile_custom_attribute_test.go index ad8d9ebf5..e8587bcfd 100644 --- a/nsxt/resource_nsxt_policy_context_profile_custom_attribute_test.go +++ b/nsxt/resource_nsxt_policy_context_profile_custom_attribute_test.go @@ -111,9 +111,21 @@ func testAccNsxtPolicyContextProfileCustomAttributeCheckDestroy(state *terraform } func testAccNsxtPolicyContextProfileCustomAttributeTemplate() string { + return testAccNsxtPolicyContextProfileCustomAttributeArgTemplate( + accTestPolicyContextProfileCustomAttributeAttributes["key"], + accTestPolicyContextProfileCustomAttributeAttributes["attribute"]) +} + +func testAccNsxtPolicyContextProfileCustomRandomAttributeTemplate() string { + return testAccNsxtPolicyContextProfileCustomAttributeArgTemplate( + accTestPolicyContextProfileCustomAttributeAttributes["key"], + getAccTestFQDN()) +} + +func testAccNsxtPolicyContextProfileCustomAttributeArgTemplate(key string, attribute string) string { return fmt.Sprintf(` resource "nsxt_policy_context_profile_custom_attribute" "test" { key = "%s" attribute = "%s" -}`, accTestPolicyContextProfileCustomAttributeAttributes["key"], accTestPolicyContextProfileCustomAttributeAttributes["attribute"]) -} +}`, key, attribute) +} \ No newline at end of file diff --git a/nsxt/resource_nsxt_policy_context_profile_test.go b/nsxt/resource_nsxt_policy_context_profile_test.go index 59df396c3..8ed72869d 100644 --- a/nsxt/resource_nsxt_policy_context_profile_test.go +++ b/nsxt/resource_nsxt_policy_context_profile_test.go @@ -5,6 +5,7 @@ package nsxt import ( "fmt" + "log" "testing" "github.com/hashicorp/terraform-plugin-sdk/v2/helper/resource" @@ -72,8 +73,11 @@ func TestAccResourceNsxtPolicyContextProfile_basic(t *testing.T) { func TestAccResourceNsxtPolicyContextProfile_CustomDomain(t *testing.T) { name := getAccTestResourceName() testResourceName := "nsxt_policy_context_profile.test" - attributes := testAccNsxtPolicyContextProfileAttributeDomainNameTemplate(accTestPolicyContextProfileCustomAttributeAttributes["attribute"]) + fqdn := getAccTestFQDN() + attributes := testAccNsxtPolicyContextProfileAttributeDomainNameTemplate(fqdn) dependsOn := testAccNsxtPolicyContextProfileDependsOnTemplate("nsxt_policy_context_profile_custom_attribute.test") + s := testAccNsxtPolicyContextProfileCustomAttributeArgTemplate(accTestPolicyContextProfileCustomAttributeAttributes["key"], fqdn) + testAccNsxtPolicyContextProfileTemplate(name, attributes+dependsOn) + log.Printf("--> Execution code:\n%s", s) resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t); testAccNSXVersion(t, "3.0.0") }, Providers: testAccProviders, @@ -82,7 +86,7 @@ func TestAccResourceNsxtPolicyContextProfile_CustomDomain(t *testing.T) { }, Steps: []resource.TestStep{ { - Config: testAccNsxtPolicyContextProfileCustomAttributeTemplate() + testAccNsxtPolicyContextProfileTemplate(name, attributes+dependsOn), + Config: s, Check: resource.ComposeTestCheckFunc( testAccNsxtPolicyContextProfileExists(testResourceName), resource.TestCheckResourceAttr(testResourceName, "display_name", name), @@ -95,7 +99,7 @@ func TestAccResourceNsxtPolicyContextProfile_CustomDomain(t *testing.T) { resource.TestCheckResourceAttr(testResourceName, "domain_name.#", "1"), resource.TestCheckResourceAttr(testResourceName, "url_category.#", "0"), resource.TestCheckResourceAttr(testResourceName, "domain_name.0.value.#", "1"), - resource.TestCheckResourceAttr(testResourceName, "domain_name.0.value.0", accTestPolicyContextProfileCustomAttributeAttributes["attribute"]), + resource.TestCheckResourceAttr(testResourceName, "domain_name.0.value.0", fqdn), ), }, }, diff --git a/nsxt/utils_test.go b/nsxt/utils_test.go index 869832813..c36f5371e 100644 --- a/nsxt/utils_test.go +++ b/nsxt/utils_test.go @@ -52,6 +52,7 @@ const doubleTags string = ` }` var randomized = false +var letterRunes = []rune("abcdefghijklmnopqrstuvwxyz") func initRand() { if randomized { @@ -71,6 +72,15 @@ func getAccTestResourceName() string { return fmt.Sprintf("%s-%d", testAccResourceName, rand.Intn(100000)) } +func getAccTestFQDN() string { + initRand() + b := make([]rune, 10) + for i := range b { + b[i] = letterRunes[rand.Intn(len(letterRunes))] + } + return fmt.Sprintf("test.%s.org", string(b)) +} + func getTier0RouterName() string { name := os.Getenv("NSXT_TEST_TIER0_ROUTER") if name == "" { diff --git a/website/docs/r/policy_context_profile.html.markdown b/website/docs/r/policy_context_profile.html.markdown index 77d419a9e..5168305de 100644 --- a/website/docs/r/policy_context_profile.html.markdown +++ b/website/docs/r/policy_context_profile.html.markdown @@ -45,7 +45,7 @@ resource "nsxt_policy_context_profile" "test2" { custom_url { value = ["test.some.org"] } - depends_on = ["nsxt_policy_context_profile_custom_attribute.test1"] + depends_on = [nsxt_policy_context_profile_custom_attribute.test1] } ```