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  }