github.com/swisspost/terratest@v0.0.0-20230214120104-7ec6de2e1ae0/test/azure/terraform_azure_storage_example_test.go (about) 1 //go:build azure 2 // +build azure 3 4 // NOTE: We use build tags to differentiate azure testing because we currently do not have azure access setup for 5 // CircleCI. 6 7 package test 8 9 import ( 10 "fmt" 11 "strings" 12 "testing" 13 14 "github.com/gruntwork-io/terratest/modules/azure" 15 "github.com/gruntwork-io/terratest/modules/random" 16 "github.com/gruntwork-io/terratest/modules/terraform" 17 "github.com/stretchr/testify/assert" 18 ) 19 20 func TestTerraformAzureStorageExample(t *testing.T) { 21 t.Parallel() 22 23 // subscriptionID is overridden by the environment variable "ARM_SUBSCRIPTION_ID" 24 subscriptionID := "" 25 uniquePostfix := random.UniqueId() 26 27 // website::tag::1:: Configure Terraform setting up a path to Terraform code. 28 terraformOptions := &terraform.Options{ 29 // The path to where our Terraform code is located 30 TerraformDir: "../../examples/azure/terraform-azure-storage-example", 31 32 // Variables to pass to our Terraform code using -var options 33 Vars: map[string]interface{}{ 34 "postfix": strings.ToLower(uniquePostfix), 35 }, 36 } 37 38 // website::tag::4:: At the end of the test, run `terraform destroy` to clean up any resources that were created 39 defer terraform.Destroy(t, terraformOptions) 40 41 // website::tag::2:: Run `terraform init` and `terraform apply`. Fail the test if there are any errors. 42 terraform.InitAndApply(t, terraformOptions) 43 44 // website::tag::3:: Run `terraform output` to get the values of output variables 45 resourceGroupName := terraform.Output(t, terraformOptions, "resource_group_name") 46 storageAccountName := terraform.Output(t, terraformOptions, "storage_account_name") 47 storageAccountTier := terraform.Output(t, terraformOptions, "storage_account_account_tier") 48 storageAccountKind := terraform.Output(t, terraformOptions, "storage_account_account_kind") 49 storageBlobContainerName := terraform.Output(t, terraformOptions, "storage_container_name") 50 51 // website::tag::4:: Verify storage account properties and ensure it matches the output. 52 storageAccountExists := azure.StorageAccountExists(t, storageAccountName, resourceGroupName, subscriptionID) 53 assert.True(t, storageAccountExists, "storage account does not exist") 54 55 containerExists := azure.StorageBlobContainerExists(t, storageBlobContainerName, storageAccountName, resourceGroupName, subscriptionID) 56 assert.True(t, containerExists, "storage container does not exist") 57 58 publicAccess := azure.GetStorageBlobContainerPublicAccess(t, storageBlobContainerName, storageAccountName, resourceGroupName, subscriptionID) 59 assert.False(t, publicAccess, "storage container has public access") 60 61 accountKind := azure.GetStorageAccountKind(t, storageAccountName, resourceGroupName, subscriptionID) 62 assert.Equal(t, storageAccountKind, accountKind, "storage account kind mismatch") 63 64 skuTier := azure.GetStorageAccountSkuTier(t, storageAccountName, resourceGroupName, subscriptionID) 65 assert.Equal(t, storageAccountTier, skuTier, "sku tier mismatch") 66 67 actualDNSString := azure.GetStorageDNSString(t, storageAccountName, resourceGroupName, subscriptionID) 68 storageSuffix, _ := azure.GetStorageURISuffixE() 69 expectedDNS := fmt.Sprintf("https://%s.blob.%s/", storageAccountName, storageSuffix) 70 assert.Equal(t, expectedDNS, actualDNSString, "Storage DNS string mismatch") 71 }