package google import ( "fmt" "testing" "github.com/hashicorp/terraform/helper/resource" "github.com/hashicorp/terraform/terraform" ) func TestAccComputeSslCertificate_basic(t *testing.T) { resource.Test(t, resource.TestCase{ PreCheck: func() { testAccPreCheck(t) }, Providers: testAccProviders, CheckDestroy: testAccCheckComputeSslCertificateDestroy, Steps: []resource.TestStep{ resource.TestStep{ Config: testAccComputeSslCertificate_basic, Check: resource.ComposeTestCheckFunc( testAccCheckComputeSslCertificateExists( "google_compute_ssl_certificate.foobar"), ), }, }, }) } func testAccCheckComputeSslCertificateDestroy(s *terraform.State) error { config := testAccProvider.Meta().(*Config) for _, rs := range s.RootModule().Resources { if rs.Type != "google_compute_ssl_certificate" { continue } _, err := config.clientCompute.SslCertificates.Get( config.Project, rs.Primary.ID).Do() if err == nil { return fmt.Errorf("SslCertificate still exists") } } return nil } func testAccCheckComputeSslCertificateExists(n string) resource.TestCheckFunc { return func(s *terraform.State) error { rs, ok := s.RootModule().Resources[n] if !ok { return fmt.Errorf("Not found: %s", n) } if rs.Primary.ID == "" { return fmt.Errorf("No ID is set") } config := testAccProvider.Meta().(*Config) found, err := config.clientCompute.SslCertificates.Get( config.Project, rs.Primary.ID).Do() if err != nil { return err } if found.Name != rs.Primary.ID { return fmt.Errorf("Certificate not found") } return nil } } const testAccComputeSslCertificate_basic = ` resource "google_compute_ssl_certificate" "foobar" { name = "terraform-test" description = "very descriptive" private_key = "${file("test-fixtures/ssl_cert/test.key")}" certificate = "${file("test-fixtures/ssl_cert/test.crt")}" } `