2015-10-23 14:10:41 +00:00
|
|
|
package google
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2017-06-06 15:34:17 +00:00
|
|
|
"log"
|
2017-01-27 21:06:46 +00:00
|
|
|
"strings"
|
2015-10-23 14:10:41 +00:00
|
|
|
"testing"
|
|
|
|
|
2016-02-04 17:20:22 +00:00
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
2015-10-23 14:10:41 +00:00
|
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
|
|
|
|
"google.golang.org/api/sqladmin/v1beta4"
|
|
|
|
)
|
|
|
|
|
2018-07-24 22:32:18 +00:00
|
|
|
// Fields that should be ignored in import tests because they aren't returned
|
|
|
|
// from GCP (and thus can't be imported)
|
|
|
|
var ignoredReplicaConfigurationFields = []string{
|
|
|
|
"replica_configuration.0.ca_certificate",
|
|
|
|
"replica_configuration.0.client_certificate",
|
|
|
|
"replica_configuration.0.client_key",
|
|
|
|
"replica_configuration.0.connect_retry_interval",
|
|
|
|
"replica_configuration.0.dump_file_path",
|
|
|
|
"replica_configuration.0.master_heartbeat_period",
|
|
|
|
"replica_configuration.0.password",
|
|
|
|
"replica_configuration.0.ssl_cipher",
|
|
|
|
"replica_configuration.0.username",
|
|
|
|
"replica_configuration.0.verify_server_certificate",
|
|
|
|
}
|
|
|
|
|
2017-06-06 15:34:17 +00:00
|
|
|
func init() {
|
|
|
|
resource.AddTestSweepers("gcp_sql_db_instance", &resource.Sweeper{
|
|
|
|
Name: "gcp_sql_db_instance",
|
|
|
|
F: testSweepDatabases,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func testSweepDatabases(region string) error {
|
|
|
|
config, err := sharedConfigForRegion(region)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error getting shared config for region: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = config.loadAndValidate()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("error loading: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
found, err := config.clientSqlAdmin.Instances.List(config.Project).Do()
|
|
|
|
if err != nil {
|
|
|
|
log.Fatalf("error listing databases: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(found.Items) == 0 {
|
|
|
|
log.Printf("No databases found")
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2017-12-06 19:56:17 +00:00
|
|
|
running := map[string]struct{}{}
|
|
|
|
|
2017-06-06 15:34:17 +00:00
|
|
|
for _, d := range found.Items {
|
|
|
|
var testDbInstance bool
|
|
|
|
for _, testName := range []string{"tf-lw-", "sqldatabasetest"} {
|
|
|
|
// only destroy instances we know to fit our test naming pattern
|
|
|
|
if strings.HasPrefix(d.Name, testName) {
|
|
|
|
testDbInstance = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if !testDbInstance {
|
|
|
|
continue
|
|
|
|
}
|
2017-12-06 20:01:30 +00:00
|
|
|
if d.State != "RUNNABLE" {
|
2017-12-06 19:59:45 +00:00
|
|
|
continue
|
|
|
|
}
|
2017-12-06 19:56:17 +00:00
|
|
|
running[d.Name] = struct{}{}
|
|
|
|
}
|
2017-06-06 15:34:17 +00:00
|
|
|
|
2017-12-06 19:56:17 +00:00
|
|
|
for _, d := range found.Items {
|
|
|
|
// don't delete replicas, we'll take care of that
|
|
|
|
// when deleting the database they replicate
|
|
|
|
if d.ReplicaConfiguration != nil {
|
|
|
|
continue
|
|
|
|
}
|
2017-06-06 15:34:17 +00:00
|
|
|
log.Printf("Destroying SQL Instance (%s)", d.Name)
|
|
|
|
|
|
|
|
// replicas need to be stopped and destroyed before destroying a master
|
|
|
|
// instance. The ordering slice tracks replica databases for a given master
|
|
|
|
// and we call destroy on them before destroying the master
|
|
|
|
var ordering []string
|
|
|
|
for _, replicaName := range d.ReplicaNames {
|
2017-12-06 19:56:17 +00:00
|
|
|
// don't try to stop replicas that aren't running
|
|
|
|
if _, ok := running[replicaName]; !ok {
|
|
|
|
ordering = append(ordering, replicaName)
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
2017-06-06 15:34:17 +00:00
|
|
|
// need to stop replication before being able to destroy a database
|
|
|
|
op, err := config.clientSqlAdmin.Instances.StopReplica(config.Project, replicaName).Do()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("error, failed to stop replica instance (%s) for instance (%s): %s", replicaName, d.Name, err)
|
|
|
|
}
|
|
|
|
|
2017-09-27 00:01:52 +00:00
|
|
|
err = sqladminOperationWait(config, op, config.Project, "Stop Replica")
|
2017-06-06 15:34:17 +00:00
|
|
|
if err != nil {
|
|
|
|
if strings.Contains(err.Error(), "does not exist") {
|
|
|
|
log.Printf("Replication operation not found")
|
|
|
|
} else {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ordering = append(ordering, replicaName)
|
|
|
|
}
|
|
|
|
|
|
|
|
// ordering has a list of replicas (or none), now add the primary to the end
|
|
|
|
ordering = append(ordering, d.Name)
|
|
|
|
|
|
|
|
for _, db := range ordering {
|
|
|
|
// destroy instances, replicas first
|
|
|
|
op, err := config.clientSqlAdmin.Instances.Delete(config.Project, db).Do()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
if strings.Contains(err.Error(), "409") {
|
|
|
|
// the GCP api can return a 409 error after the delete operation
|
|
|
|
// reaches a successful end
|
|
|
|
log.Printf("Operation not found, got 409 response")
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
return fmt.Errorf("Error, failed to delete instance %s: %s", db, err)
|
|
|
|
}
|
|
|
|
|
2017-09-27 00:01:52 +00:00
|
|
|
err = sqladminOperationWait(config, op, config.Project, "Delete Instance")
|
2017-06-06 15:34:17 +00:00
|
|
|
if err != nil {
|
|
|
|
if strings.Contains(err.Error(), "does not exist") {
|
|
|
|
log.Printf("SQL instance not found")
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2018-08-28 23:51:37 +00:00
|
|
|
func TestAccSqlDatabaseInstance_basicFirstGen(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2018-08-28 23:51:37 +00:00
|
|
|
instanceID := acctest.RandInt()
|
|
|
|
instanceName := fmt.Sprintf("tf-lw-%d", instanceID)
|
|
|
|
resourceName := "google_sql_database_instance.instance"
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2015-10-23 14:10:41 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
2018-11-07 22:06:12 +00:00
|
|
|
Config: fmt.Sprintf(testGoogleSqlDatabaseInstance_basic, instanceID),
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
2018-08-28 23:51:37 +00:00
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: resourceName,
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: resourceName,
|
|
|
|
ImportStateId: fmt.Sprintf("projects/%s/instances/%s", getTestProjectFromEnv(), instanceName),
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: resourceName,
|
|
|
|
ImportStateId: fmt.Sprintf("%s/%s", getTestProjectFromEnv(), instanceName),
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-08-28 23:51:37 +00:00
|
|
|
func TestAccSqlDatabaseInstance_basicInferredName(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-01-08 16:54:55 +00:00
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2016-01-08 16:54:55 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: testGoogleSqlDatabaseInstance_basic2,
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2016-01-08 16:54:55 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-08-28 23:51:37 +00:00
|
|
|
func TestAccSqlDatabaseInstance_basicSecondGen(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2018-11-07 22:06:12 +00:00
|
|
|
databaseName := "tf-test-" + acctest.RandString(10)
|
2017-02-01 06:21:11 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-02-01 06:21:11 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
2018-11-07 22:06:12 +00:00
|
|
|
testGoogleSqlDatabaseInstance_basic3, databaseName),
|
|
|
|
Check: testAccCheckGoogleSqlDatabaseRootUserDoesNotExist(databaseName),
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2017-02-01 06:21:11 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
2017-09-07 19:44:17 +00:00
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_dontDeleteDefaultUserOnReplica(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-09-07 19:44:17 +00:00
|
|
|
databaseName := "sql-instance-test-" + acctest.RandString(10)
|
|
|
|
failoverName := "sql-instance-test-failover-" + acctest.RandString(10)
|
|
|
|
// 1. Create an instance.
|
|
|
|
// 2. Add a root@'%' user.
|
|
|
|
// 3. Create a replica and assert it succeeds (it'll fail if we try to delete the root user thinking it's a
|
|
|
|
// default user)
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-09-07 19:44:17 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: testGoogleSqlDatabaseInstanceConfig_withoutReplica(databaseName),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
2017-09-07 19:44:17 +00:00
|
|
|
PreConfig: func() {
|
|
|
|
// Add a root user
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
user := sqladmin.User{
|
|
|
|
Name: "root",
|
|
|
|
Host: "%",
|
|
|
|
Password: acctest.RandString(26),
|
|
|
|
}
|
|
|
|
op, err := config.clientSqlAdmin.Users.Insert(config.Project, databaseName, &user).Do()
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Error while inserting root@%% user: %s", err)
|
|
|
|
return
|
|
|
|
}
|
2017-09-27 00:01:52 +00:00
|
|
|
err = sqladminOperationWait(config, op, config.Project, "Waiting for user to insert")
|
2017-09-07 19:44:17 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Error while waiting for user insert operation to complete: %s", err.Error())
|
|
|
|
}
|
|
|
|
// User was created, now create replica
|
|
|
|
},
|
|
|
|
Config: testGoogleSqlDatabaseInstanceConfig_withReplica(databaseName, failoverName),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_settings_basic(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-02-04 17:20:22 +00:00
|
|
|
databaseID := acctest.RandInt()
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2015-10-23 14:10:41 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
2016-01-05 00:04:55 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_settings, databaseID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-07-24 22:32:18 +00:00
|
|
|
func TestAccSqlDatabaseInstance_replica(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
databaseID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_replica, databaseID, databaseID, databaseID),
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance_master",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.replica1",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
ImportStateVerifyIgnore: ignoredReplicaConfigurationFields,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.replica2",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
ImportStateVerifyIgnore: ignoredReplicaConfigurationFields,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_slave(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-01-27 21:06:46 +00:00
|
|
|
masterID := acctest.RandInt()
|
|
|
|
slaveID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-01-27 21:06:46 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_slave, masterID, slaveID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance_master",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance_slave",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2017-01-27 21:06:46 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_highAvailability(t *testing.T) {
|
2018-01-24 17:23:48 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
instanceID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2018-01-24 17:23:48 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_highAvailability, instanceID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2018-01-24 17:23:48 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_diskspecs(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-02-01 16:20:31 +00:00
|
|
|
masterID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-02-01 16:20:31 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_diskspecs, masterID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2017-02-01 16:20:31 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_maintenance(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-02-17 23:33:47 +00:00
|
|
|
masterID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-02-17 23:33:47 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_maintenance, masterID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2017-02-17 23:33:47 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_settings_upgrade(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-02-04 17:20:22 +00:00
|
|
|
databaseID := acctest.RandInt()
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2015-10-23 14:10:41 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
2016-01-05 00:04:55 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_basic, databaseID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
2016-01-05 00:04:55 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_settings, databaseID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_settingsDowngrade(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2016-02-04 17:20:22 +00:00
|
|
|
databaseID := acctest.RandInt()
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2015-10-23 14:10:41 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
2016-01-05 00:04:55 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_settings, databaseID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
2016-01-05 00:04:55 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_basic, databaseID),
|
2018-11-07 22:06:12 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2015-10-23 14:10:41 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-08-18 15:25:42 +00:00
|
|
|
// GH-4222
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_authNets(t *testing.T) {
|
2018-11-07 22:06:12 +00:00
|
|
|
t.Parallel()
|
2017-10-12 22:07:29 +00:00
|
|
|
|
2016-08-18 15:25:42 +00:00
|
|
|
databaseID := acctest.RandInt()
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2016-08-18 15:25:42 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_authNets_step1, databaseID),
|
|
|
|
},
|
2018-11-07 22:06:12 +00:00
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
2016-08-18 15:25:42 +00:00
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_authNets_step2, databaseID),
|
|
|
|
},
|
2018-11-07 22:06:12 +00:00
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
2016-08-18 15:25:42 +00:00
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_authNets_step1, databaseID),
|
|
|
|
},
|
2018-11-07 22:06:12 +00:00
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
2016-08-18 15:25:42 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2017-05-31 19:19:27 +00:00
|
|
|
// Tests that a SQL instance can be referenced from more than one other resource without
|
|
|
|
// throwing an error during provisioning, see #9018.
|
2018-02-23 23:14:24 +00:00
|
|
|
func TestAccSqlDatabaseInstance_multipleOperations(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-05-31 19:19:27 +00:00
|
|
|
databaseID, instanceID, userID := acctest.RandString(8), acctest.RandString(8), acctest.RandString(8)
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-02-23 23:14:24 +00:00
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
2017-05-31 19:19:27 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabaseInstance_multipleOperations, databaseID, instanceID, userID),
|
|
|
|
},
|
2018-11-07 22:06:12 +00:00
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
|
|
|
},
|
2017-05-31 19:19:27 +00:00
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-05-30 22:32:11 +00:00
|
|
|
func TestAccSqlDatabaseInstance_basic_with_user_labels(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
2018-11-07 22:06:12 +00:00
|
|
|
databaseName := "tf-test-" + acctest.RandString(10)
|
2018-05-30 22:32:11 +00:00
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
CheckDestroy: testAccSqlDatabaseInstanceDestroy,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
2018-11-07 22:06:12 +00:00
|
|
|
testGoogleSqlDatabaseInstance_basic_with_user_labels, databaseName),
|
|
|
|
Check: testAccCheckGoogleSqlDatabaseRootUserDoesNotExist(databaseName),
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2018-05-30 22:32:11 +00:00
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
2018-11-07 22:06:12 +00:00
|
|
|
testGoogleSqlDatabaseInstance_basic_with_user_labels_update, databaseName),
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
ResourceName: "google_sql_database_instance.instance",
|
|
|
|
ImportState: true,
|
|
|
|
ImportStateVerify: true,
|
2018-05-30 22:32:11 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2018-02-23 23:14:24 +00:00
|
|
|
func testAccSqlDatabaseInstanceDestroy(s *terraform.State) error {
|
2015-10-23 14:10:41 +00:00
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
if rs.Type != "google_sql_database_instance" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
_, err := config.clientSqlAdmin.Instances.Get(config.Project,
|
|
|
|
rs.Primary.Attributes["name"]).Do()
|
|
|
|
if err == nil {
|
|
|
|
return fmt.Errorf("Database Instance still exists")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2018-11-07 22:06:12 +00:00
|
|
|
func testAccCheckGoogleSqlDatabaseRootUserDoesNotExist(instance string) resource.TestCheckFunc {
|
2017-02-01 06:21:11 +00:00
|
|
|
return func(s *terraform.State) error {
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
|
2018-11-07 22:06:12 +00:00
|
|
|
users, err := config.clientSqlAdmin.Users.List(config.Project, instance).Do()
|
2017-02-01 06:21:11 +00:00
|
|
|
|
|
|
|
if err != nil {
|
2018-11-07 22:06:12 +00:00
|
|
|
return fmt.Errorf("Could not list database users for %q: %s", instance, err)
|
2017-02-01 06:21:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
for _, u := range users.Items {
|
|
|
|
if u.Name == "root" && u.Host == "%" {
|
|
|
|
return fmt.Errorf("%v@%v user still exists", u.Name, u.Host)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-05 00:04:55 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_basic = `
|
2015-10-23 14:10:41 +00:00
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
}
|
|
|
|
}
|
2016-01-05 00:04:55 +00:00
|
|
|
`
|
2015-10-23 14:10:41 +00:00
|
|
|
|
2016-01-08 16:54:55 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_basic2 = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
2017-02-01 06:21:11 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_basic3 = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
2018-11-07 22:06:12 +00:00
|
|
|
name = "%s"
|
2017-06-22 17:25:26 +00:00
|
|
|
region = "us-central1"
|
2017-02-01 06:21:11 +00:00
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
2016-01-08 16:54:55 +00:00
|
|
|
|
2017-09-07 19:44:17 +00:00
|
|
|
func testGoogleSqlDatabaseInstanceConfig_withoutReplica(instanceName string) string {
|
|
|
|
return fmt.Sprintf(`resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "%s"
|
|
|
|
region = "us-central1"
|
|
|
|
database_version = "MYSQL_5_7"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-n1-standard-1"
|
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
binary_log_enabled = "true"
|
|
|
|
enabled = "true"
|
|
|
|
start_time = "18:00"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}`, instanceName)
|
|
|
|
}
|
|
|
|
|
|
|
|
func testGoogleSqlDatabaseInstanceConfig_withReplica(instanceName, failoverName string) string {
|
|
|
|
return fmt.Sprintf(`
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "%s"
|
|
|
|
region = "us-central1"
|
|
|
|
database_version = "MYSQL_5_7"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-n1-standard-1"
|
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
binary_log_enabled = "true"
|
|
|
|
enabled = "true"
|
|
|
|
start_time = "18:00"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database_instance" "instance-failover" {
|
|
|
|
name = "%s"
|
|
|
|
region = "us-central1"
|
|
|
|
database_version = "MYSQL_5_7"
|
|
|
|
master_instance_name = "${google_sql_database_instance.instance.name}"
|
|
|
|
|
|
|
|
replica_configuration {
|
|
|
|
failover_target = "true"
|
|
|
|
}
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-n1-standard-1"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`, instanceName, failoverName)
|
|
|
|
}
|
|
|
|
|
2016-01-05 00:04:55 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_settings = `
|
2015-10-23 14:10:41 +00:00
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
replication_type = "ASYNCHRONOUS"
|
|
|
|
location_preference {
|
|
|
|
zone = "us-central1-f"
|
|
|
|
}
|
|
|
|
|
|
|
|
ip_configuration {
|
|
|
|
ipv4_enabled = "true"
|
|
|
|
authorized_networks {
|
|
|
|
value = "108.12.12.12"
|
|
|
|
name = "misc"
|
2017-11-16 19:01:05 +00:00
|
|
|
expiration_time = "2050-11-15T16:19:00.094Z"
|
2015-10-23 14:10:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
enabled = "true"
|
|
|
|
start_time = "19:19"
|
|
|
|
}
|
|
|
|
|
|
|
|
activation_policy = "ON_DEMAND"
|
|
|
|
}
|
|
|
|
}
|
2016-01-05 00:04:55 +00:00
|
|
|
`
|
2015-10-23 14:10:41 +00:00
|
|
|
|
2016-01-05 00:04:55 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_replica = `
|
2015-10-23 14:10:41 +00:00
|
|
|
resource "google_sql_database_instance" "instance_master" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
database_version = "MYSQL_5_6"
|
2018-07-24 22:32:18 +00:00
|
|
|
region = "us-central1"
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
settings {
|
2018-07-24 22:32:18 +00:00
|
|
|
tier = "db-n1-standard-1"
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
enabled = true
|
|
|
|
start_time = "00:00"
|
|
|
|
binary_log_enabled = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-24 22:32:18 +00:00
|
|
|
resource "google_sql_database_instance" "replica1" {
|
|
|
|
name = "tf-lw-%d-1"
|
2015-10-23 14:10:41 +00:00
|
|
|
database_version = "MYSQL_5_6"
|
2018-07-24 22:32:18 +00:00
|
|
|
region = "us-central1"
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
settings {
|
2018-07-24 22:32:18 +00:00
|
|
|
tier = "db-n1-standard-1"
|
|
|
|
}
|
|
|
|
|
|
|
|
master_instance_name = "${google_sql_database_instance.instance_master.name}"
|
|
|
|
|
|
|
|
replica_configuration {
|
|
|
|
connect_retry_interval = 100
|
|
|
|
master_heartbeat_period = 10000
|
|
|
|
password = "password"
|
|
|
|
username = "username"
|
|
|
|
ssl_cipher = "ALL"
|
|
|
|
verify_server_certificate = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database_instance" "replica2" {
|
|
|
|
name = "tf-lw-%d-2"
|
|
|
|
database_version = "MYSQL_5_6"
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-n1-standard-1"
|
2015-10-23 14:10:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
master_instance_name = "${google_sql_database_instance.instance_master.name}"
|
|
|
|
|
|
|
|
replica_configuration {
|
|
|
|
connect_retry_interval = 100
|
|
|
|
master_heartbeat_period = 10000
|
|
|
|
password = "password"
|
|
|
|
username = "username"
|
|
|
|
ssl_cipher = "ALL"
|
|
|
|
verify_server_certificate = false
|
|
|
|
}
|
|
|
|
}
|
2016-01-05 00:04:55 +00:00
|
|
|
`
|
2016-08-18 15:25:42 +00:00
|
|
|
|
2017-01-27 21:06:46 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_slave = `
|
|
|
|
resource "google_sql_database_instance" "instance_master" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
enabled = true
|
|
|
|
binary_log_enabled = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database_instance" "instance_slave" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
master_instance_name = "${google_sql_database_instance.instance_master.name}"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
2018-01-24 17:23:48 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_highAvailability = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central1"
|
|
|
|
database_version = "POSTGRES_9_6"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
|
|
|
|
availability_type = "REGIONAL"
|
|
|
|
|
|
|
|
backup_configuration {
|
|
|
|
enabled = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
2017-02-01 16:20:31 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_diskspecs = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
disk_autoresize = true
|
|
|
|
disk_size = 15
|
|
|
|
disk_type = "PD_HDD"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
2017-02-17 23:33:47 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_maintenance = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central1"
|
|
|
|
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
|
|
|
|
maintenance_window {
|
|
|
|
day = 7
|
|
|
|
hour = 3
|
|
|
|
update_track = "canary"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
2016-08-18 15:25:42 +00:00
|
|
|
var testGoogleSqlDatabaseInstance_authNets_step1 = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
|
|
|
|
ip_configuration {
|
|
|
|
ipv4_enabled = "true"
|
|
|
|
authorized_networks {
|
|
|
|
value = "108.12.12.12"
|
|
|
|
name = "misc"
|
2017-11-16 19:01:05 +00:00
|
|
|
expiration_time = "2050-11-15T16:19:00.094Z"
|
2016-08-18 15:25:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
|
|
|
var testGoogleSqlDatabaseInstance_authNets_step2 = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-lw-%d"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
|
|
|
|
ip_configuration {
|
|
|
|
ipv4_enabled = "true"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
2017-05-31 19:19:27 +00:00
|
|
|
|
|
|
|
var testGoogleSqlDatabaseInstance_multipleOperations = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "tf-test-%s"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
crash_safe_replication = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database" "database" {
|
|
|
|
name = "tf-test-%s"
|
|
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_user" "user" {
|
|
|
|
name = "tf-test-%s"
|
|
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
|
|
host = "google.com"
|
|
|
|
password = "hunter2"
|
|
|
|
}
|
|
|
|
`
|
2018-05-30 22:32:11 +00:00
|
|
|
|
|
|
|
var testGoogleSqlDatabaseInstance_basic_with_user_labels = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
2018-11-07 22:06:12 +00:00
|
|
|
name = "%s"
|
2018-05-30 22:32:11 +00:00
|
|
|
region = "us-central1"
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
user_labels {
|
|
|
|
track = "production"
|
|
|
|
location = "western-division"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|
|
|
|
var testGoogleSqlDatabaseInstance_basic_with_user_labels_update = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
2018-11-07 22:06:12 +00:00
|
|
|
name = "%s"
|
2018-05-30 22:32:11 +00:00
|
|
|
region = "us-central1"
|
|
|
|
settings {
|
|
|
|
tier = "db-f1-micro"
|
|
|
|
user_labels {
|
|
|
|
track = "production"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`
|