mirror of
https://github.com/kreuzwerker/terraform-provider-docker.git
synced 2025-12-20 22:59:42 -05:00
94 lines
2.4 KiB
Go
94 lines
2.4 KiB
Go
|
|
package docker
|
||
|
|
|
||
|
|
import (
|
||
|
|
"fmt"
|
||
|
|
"testing"
|
||
|
|
|
||
|
|
"github.com/hashicorp/terraform/helper/resource"
|
||
|
|
"github.com/hashicorp/terraform/terraform"
|
||
|
|
)
|
||
|
|
|
||
|
|
func TestAccDockerSecret_basic(t *testing.T) {
|
||
|
|
resource.Test(t, resource.TestCase{
|
||
|
|
PreCheck: func() { testAccPreCheck(t) },
|
||
|
|
Providers: testAccProviders,
|
||
|
|
CheckDestroy: testCheckDockerSecretDestroy,
|
||
|
|
Steps: []resource.TestStep{
|
||
|
|
resource.TestStep{
|
||
|
|
Config: `
|
||
|
|
resource "docker_secret" "foo" {
|
||
|
|
name = "foo-secret"
|
||
|
|
data = "Ymxhc2RzYmxhYmxhMTI0ZHNkd2VzZA=="
|
||
|
|
}
|
||
|
|
`,
|
||
|
|
Check: resource.ComposeTestCheckFunc(
|
||
|
|
resource.TestCheckResourceAttr("docker_secret.foo", "name", "foo-secret"),
|
||
|
|
resource.TestCheckResourceAttr("docker_secret.foo", "data", "Ymxhc2RzYmxhYmxhMTI0ZHNkd2VzZA=="),
|
||
|
|
),
|
||
|
|
},
|
||
|
|
},
|
||
|
|
})
|
||
|
|
}
|
||
|
|
func TestAccDockerSecret_basicUpdateble(t *testing.T) {
|
||
|
|
resource.Test(t, resource.TestCase{
|
||
|
|
PreCheck: func() { testAccPreCheck(t) },
|
||
|
|
Providers: testAccProviders,
|
||
|
|
CheckDestroy: testCheckDockerSecretDestroy,
|
||
|
|
Steps: []resource.TestStep{
|
||
|
|
resource.TestStep{
|
||
|
|
Config: `
|
||
|
|
resource "docker_secret" "foo" {
|
||
|
|
name = "tftest-mysecret-${replace(timestamp(),":", ".")}"
|
||
|
|
data = "Ymxhc2RzYmxhYmxhMTI0ZHNkd2VzZA=="
|
||
|
|
|
||
|
|
lifecycle {
|
||
|
|
ignore_changes = ["name"]
|
||
|
|
create_before_destroy = true
|
||
|
|
}
|
||
|
|
}
|
||
|
|
`,
|
||
|
|
Check: resource.ComposeTestCheckFunc(
|
||
|
|
resource.TestCheckResourceAttr("docker_secret.foo", "data", "Ymxhc2RzYmxhYmxhMTI0ZHNkd2VzZA=="),
|
||
|
|
),
|
||
|
|
},
|
||
|
|
resource.TestStep{
|
||
|
|
Config: `
|
||
|
|
resource "docker_secret" "foo" {
|
||
|
|
name = "tftest-mysecret2-${replace(timestamp(),":", ".")}"
|
||
|
|
data = "U3VuIDI1IE1hciAyMDE4IDE0OjUzOjIxIENFU1QK"
|
||
|
|
|
||
|
|
lifecycle {
|
||
|
|
ignore_changes = ["name"]
|
||
|
|
create_before_destroy = true
|
||
|
|
}
|
||
|
|
}
|
||
|
|
`,
|
||
|
|
Check: resource.ComposeTestCheckFunc(
|
||
|
|
resource.TestCheckResourceAttr("docker_secret.foo", "data", "U3VuIDI1IE1hciAyMDE4IDE0OjUzOjIxIENFU1QK"),
|
||
|
|
),
|
||
|
|
},
|
||
|
|
},
|
||
|
|
})
|
||
|
|
}
|
||
|
|
|
||
|
|
/////////////
|
||
|
|
// Helpers
|
||
|
|
/////////////
|
||
|
|
func testCheckDockerSecretDestroy(s *terraform.State) error {
|
||
|
|
client := testAccProvider.Meta().(*ProviderConfig).DockerClient
|
||
|
|
for _, rs := range s.RootModule().Resources {
|
||
|
|
if rs.Type != "secrets" {
|
||
|
|
continue
|
||
|
|
}
|
||
|
|
|
||
|
|
id := rs.Primary.Attributes["id"]
|
||
|
|
secret, err := client.InspectSecret(id)
|
||
|
|
|
||
|
|
if err == nil || secret != nil {
|
||
|
|
return fmt.Errorf("Secret with id '%s' still exists", id)
|
||
|
|
}
|
||
|
|
return nil
|
||
|
|
}
|
||
|
|
return nil
|
||
|
|
}
|