Documentation ¶
Index ¶
- Constants
- Variables
- func AddAttrChecks(targetName string, checks []resource.TestCheckFunc, ...) []resource.TestCheckFunc
- func AddAttrChecksPrefix(targetName string, checks []resource.TestCheckFunc, ...) []resource.TestCheckFunc
- func AddAttrChecksPrefixSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, ...) []resource.TestCheckFunc
- func AddAttrChecksSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, ...) []resource.TestCheckFunc
- func AddAttrSetChecks(targetName string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
- func AddAttrSetChecksPrefix(targetName string, checks []resource.TestCheckFunc, attrNames []string, ...) []resource.TestCheckFunc
- func AddAttrSetChecksSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
- func AddNoAttrSetChecks(targetName string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
- func AssertEqualHCL(t *testing.T, expected, actual string, msgAndArgs ...interface{})
- func AttrNameToSchemaV2(isAcc bool, name string) string
- func CIDRBlockExpression() resource.CheckResourceAttrWithFunc
- func CheckDestroyCluster(s *terraform.State) error
- func CheckDestroyFederatedDatabaseInstance(s *terraform.State) error
- func CheckDestroyNetworkPeering(s *terraform.State) error
- func CheckDestroyOrgInvitation(s *terraform.State) error
- func CheckDestroyProject(s *terraform.State) error
- func CheckDestroyProjectGov(s *terraform.State) error
- func CheckDestroySearchIndex(state *terraform.State) error
- func CheckDestroyStreamInstance(state *terraform.State) error
- func CheckDestroyTeam(s *terraform.State) error
- func CheckEARExists(resourceName string) resource.TestCheckFunc
- func CheckExistsCluster(resourceName string) resource.TestCheckFunc
- func CheckExistsClusterHandlingRetry(projectID, clusterName string) error
- func CheckFCVPinningConfig(isAcc bool, resourceName, dataSourceName, pluralDataSourceName string, ...) resource.TestCheckFunc
- func CheckIndependentShardScalingMode(resourceName, clusterName, expectedMode string) resource.TestCheckFunc
- func CheckRSAndDS(resourceName string, dataSourceName, pluralDataSourceName *string, ...) resource.TestCheckFunc
- func CheckRSAndDSSchemaV2(isAcc bool, resourceName string, dataSourceName, pluralDataSourceName *string, ...) resource.TestCheckFunc
- func ClusterDatasourceHcl(req *ClusterRequest) (configStr, clusterName, resourceName string, err error)
- func ClusterNameExecution(tb testing.TB, populateSampleData bool) (projectID, clusterName string)
- func ClusterResourceHcl(req *ClusterRequest) (configStr, clusterName, resourceName string, err error)
- func ConfigAzapiProvider(subscriptionID, clientID, clientSecret, tenantID string) string
- func ConfigConfluentProvider() string
- func ConfigDataBaseUserWithOIDCAuthType(projectID, username, authType, databaseName, roleName string) string
- func ConfigDataConfluentDedicatedCluster(networkID, privatelinkAccessID string) string
- func ConfigDatabaseUserBasic(projectID, username, roleName, keyLabel, valueLabel string) string
- func ConfigDatabaseUserWithAWSIAMType(projectID, username, roleName, keyLabel, valueLabel string) string
- func ConfigDatabaseUserWithLDAPAuthType(projectID, username, roleName, keyLabel, valueLabel string) string
- func ConfigDatabaseUserWithLabels(projectID, username, roleName string, labels []admin.ComponentLabel) string
- func ConfigDatabaseUserWithRoles(projectID, username, password string, rolesArr []*admin.DatabaseUserRole) string
- func ConfigDatabaseUserWithScopes(projectID, username, password, roleName string, scopesArr []*admin.UserScope) string
- func ConfigDatabaseUserWithX509Type(projectID, username, x509Type, roleName, keyLabel, valueLabel string) string
- func ConfigEARAzureKeyVault(projectID string, azure *admin.AzureKeyVault, ...) string
- func ConfigGovProvider() string
- func ConfigProjectWithSettings(projectName, orgID, projectOwnerID string, value bool) string
- func ConfigReadOnlyProvider() string
- func ConfigServerlessInstance(projectID, name string, ignoreConnectionStrings bool, autoIndexing *bool, ...) string
- func Conn() *matlas.Client
- func ConnPreview() *adminpreview.APIClient
- func ConnV2() *admin.APIClient
- func ConnV2UsingGov() *admin.APIClient
- func ConnV2UsingProxy(proxyPort *int) *admin.APIClient
- func ConvertAdvancedClusterToSchemaV2(t *testing.T, isAcc bool, def string) string
- func ConvertToAzureKeyVaultEARAttrMap(az *admin.AzureKeyVault) map[string]string
- func ConvertToSchemaV2AttrsMap(isAcc bool, attrsMap map[string]string) map[string]string
- func ConvertToSchemaV2AttrsSet(isAcc bool, attrsSet []string) []string
- func DebugPlan() plancheck.PlanCheck
- func EARCheckResourceAttr(resourceName, prefix string, attrsMap map[string]string) resource.TestCheckFunc
- func EARDatasourceConfig() string
- func EARDestroy(s *terraform.State) error
- func EARImportStateIDFunc(resourceName string) resource.ImportStateIdFunc
- func ExistingClusterUsed() bool
- func ExternalProviders(versionAtlasProvider string) map[string]resource.ExternalProvider
- func ExternalProvidersOnlyAWS() map[string]resource.ExternalProvider
- func ExternalProvidersOnlyAzapi() map[string]resource.ExternalProvider
- func ExternalProvidersOnlyConfluent() map[string]resource.ExternalProvider
- func ExternalProvidersWithAWS(versionAtlasProvider string) map[string]resource.ExternalProvider
- func ExternalProvidersWithConfluent(versionAtlasProvider string) map[string]resource.ExternalProvider
- func FormatToHCLLifecycleIgnore(keys ...string) string
- func FormatToHCLMap(m map[string]string, indent, varName string) string
- func GetCompleteConfluentConfig(usesExistingConfluentCluster, withDNSSubdomains bool, ...) string
- func GetIndependentShardScalingMode(ctx context.Context, projectID, clusterName string) (*string, *http.Response, error)
- func GetProjectTeamsIDsWithPos(pos int) string
- func IDWithProjectIDClusterName(projectID, clusterName string) (string, error)
- func ImportStateIDFuncProjectIDClusterName(resourceName, attrNameProjectID, attrNameClusterName string) resource.ImportStateIdFunc
- func ImportStateProjectIDFunc(resourceName string) resource.ImportStateIdFunc
- func InCI() bool
- func InUnitTest() bool
- func IntGreatThan(value int) resource.CheckResourceAttrWithFunc
- func IsProjectNameOrID(expected string) resource.CheckResourceAttrWithFunc
- func JSONEquals(expected string) resource.CheckResourceAttrWithFunc
- func MatchesExpression(expr string) resource.CheckResourceAttrWithFunc
- func NextProjectIDClusterName(totalNodeCount int, projectCreator func(string) string) (projectID, clusterName string)
- func PopulateWithSampleData(projectID, clusterName string) error
- func PopulateWithSampleDataTestCheck(projectID, clusterName string) resource.TestCheckFunc
- func PreCheck(tb testing.TB)
- func PreCheckAtlasUsername(tb testing.TB)
- func PreCheckAtlasUsernames(tb testing.TB)
- func PreCheckAwsEnv(tb testing.TB)
- func PreCheckAwsEnvBasic(tb testing.TB)
- func PreCheckAwsEnvPrivateLinkEndpointService(tb testing.TB)
- func PreCheckAwsRegionCases(tb testing.TB)
- func PreCheckAzureExportBucket(tb testing.TB)
- func PreCheckBasic(tb testing.TB)
- func PreCheckBasicOwnerID(tb testing.TB)
- func PreCheckBasicSleep(tb testing.TB, clusterInfo *ClusterInfo, projectID, clusterName string) func()
- func PreCheckCert(tb testing.TB)
- func PreCheckCloudProviderAccessAzure(tb testing.TB)
- func PreCheckConfluentAWSPrivatelink(tb testing.TB)
- func PreCheckDataLakePipelineRun(tb testing.TB)
- func PreCheckDataLakePipelineRuns(tb testing.TB)
- func PreCheckEncryptionAtRestEnvAzure(tb testing.TB)
- func PreCheckEncryptionAtRestEnvAzureWithUpdate(tb testing.TB)
- func PreCheckEncryptionAtRestPrivateEndpoint(tb testing.TB)
- func PreCheckFederatedSettings(tb testing.TB)
- func PreCheckFederatedSettingsIdentityProvider(tb testing.TB)
- func PreCheckGPCEnv(tb testing.TB)
- func PreCheckGovBasic(tb testing.TB)
- func PreCheckLDAP(tb testing.TB)
- func PreCheckLDAPCert(tb testing.TB)
- func PreCheckPeeringEnvAWS(tb testing.TB)
- func PreCheckPeeringEnvAzure(tb testing.TB)
- func PreCheckPeeringEnvGCP(tb testing.TB)
- func PreCheckPreviewFlag(tb testing.TB)
- func PreCheckPrivateEndpoint(tb testing.TB)
- func PreCheckProjectTeamsIDsWithMinCount(tb testing.TB, minTeamsCount int)
- func PreCheckPublicKey2(tb testing.TB)
- func PreCheckRegularCredsAreEmpty(tb testing.TB)
- func PreCheckS3Bucket(tb testing.TB)
- func PreCheckSTSAssumeRole(tb testing.TB)
- func ProjectID(tb testing.TB, name string) string
- func ProjectIDExecution(tb testing.TB) string
- func ProjectIDExecutionWithCluster(tb testing.TB, totalNodeCount int) (projectID, clusterName string)
- func RandomClusterName() string
- func RandomEmail() string
- func RandomIAMRole() string
- func RandomIAMUser() string
- func RandomIP(a, b, c byte) string
- func RandomLDAPName() string
- func RandomName() string
- func RandomProjectName() string
- func RandomS3BucketName() string
- func SerialSleep(tb testing.TB)
- func SetupSharedResources() func()
- func SkipIfAdvancedClusterV2Schema(tb testing.TB)
- func SkipInUnitTest(tb testing.TB)
- func SkipTestForCI(tb testing.TB)
- func SortStringMapKeys(m map[string]string) []string
- func StreamInstanceConfig(projectID, instanceName, region, cloudProvider string) string
- func StreamInstanceWithStreamConfigConfig(projectID, instanceName, region, cloudProvider, configTier string) string
- func TestAccProviderV6FactoriesWithProxy(proxyPort *int) map[string]func() (tfprotov6.ProviderServer, error)
- func TestCheckResourceAttrSchemaV2(isAcc bool, name, key, value string) resource.TestCheckFunc
- func TestCheckResourceAttrSetSchemaV2(isAcc bool, name, key string) resource.TestCheckFunc
- func TestCheckResourceAttrWithSchemaV2(isAcc bool, name, key string, ...) resource.TestCheckFunc
- func TestCheckTypeSetElemNestedAttrsSchemaV2(isAcc bool, name, key string, values map[string]string) resource.TestCheckFunc
- func TestStepImportCluster(resourceName string, ignorePrefixFields ...string) resource.TestStep
- func ToSnakeCase(str string) string
- type ClusterInfo
- type ClusterRequest
- type ReplicationSpecRequest
Constants ¶
const AwsProviderVersion = "5.1.0"
const (
MaxClusterNodesPerProject = 30 // Choose to be conservative, 40 clusters per project is the limit before `CROSS_REGION_NETWORK_PERMISSIONS_LIMIT_EXCEEDED` error, see https://www.mongodb.com/docs/atlas/reference/atlas-limits/
)
const (
// Provider name for single configuration testing
ProviderNameMongoDBAtlas = "mongodbatlas"
)
Variables ¶
var ( ClusterTagsMap1 = map[string]string{ "key": "key 1", "value": "value 1", } ClusterTagsMap2 = map[string]string{ "key": "key 2", "value": "value 2", } ClusterTagsMap3 = map[string]string{ "key": "key 3", "value": "value 3", } ClusterLabelsMap1 = map[string]string{ "key": "label key 1", "value": "label value 1", } ClusterLabelsMap2 = map[string]string{ "key": "label key 2", "value": "label value 2", } ClusterLabelsMap3 = map[string]string{ "key": "label key 3", "value": "label value 3", } ClusterLabelsMapIgnored = map[string]string{ "key": advancedclustertpf.LegacyIgnoredLabelKey, "value": "value", } )
var (
ClusterAdvConfigOplogMinRetentionHours = "oplog_min_retention_hours"
)
var MongoDBClient *config.MongoDBClient
MongoDBClient is used to configure client required for Framework-based acceptance tests.
var TestAccProviderV6Factories map[string]func() (tfprotov6.ProviderServer, error)
TestAccProviderV6Factories is used in all tests for ProtoV6ProviderFactories.
Functions ¶
func AddAttrChecks ¶ added in v1.15.3
func AddAttrChecks(targetName string, checks []resource.TestCheckFunc, mapChecks map[string]string) []resource.TestCheckFunc
func AddAttrChecksPrefix ¶ added in v1.17.0
func AddAttrChecksPrefix(targetName string, checks []resource.TestCheckFunc, mapChecks map[string]string, prefix string, skipNames ...string) []resource.TestCheckFunc
func AddAttrChecksPrefixSchemaV2 ¶ added in v1.23.0
func AddAttrChecksPrefixSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, mapChecks map[string]string, prefix string, skipNames ...string) []resource.TestCheckFunc
func AddAttrChecksSchemaV2 ¶ added in v1.23.0
func AddAttrChecksSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, mapChecks map[string]string) []resource.TestCheckFunc
func AddAttrSetChecks ¶ added in v1.15.3
func AddAttrSetChecks(targetName string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
func AddAttrSetChecksPrefix ¶ added in v1.19.0
func AddAttrSetChecksPrefix(targetName string, checks []resource.TestCheckFunc, attrNames []string, prefix string) []resource.TestCheckFunc
func AddAttrSetChecksSchemaV2 ¶ added in v1.23.0
func AddAttrSetChecksSchemaV2(isAcc bool, name string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
func AddNoAttrSetChecks ¶ added in v1.16.0
func AddNoAttrSetChecks(targetName string, checks []resource.TestCheckFunc, attrNames ...string) []resource.TestCheckFunc
func AssertEqualHCL ¶ added in v1.23.0
func AttrNameToSchemaV2 ¶ added in v1.23.0
func CIDRBlockExpression ¶ added in v1.17.0
func CIDRBlockExpression() resource.CheckResourceAttrWithFunc
func CheckDestroyCluster ¶ added in v1.15.2
func CheckDestroyProject ¶
func CheckDestroyProjectGov ¶ added in v1.16.1
func CheckDestroySearchIndex ¶
func CheckDestroyTeam ¶
func CheckEARExists ¶ added in v1.19.0
func CheckEARExists(resourceName string) resource.TestCheckFunc
func CheckExistsCluster ¶ added in v1.23.0
func CheckExistsCluster(resourceName string) resource.TestCheckFunc
func CheckExistsClusterHandlingRetry ¶ added in v1.23.0
func CheckFCVPinningConfig ¶ added in v1.23.0
func CheckIndependentShardScalingMode ¶ added in v1.26.0
func CheckIndependentShardScalingMode(resourceName, clusterName, expectedMode string) resource.TestCheckFunc
func CheckRSAndDS ¶ added in v1.19.0
func CheckRSAndDS(resourceName string, dataSourceName, pluralDataSourceName *string, attrsSet []string, attrsMap map[string]string, extra ...resource.TestCheckFunc) resource.TestCheckFunc
CheckRSAndDS returns a check function that asserts a set of attributes (presence and values) in resource and data sources. If a plural data source name is provided, it will apply checks over first result
func CheckRSAndDSSchemaV2 ¶ added in v1.26.0
func CheckRSAndDSSchemaV2(isAcc bool, resourceName string, dataSourceName, pluralDataSourceName *string, attrsSet []string, attrsMap map[string]string, extra ...resource.TestCheckFunc) resource.TestCheckFunc
func ClusterDatasourceHcl ¶ added in v1.17.4
func ClusterDatasourceHcl(req *ClusterRequest) (configStr, clusterName, resourceName string, err error)
func ClusterNameExecution ¶ added in v1.16.0
ClusterNameExecution returns the name of a created cluster for the execution of the tests in the resource package. This function relies on using an execution project and returns its id. When `MONGODB_ATLAS_CLUSTER_NAME` and `MONGODB_ATLAS_PROJECT_ID` are defined it will be used instead of creating resources. This is useful for local execution but not intended for CI executions.
func ClusterResourceHcl ¶ added in v1.17.4
func ClusterResourceHcl(req *ClusterRequest) (configStr, clusterName, resourceName string, err error)
func ConfigAzapiProvider ¶ added in v1.19.0
configAzapiProvider creates a new azure/azapi provider with credentials explicit in config. This will authorize the provider for a client
func ConfigConfluentProvider ¶ added in v1.26.0
func ConfigConfluentProvider() string
func ConfigDataBaseUserWithOIDCAuthType ¶ added in v1.17.0
func ConfigDataConfluentDedicatedCluster ¶ added in v1.26.0
func ConfigDatabaseUserBasic ¶
func ConfigDatabaseUserWithLabels ¶
func ConfigDatabaseUserWithLabels(projectID, username, roleName string, labels []admin.ComponentLabel) string
func ConfigDatabaseUserWithRoles ¶
func ConfigDatabaseUserWithRoles(projectID, username, password string, rolesArr []*admin.DatabaseUserRole) string
func ConfigEARAzureKeyVault ¶ added in v1.19.0
func ConfigEARAzureKeyVault(projectID string, azure *admin.AzureKeyVault, useRequirePrivateNetworking, useDatasource bool) string
func ConfigGovProvider ¶ added in v1.16.1
func ConfigGovProvider() string
ConfigGovProvider creates provider using MONGODB_ATLAS_GOV_* env vars.
Remember to use PreCheckGovBasic when using this.
func ConfigProjectWithSettings ¶ added in v1.15.0
func ConfigReadOnlyProvider ¶ added in v1.25.0
func ConfigReadOnlyProvider() string
func ConfigServerlessInstance ¶ added in v1.16.0
func ConnPreview ¶ added in v1.22.0
func ConnPreview() *adminpreview.APIClient
func ConnV2UsingGov ¶ added in v1.16.1
func ConnV2UsingProxy ¶ added in v1.15.3
func ConvertAdvancedClusterToSchemaV2 ¶ added in v1.23.0
func ConvertToAzureKeyVaultEARAttrMap ¶ added in v1.19.0
func ConvertToAzureKeyVaultEARAttrMap(az *admin.AzureKeyVault) map[string]string
func ConvertToSchemaV2AttrsMap ¶ added in v1.23.0
func ConvertToSchemaV2AttrsSet ¶ added in v1.23.0
func EARCheckResourceAttr ¶ added in v1.19.0
func EARCheckResourceAttr(resourceName, prefix string, attrsMap map[string]string) resource.TestCheckFunc
func EARDatasourceConfig ¶ added in v1.19.0
func EARDatasourceConfig() string
func EARDestroy ¶ added in v1.19.0
func EARImportStateIDFunc ¶ added in v1.19.0
func EARImportStateIDFunc(resourceName string) resource.ImportStateIdFunc
func ExistingClusterUsed ¶ added in v1.15.2
func ExistingClusterUsed() bool
func ExternalProviders ¶ added in v1.15.0
func ExternalProviders(versionAtlasProvider string) map[string]resource.ExternalProvider
func ExternalProvidersOnlyAWS ¶ added in v1.15.0
func ExternalProvidersOnlyAWS() map[string]resource.ExternalProvider
func ExternalProvidersOnlyAzapi ¶ added in v1.19.0
func ExternalProvidersOnlyAzapi() map[string]resource.ExternalProvider
func ExternalProvidersOnlyConfluent ¶ added in v1.26.0
func ExternalProvidersOnlyConfluent() map[string]resource.ExternalProvider
func ExternalProvidersWithAWS ¶ added in v1.15.0
func ExternalProvidersWithAWS(versionAtlasProvider string) map[string]resource.ExternalProvider
func ExternalProvidersWithConfluent ¶ added in v1.26.0
func ExternalProvidersWithConfluent(versionAtlasProvider string) map[string]resource.ExternalProvider
func FormatToHCLLifecycleIgnore ¶ added in v1.16.0
func FormatToHCLMap ¶ added in v1.16.0
func GetCompleteConfluentConfig ¶ added in v1.26.0
func GetIndependentShardScalingMode ¶ added in v1.23.0
func GetProjectTeamsIDsWithPos ¶ added in v1.15.2
func IDWithProjectIDClusterName ¶ added in v1.20.0
func ImportStateIDFuncProjectIDClusterName ¶ added in v1.20.0
func ImportStateIDFuncProjectIDClusterName(resourceName, attrNameProjectID, attrNameClusterName string) resource.ImportStateIdFunc
func ImportStateProjectIDFunc ¶
func ImportStateProjectIDFunc(resourceName string) resource.ImportStateIdFunc
func InUnitTest ¶ added in v1.15.2
func InUnitTest() bool
func IntGreatThan ¶
func IntGreatThan(value int) resource.CheckResourceAttrWithFunc
func IsProjectNameOrID ¶ added in v1.21.4
func IsProjectNameOrID(expected string) resource.CheckResourceAttrWithFunc
IsProjectNameOrID accepts a project id or name and checks if the input project id matches the expected project
func JSONEquals ¶
func JSONEquals(expected string) resource.CheckResourceAttrWithFunc
func MatchesExpression ¶
func MatchesExpression(expr string) resource.CheckResourceAttrWithFunc
func NextProjectIDClusterName ¶ added in v1.26.0
func NextProjectIDClusterName(totalNodeCount int, projectCreator func(string) string) (projectID, clusterName string)
NextProjectIDClusterName is an internal method used when we want to reuse a projectID `MaxClustersPerProject` times
func PopulateWithSampleData ¶ added in v1.26.0
PopulateWithSampleData adds Sample Data to the cluster, otherwise resources like online archive or indexes won't work
func PopulateWithSampleDataTestCheck ¶ added in v1.26.0
func PopulateWithSampleDataTestCheck(projectID, clusterName string) resource.TestCheckFunc
PopulateWithSampleDataTestCheck is a wrapper around PopulateWithSampleData to be used as a resource.TestCheckFunc
func PreCheck ¶
PreCheck checks common Atlas environment variables and MONGODB_ATLAS_PROJECT_ID. Deprecated: it should not be used as MONGODB_ATLAS_PROJECT_ID is not intended to be used in CI. Use PreCheckBasic instead.
func PreCheckAtlasUsername ¶
func PreCheckAtlasUsernames ¶ added in v1.21.1
func PreCheckAwsEnv ¶
func PreCheckAwsEnvBasic ¶ added in v1.16.0
func PreCheckAwsEnvPrivateLinkEndpointService ¶ added in v1.16.1
func PreCheckAwsRegionCases ¶ added in v1.17.4
func PreCheckAzureExportBucket ¶ added in v1.18.0
func PreCheckBasic ¶
func PreCheckBasicOwnerID ¶
func PreCheckBasicSleep ¶ added in v1.21.2
func PreCheckBasicSleep(tb testing.TB, clusterInfo *ClusterInfo, projectID, clusterName string) func()
PreCheckBasicSleep is a helper function to call SerialSleep, see its help for more info. Some examples of use are when the test is calling ProjectIDExecution or GetClusterInfo to create clusters.
func PreCheckCert ¶ added in v1.15.1
func PreCheckConfluentAWSPrivatelink ¶ added in v1.26.0
func PreCheckEncryptionAtRestEnvAzureWithUpdate ¶ added in v1.19.0
func PreCheckEncryptionAtRestPrivateEndpoint ¶ added in v1.19.0
func PreCheckFederatedSettingsIdentityProvider ¶ added in v1.16.1
func PreCheckGPCEnv ¶
func PreCheckGovBasic ¶ added in v1.16.0
func PreCheckLDAP ¶
func PreCheckLDAPCert ¶ added in v1.15.2
func PreCheckPeeringEnvAWS ¶
func PreCheckPeeringEnvAzure ¶
func PreCheckPeeringEnvGCP ¶
func PreCheckPreviewFlag ¶ added in v1.15.2
PreCheckPreviewFlag is used for resources not yet in GA
func PreCheckPrivateEndpoint ¶ added in v1.15.2
func PreCheckProjectTeamsIDsWithMinCount ¶ added in v1.15.2
func PreCheckPublicKey2 ¶ added in v1.25.0
func PreCheckS3Bucket ¶ added in v1.15.0
func PreCheckSTSAssumeRole ¶
func ProjectID ¶ added in v1.15.3
ProjectID returns the id for a project name. When `MONGODB_ATLAS_PROJECT_ID` is defined, it is used instead of creating a project. This is useful for local execution but not intended for CI executions.
func ProjectIDExecution ¶ added in v1.15.2
ProjectIDExecution returns a project id created for the execution of the tests in the resource package. Even if a GH test group is run, every resource/package will create its own project, not a shared project for all the test group. When `MONGODB_ATLAS_PROJECT_ID` is defined, it is used instead of creating a project. This is useful for local execution but not intended for CI executions.
func ProjectIDExecutionWithCluster ¶ added in v1.26.0
func ProjectIDExecutionWithCluster(tb testing.TB, totalNodeCount int) (projectID, clusterName string)
ProjectIDExecutionWithCluster creates a project and reuses it for `MaxClusterNodesPerProject ` nodes. The clusterName is always unique. TotalNodeCount = sum(specs.node_count) * num_shards (1 if new schema) This avoids the `CROSS_REGION_NETWORK_PERMISSIONS_LIMIT_EXCEEDED` error when creating too many clusters within the same project. When `MONGODB_ATLAS_PROJECT_ID` and `MONGODB_ATLAS_CLUSTER_NAME` are defined, they are used instead of creating a project and clusterName.
func RandomClusterName ¶ added in v1.15.2
func RandomClusterName() string
func RandomEmail ¶ added in v1.15.2
func RandomEmail() string
func RandomIAMRole ¶ added in v1.15.2
func RandomIAMRole() string
func RandomIAMUser ¶ added in v1.15.2
func RandomIAMUser() string
func RandomLDAPName ¶ added in v1.15.2
func RandomLDAPName() string
func RandomName ¶ added in v1.15.2
func RandomName() string
func RandomProjectName ¶ added in v1.15.2
func RandomProjectName() string
func RandomS3BucketName ¶ added in v1.16.0
func RandomS3BucketName() string
func SerialSleep ¶ added in v1.21.2
SerialSleep waits a few seconds so clusters in a project are not created concurrently, see HELP-65223. This must be called once the test is marked as parallel, e.g. in PreCheck inside Terraform tests.
func SetupSharedResources ¶ added in v1.15.2
func SetupSharedResources() func()
SetupSharedResources must be called from TestMain test package in order to use ProjectIDExecution. It returns the cleanup function that must be called at the end of TestMain.
func SkipIfAdvancedClusterV2Schema ¶ added in v1.23.0
func SkipInUnitTest ¶ added in v1.15.2
SkipInUnitTest allows skipping a test entirely when TF_ACC=1 is not defined. This can be useful for acceptance tests that define logic prior to resource.Test/resource.ParallelTest functions as this code would always be run.
func SkipTestForCI ¶
SkipTestForCI is added to tests that cannot run as part of CI, e.g. in Github actions.
func SortStringMapKeys ¶ added in v1.22.0
func StreamInstanceConfig ¶
func StreamInstanceWithStreamConfigConfig ¶ added in v1.15.2
func TestAccProviderV6FactoriesWithProxy ¶ added in v1.15.3
func TestAccProviderV6FactoriesWithProxy(proxyPort *int) map[string]func() (tfprotov6.ProviderServer, error)
func TestCheckResourceAttrSchemaV2 ¶ added in v1.23.0
func TestCheckResourceAttrSchemaV2(isAcc bool, name, key, value string) resource.TestCheckFunc
func TestCheckResourceAttrSetSchemaV2 ¶ added in v1.23.0
func TestCheckResourceAttrSetSchemaV2(isAcc bool, name, key string) resource.TestCheckFunc
func TestCheckResourceAttrWithSchemaV2 ¶ added in v1.23.0
func TestCheckResourceAttrWithSchemaV2(isAcc bool, name, key string, checkValueFunc resource.CheckResourceAttrWithFunc) resource.TestCheckFunc
func TestCheckTypeSetElemNestedAttrsSchemaV2 ¶ added in v1.23.0
func TestStepImportCluster ¶ added in v1.23.0
func ToSnakeCase ¶ added in v1.17.4
Types ¶
type ClusterInfo ¶
type ClusterInfo struct { ProjectID string Name string ResourceName string TerraformNameRef string TerraformStr string }
func GetClusterInfo ¶
func GetClusterInfo(tb testing.TB, req *ClusterRequest) ClusterInfo
GetClusterInfo is used to obtain a project and cluster configuration resource. When `MONGODB_ATLAS_CLUSTER_NAME` and `MONGODB_ATLAS_PROJECT_ID` are defined, a data source is created instead. This is useful for local execution but not intended for CI executions. Clusters will be created in project ProjectIDExecution or in req.ProjectID which can be both a direct id, e.g., `664610ec80cc36255e634074` or a config reference `mongodbatlas_project.test.id`.
type ClusterRequest ¶ added in v1.15.2
type ClusterRequest struct { Tags map[string]string ProjectID string ResourceSuffix string AdvancedConfiguration map[string]any ResourceDependencyName string ClusterName string MongoDBMajorVersion string ReplicationSpecs []ReplicationSpecRequest DiskSizeGb int CloudBackup bool Geosharded bool RetainBackupsEnabled bool PitEnabled bool }
ClusterRequest contains configuration for a cluster where all fields are optional and AddDefaults is used for required fields. Used together with GetClusterInfo which will set ProjectID if it is unset.
func (*ClusterRequest) AddDefaults ¶ added in v1.17.4
func (r *ClusterRequest) AddDefaults()
AddDefaults ensures the required fields are populated to generate a resource.
func (*ClusterRequest) ClusterType ¶ added in v1.17.4
func (r *ClusterRequest) ClusterType() string
type ReplicationSpecRequest ¶ added in v1.17.4
type ReplicationSpecRequest struct { ZoneName string Region string InstanceSize string ProviderName string EbsVolumeType string ExtraRegionConfigs []ReplicationSpecRequest NodeCount int NodeCountReadOnly int Priority int AutoScalingDiskGbEnabled bool }
ReplicationSpecRequest can be used to customize the ReplicationSpecs of a Cluster. No fields are required. Use `ExtraRegionConfigs` to specify multiple region configs.
func (*ReplicationSpecRequest) AddDefaults ¶ added in v1.17.4
func (r *ReplicationSpecRequest) AddDefaults()
func (*ReplicationSpecRequest) AllRegionConfigs ¶ added in v1.17.4
func (r *ReplicationSpecRequest) AllRegionConfigs() []admin.CloudRegionConfig20240805
Source Files ¶
- advanced_cluster.go
- advanced_cluster_schema_v2.go
- atlas.go
- attribute_checks.go
- cluster.go
- config_cluster.go
- config_formatter.go
- database_user.go
- encryption_at_rest.go
- factory.go
- federated.go
- import_state.go
- independent_shard_scaling.go
- name.go
- network_peering.go
- org.go
- plan_check.go
- pre_check.go
- project.go
- provider.go
- search_index.go
- serverless.go
- shared_resource.go
- skip.go
- sort.go
- stream_instance.go
- stream_privatelink_endpoint.go
- team.go