mirror of
https://github.com/letic/terraform-provider-google.git
synced 2024-10-15 07:27:15 +00:00
27ade47e5a
* fix importing for sql resources * fmt * fix id for sql db import, tests * change test names to be more specific
213 lines
5.7 KiB
Go
213 lines
5.7 KiB
Go
package google
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
"google.golang.org/api/sqladmin/v1beta4"
|
|
)
|
|
|
|
func TestAccSqlDatabase_basic(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
var database sqladmin.Database
|
|
|
|
resourceName := "google_sql_database.database"
|
|
instanceName := fmt.Sprintf("sqldatabasetest%s", acctest.RandString(10))
|
|
dbName := fmt.Sprintf("sqldatabasetest%s", acctest.RandString(10))
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
Providers: testAccProviders,
|
|
CheckDestroy: testAccSqlDatabaseDestroy,
|
|
Steps: []resource.TestStep{
|
|
resource.TestStep{
|
|
Config: fmt.Sprintf(testGoogleSqlDatabase_basic, instanceName, dbName),
|
|
Check: resource.ComposeTestCheckFunc(
|
|
testAccCheckGoogleSqlDatabaseExists(resourceName, &database),
|
|
testAccCheckGoogleSqlDatabaseEquals(resourceName, &database),
|
|
),
|
|
},
|
|
resource.TestStep{
|
|
ResourceName: resourceName,
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
resource.TestStep{
|
|
ResourceName: resourceName,
|
|
ImportStateId: fmt.Sprintf("%s/%s", instanceName, dbName),
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
|
|
resource.TestStep{
|
|
ResourceName: resourceName,
|
|
ImportStateId: fmt.Sprintf("instances/%s/databases/%s", instanceName, dbName),
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
resource.TestStep{
|
|
ResourceName: resourceName,
|
|
ImportStateId: fmt.Sprintf("%s/%s/%s", getTestProjectFromEnv(), instanceName, dbName),
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
resource.TestStep{
|
|
ResourceName: resourceName,
|
|
ImportStateId: fmt.Sprintf("projects/%s/instances/%s/databases/%s", getTestProjectFromEnv(), instanceName, dbName),
|
|
ImportState: true,
|
|
ImportStateVerify: true,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
func TestAccSqlDatabase_update(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
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,
|
|
CheckDestroy: testAccSqlDatabaseDestroy,
|
|
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),
|
|
),
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
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"]
|
|
charset := rs.Primary.Attributes["charset"]
|
|
collation := rs.Primary.Attributes["collation"]
|
|
|
|
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)
|
|
}
|
|
|
|
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)
|
|
}
|
|
|
|
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 testAccSqlDatabaseDestroy(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
|
|
}
|
|
|
|
var testGoogleSqlDatabase_basic = `
|
|
resource "google_sql_database_instance" "instance" {
|
|
name = "%s"
|
|
region = "us-central"
|
|
settings {
|
|
tier = "D0"
|
|
}
|
|
}
|
|
|
|
resource "google_sql_database" "database" {
|
|
name = "%s"
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
}
|
|
`
|
|
var testGoogleSqlDatabase_latin1 = `
|
|
resource "google_sql_database_instance" "instance" {
|
|
name = "%s"
|
|
region = "us-central"
|
|
settings {
|
|
tier = "D0"
|
|
}
|
|
}
|
|
|
|
resource "google_sql_database" "database" {
|
|
name = "%s"
|
|
instance = "${google_sql_database_instance.instance.name}"
|
|
charset = "latin1"
|
|
collation = "latin1_swedish_ci"
|
|
}
|
|
`
|