2015-03-27 18:22:33 -04:00
|
|
|
package docker
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"os/exec"
|
2020-03-25 15:39:35 -04:00
|
|
|
"regexp"
|
2015-03-27 18:22:33 -04:00
|
|
|
"testing"
|
|
|
|
|
|
2020-03-25 15:39:35 -04:00
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
|
2019-10-09 14:25:38 -04:00
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
|
|
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/terraform"
|
2015-03-27 18:22:33 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
var testAccProviders map[string]terraform.ResourceProvider
|
|
|
|
|
var testAccProvider *schema.Provider
|
|
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
|
testAccProvider = Provider().(*schema.Provider)
|
|
|
|
|
testAccProviders = map[string]terraform.ResourceProvider{
|
|
|
|
|
"docker": testAccProvider,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func TestProvider(t *testing.T) {
|
|
|
|
|
if err := Provider().(*schema.Provider).InternalValidate(); err != nil {
|
|
|
|
|
t.Fatalf("err: %s", err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-25 15:39:35 -04:00
|
|
|
func TestAccDockerProvider_WithIncompleteRegistryAuth(t *testing.T) {
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
|
{
|
|
|
|
|
Config: testAccDockerProviderWithIncompleteAuthConfig,
|
|
|
|
|
ExpectError: regexp.MustCompile(`401 Unauthorized`),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2015-03-27 18:22:33 -04:00
|
|
|
func TestProvider_impl(t *testing.T) {
|
|
|
|
|
var _ terraform.ResourceProvider = Provider()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccPreCheck(t *testing.T) {
|
|
|
|
|
cmd := exec.Command("docker", "version")
|
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
|
t.Fatalf("Docker must be available: %s", err)
|
|
|
|
|
}
|
2017-11-21 04:14:07 -05:00
|
|
|
|
2018-04-10 02:47:28 -04:00
|
|
|
cmd = exec.Command("docker", "node", "ls")
|
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
|
cmd = exec.Command("docker", "swarm", "init")
|
|
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
|
t.Fatalf("Docker swarm could not be initialized: %s", err)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-09-23 14:15:30 -04:00
|
|
|
err := testAccProvider.Configure(terraform.NewResourceConfigRaw(nil))
|
2019-03-05 09:53:56 -05:00
|
|
|
if err != nil {
|
|
|
|
|
t.Fatal(err)
|
|
|
|
|
}
|
2015-03-27 18:22:33 -04:00
|
|
|
}
|
2020-03-25 15:39:35 -04:00
|
|
|
|
|
|
|
|
const testAccDockerProviderWithIncompleteAuthConfig = `
|
|
|
|
|
provider "docker" {
|
|
|
|
|
alias = "private"
|
|
|
|
|
registry_auth {
|
|
|
|
|
address = ""
|
|
|
|
|
username = ""
|
|
|
|
|
password = ""
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
data "docker_registry_image" "foobar" {
|
|
|
|
|
provider = "docker.private"
|
|
|
|
|
name = "localhost:15000/helloworld:1.0"
|
|
|
|
|
}
|
|
|
|
|
`
|