diff --git a/mmv1/third_party/terraform/resources/resource_sql_database_instance.go.erb b/mmv1/third_party/terraform/resources/resource_sql_database_instance.go.erb index 12e8299572cf..1f9a000dfb5e 100644 --- a/mmv1/third_party/terraform/resources/resource_sql_database_instance.go.erb +++ b/mmv1/third_party/terraform/resources/resource_sql_database_instance.go.erb @@ -857,6 +857,17 @@ func resourceSqlDatabaseInstanceCreate(d *schema.ResourceData, meta interface{}) } <% end -%> + var patchData *sqladmin.DatabaseInstance + + // BinaryLogging can be enabled on replica instances but only after creation. + if instance.MasterInstanceName != "" && instance.Settings != nil && instance.Settings.BackupConfiguration != nil { + bc := instance.Settings.BackupConfiguration + instance.Settings.BackupConfiguration = nil + if bc.BinaryLogEnabled { + patchData = &sqladmin.DatabaseInstance{Settings: &sqladmin.Settings{BackupConfiguration: bc}} + } + } + var op *sqladmin.Operation err = retryTimeDuration(func() (operr error) { if cloneContext != nil { @@ -884,6 +895,21 @@ func resourceSqlDatabaseInstanceCreate(d *schema.ResourceData, meta interface{}) return err } + // patch any fields that need to be sent postcreation + if patchData != nil { + err = retryTimeDuration(func() (rerr error) { + op, rerr = config.NewSqlAdminClient(userAgent).Instances.Patch(project, instance.Name, patchData).Do() + return rerr + }, d.Timeout(schema.TimeoutUpdate), isSqlOperationInProgressError) + if err != nil { + return fmt.Errorf("Error, failed to update instance settings for %s: %s", instance.Name, err) + } + err = sqlAdminOperationWaitTime(config, op, project, "Patch Instance", userAgent, d.Timeout(schema.TimeoutUpdate)) + if err != nil { + return err + } + } + err = resourceSqlDatabaseInstanceRead(d, meta) if err != nil { return err diff --git a/mmv1/third_party/terraform/tests/resource_sql_database_instance_test.go.erb b/mmv1/third_party/terraform/tests/resource_sql_database_instance_test.go.erb index 08ad48a2f9a7..6da8bf7545f5 100644 --- a/mmv1/third_party/terraform/tests/resource_sql_database_instance_test.go.erb +++ b/mmv1/third_party/terraform/tests/resource_sql_database_instance_test.go.erb @@ -1142,7 +1142,7 @@ resource "google_sql_database_instance" "instance" { var testGoogleSqlDatabaseInstance_replica = ` resource "google_sql_database_instance" "instance_master" { name = "tf-lw-%d" - database_version = "MYSQL_5_6" + database_version = "MYSQL_5_7" region = "us-central1" deletion_protection = false @@ -1159,12 +1159,15 @@ resource "google_sql_database_instance" "instance_master" { resource "google_sql_database_instance" "replica1" { name = "tf-lw-%d-1" - database_version = "MYSQL_5_6" + database_version = "MYSQL_5_7" region = "us-central1" deletion_protection = false settings { tier = "db-n1-standard-1" + backup_configuration { + binary_log_enabled = true + } } master_instance_name = google_sql_database_instance.instance_master.name @@ -1181,7 +1184,7 @@ resource "google_sql_database_instance" "replica1" { resource "google_sql_database_instance" "replica2" { name = "tf-lw-%d-2" - database_version = "MYSQL_5_6" + database_version = "MYSQL_5_7" region = "us-central1" deletion_protection = false