2015-10-23 14:10:41 +00:00
|
|
|
package google
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
2016-01-05 21:47:10 +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"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAccGoogleSqlDatabase_basic(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2015-10-23 14:10:41 +00:00
|
|
|
var database sqladmin.Database
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-01-02 19:15:13 +00:00
|
|
|
CheckDestroy: testAccGoogleSqlDatabaseDestroy,
|
2015-10-23 14:10:41 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
2017-06-22 16:13:05 +00:00
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabase_basic, acctest.RandString(10), acctest.RandString(10)),
|
2015-10-23 14:10:41 +00:00
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleSqlDatabaseExists(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
testAccCheckGoogleSqlDatabaseEquals(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2017-07-17 15:32:29 +00:00
|
|
|
func TestAccGoogleSqlDatabase_update(t *testing.T) {
|
2017-10-12 22:07:29 +00:00
|
|
|
t.Parallel()
|
|
|
|
|
2017-07-17 15:32:29 +00:00
|
|
|
var database sqladmin.Database
|
|
|
|
|
|
|
|
instance_name := acctest.RandString(10)
|
|
|
|
database_name := acctest.RandString(10)
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
2018-01-02 19:15:13 +00:00
|
|
|
CheckDestroy: testAccGoogleSqlDatabaseDestroy,
|
2017-07-17 15:32:29 +00:00
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabase_basic, instance_name, database_name),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleSqlDatabaseExists(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
testAccCheckGoogleSqlDatabaseEquals(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
resource.TestStep{
|
|
|
|
Config: fmt.Sprintf(
|
|
|
|
testGoogleSqlDatabase_latin1, instance_name, database_name),
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testAccCheckGoogleSqlDatabaseExists(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
testAccCheckGoogleSqlDatabaseEquals(
|
|
|
|
"google_sql_database.database", &database),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2015-10-23 14:10:41 +00:00
|
|
|
func testAccCheckGoogleSqlDatabaseEquals(n string,
|
|
|
|
database *sqladmin.Database) resource.TestCheckFunc {
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
rs, ok := s.RootModule().Resources[n]
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("Resource not found: %s", n)
|
|
|
|
}
|
|
|
|
|
|
|
|
database_name := rs.Primary.Attributes["name"]
|
|
|
|
instance_name := rs.Primary.Attributes["instance"]
|
2017-07-17 15:32:29 +00:00
|
|
|
charset := rs.Primary.Attributes["charset"]
|
|
|
|
collation := rs.Primary.Attributes["collation"]
|
2015-10-23 14:10:41 +00:00
|
|
|
|
|
|
|
if database_name != database.Name {
|
|
|
|
return fmt.Errorf("Error name mismatch, (%s, %s)", database_name, database.Name)
|
|
|
|
}
|
|
|
|
|
|
|
|
if instance_name != database.Instance {
|
|
|
|
return fmt.Errorf("Error instance_name mismatch, (%s, %s)", instance_name, database.Instance)
|
|
|
|
}
|
|
|
|
|
2017-07-17 15:32:29 +00:00
|
|
|
if charset != database.Charset {
|
|
|
|
return fmt.Errorf("Error charset mismatch, (%s, %s)", charset, database.Charset)
|
|
|
|
}
|
|
|
|
|
|
|
|
if collation != database.Collation {
|
|
|
|
return fmt.Errorf("Error collation mismatch, (%s, %s)", collation, database.Collation)
|
|
|
|
}
|
|
|
|
|
2015-10-23 14:10:41 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func testAccCheckGoogleSqlDatabaseExists(n string,
|
|
|
|
database *sqladmin.Database) resource.TestCheckFunc {
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
rs, ok := s.RootModule().Resources[n]
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("Resource not found: %s", n)
|
|
|
|
}
|
|
|
|
|
|
|
|
database_name := rs.Primary.Attributes["name"]
|
|
|
|
instance_name := rs.Primary.Attributes["instance"]
|
|
|
|
found, err := config.clientSqlAdmin.Databases.Get(config.Project,
|
|
|
|
instance_name, database_name).Do()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Not found: %s: %s", n, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
*database = *found
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func testAccGoogleSqlDatabaseDestroy(s *terraform.State) error {
|
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
|
|
config := testAccProvider.Meta().(*Config)
|
|
|
|
if rs.Type != "google_sql_database" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
database_name := rs.Primary.Attributes["name"]
|
|
|
|
instance_name := rs.Primary.Attributes["instance"]
|
|
|
|
_, err := config.clientSqlAdmin.Databases.Get(config.Project,
|
|
|
|
instance_name, database_name).Do()
|
|
|
|
|
|
|
|
if err == nil {
|
|
|
|
return fmt.Errorf("Database resource still exists")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2017-06-22 16:13:05 +00:00
|
|
|
var testGoogleSqlDatabase_basic = `
|
2015-10-23 14:10:41 +00:00
|
|
|
resource "google_sql_database_instance" "instance" {
|
2016-01-06 00:49:06 +00:00
|
|
|
name = "sqldatabasetest%s"
|
2015-11-20 15:52:23 +00:00
|
|
|
region = "us-central"
|
2015-10-23 14:10:41 +00:00
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database" "database" {
|
2016-01-06 00:49:06 +00:00
|
|
|
name = "sqldatabasetest%s"
|
2015-10-23 14:10:41 +00:00
|
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
|
|
}
|
2017-06-22 16:13:05 +00:00
|
|
|
`
|
2017-07-17 15:32:29 +00:00
|
|
|
var testGoogleSqlDatabase_latin1 = `
|
|
|
|
resource "google_sql_database_instance" "instance" {
|
|
|
|
name = "sqldatabasetest%s"
|
|
|
|
region = "us-central"
|
|
|
|
settings {
|
|
|
|
tier = "D0"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "google_sql_database" "database" {
|
|
|
|
name = "sqldatabasetest%s"
|
|
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
|
|
charset = "latin1"
|
|
|
|
collation = "latin1_swedish_ci"
|
|
|
|
}
|
|
|
|
`
|