2016-01-02 06:20:55 -05:00
|
|
|
package docker
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"testing"
|
|
|
|
|
|
2018-07-03 11:30:53 -04:00
|
|
|
"context"
|
2019-11-23 08:42:05 -05:00
|
|
|
|
2018-07-03 11:30:53 -04:00
|
|
|
"github.com/docker/docker/api/types"
|
2019-10-09 14:25:38 -04:00
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/helper/resource"
|
|
|
|
|
"github.com/hashicorp/terraform-plugin-sdk/terraform"
|
2016-01-02 06:20:55 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func TestAccDockerNetwork_basic(t *testing.T) {
|
2018-07-03 11:30:53 -04:00
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2016-01-02 06:20:55 -05:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2016-01-02 06:20:55 -05:00
|
|
|
Config: testAccDockerNetworkConfig,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2016-01-02 06:20:55 -05:00
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2016-01-02 06:20:55 -05:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-23 08:42:05 -05:00
|
|
|
// TODO mavogel: add full network config test in #219
|
|
|
|
|
|
2018-07-03 11:30:53 -04:00
|
|
|
func testAccNetwork(n string, network *types.NetworkResource) resource.TestCheckFunc {
|
2016-01-02 06:20:55 -05:00
|
|
|
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")
|
|
|
|
|
}
|
|
|
|
|
|
2017-11-21 04:14:07 -05:00
|
|
|
client := testAccProvider.Meta().(*ProviderConfig).DockerClient
|
2018-07-03 11:30:53 -04:00
|
|
|
networks, err := client.NetworkList(context.Background(), types.NetworkListOptions{})
|
2016-01-02 06:20:55 -05:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, n := range networks {
|
|
|
|
|
if n.ID == rs.Primary.ID {
|
2018-07-03 11:30:53 -04:00
|
|
|
inspected, err := client.NetworkInspect(context.Background(), n.ID, types.NetworkInspectOptions{})
|
2016-01-02 06:20:55 -05:00
|
|
|
if err != nil {
|
|
|
|
|
return fmt.Errorf("Network could not be obtained: %s", err)
|
|
|
|
|
}
|
2018-07-03 11:30:53 -04:00
|
|
|
*network = inspected
|
2016-01-02 06:20:55 -05:00
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return fmt.Errorf("Network not found: %s", rs.Primary.ID)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkConfig = `
|
|
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "bar"
|
|
|
|
|
}
|
|
|
|
|
`
|
2017-01-03 06:46:16 -05:00
|
|
|
|
|
|
|
|
func TestAccDockerNetwork_internal(t *testing.T) {
|
2018-07-03 11:30:53 -04:00
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2017-01-03 06:46:16 -05:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2017-01-03 06:46:16 -05:00
|
|
|
Config: testAccDockerNetworkInternalConfig,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2017-01-03 06:46:16 -05:00
|
|
|
testAccNetworkInternal(&n, true),
|
|
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2017-01-03 06:46:16 -05:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2018-07-03 11:30:53 -04:00
|
|
|
func testAccNetworkInternal(network *types.NetworkResource, internal bool) resource.TestCheckFunc {
|
2017-01-03 06:46:16 -05:00
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if network.Internal != internal {
|
|
|
|
|
return fmt.Errorf("Bad value for attribute 'internal': %t", network.Internal)
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkInternalConfig = `
|
2018-10-29 01:36:21 -04:00
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "bar"
|
2018-10-18 06:39:58 -04:00
|
|
|
internal = true
|
|
|
|
|
}
|
|
|
|
|
`
|
|
|
|
|
|
|
|
|
|
func TestAccDockerNetwork_attachable(t *testing.T) {
|
|
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2018-10-18 06:39:58 -04:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2018-10-18 06:39:58 -04:00
|
|
|
Config: testAccDockerNetworkAttachableConfig,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2018-10-18 06:39:58 -04:00
|
|
|
testAccNetworkAttachable(&n, true),
|
|
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2018-10-18 06:39:58 -04:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccNetworkAttachable(network *types.NetworkResource, attachable bool) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if network.Attachable != attachable {
|
|
|
|
|
return fmt.Errorf("Bad value for attribute 'attachable': %t", network.Attachable)
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkAttachableConfig = `
|
2018-10-29 01:36:21 -04:00
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "bar"
|
2018-10-18 06:39:58 -04:00
|
|
|
attachable = true
|
|
|
|
|
}
|
|
|
|
|
`
|
|
|
|
|
|
2018-10-29 01:36:21 -04:00
|
|
|
//func TestAccDockerNetwork_ingress(t *testing.T) {
|
|
|
|
|
// var n types.NetworkResource
|
|
|
|
|
//
|
|
|
|
|
// resource.Test(t, resource.TestCase{
|
|
|
|
|
// PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
// Providers: testAccProviders,
|
|
|
|
|
// Steps: []resource.TestStep{
|
|
|
|
|
// resource.TestStep{
|
|
|
|
|
// Config: testAccDockerNetworkIngressConfig,
|
|
|
|
|
// Check: resource.ComposeTestCheckFunc(
|
|
|
|
|
// testAccNetwork("docker_network.foo", &n),
|
|
|
|
|
// testAccNetworkIngress(&n, true),
|
|
|
|
|
// ),
|
|
|
|
|
// },
|
|
|
|
|
// },
|
|
|
|
|
// })
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//func testAccNetworkIngress(network *types.NetworkResource, internal bool) resource.TestCheckFunc {
|
|
|
|
|
// return func(s *terraform.State) error {
|
|
|
|
|
// if network.Internal != internal {
|
|
|
|
|
// return fmt.Errorf("Bad value for attribute 'ingress': %t", network.Ingress)
|
|
|
|
|
// }
|
|
|
|
|
// return nil
|
|
|
|
|
// }
|
|
|
|
|
//}
|
|
|
|
|
//
|
|
|
|
|
//const testAccDockerNetworkIngressConfig = `
|
|
|
|
|
//resource "docker_network" "foo" {
|
|
|
|
|
// name = "bar"
|
|
|
|
|
// ingress = true
|
|
|
|
|
//}
|
|
|
|
|
//`
|
|
|
|
|
|
|
|
|
|
func TestAccDockerNetwork_ipv4(t *testing.T) {
|
|
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2018-10-29 01:36:21 -04:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2018-10-29 01:36:21 -04:00
|
|
|
Config: testAccDockerNetworkIPv4Config,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2018-10-29 01:36:21 -04:00
|
|
|
testAccNetworkIPv4(&n, true),
|
|
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2018-10-29 01:36:21 -04:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccNetworkIPv4(network *types.NetworkResource, internal bool) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if len(network.IPAM.Config) != 1 {
|
|
|
|
|
return fmt.Errorf("Bad value for IPAM configuration count: %d", len(network.IPAM.Config))
|
|
|
|
|
}
|
|
|
|
|
if network.IPAM.Config[0].Subnet != "10.0.1.0/24" {
|
|
|
|
|
return fmt.Errorf("Bad value for attribute 'subnet': %v", network.IPAM.Config[0].Subnet)
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkIPv4Config = `
|
|
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "bar"
|
|
|
|
|
ipam_config {
|
|
|
|
|
subnet = "10.0.1.0/24"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
`
|
|
|
|
|
|
|
|
|
|
func TestAccDockerNetwork_ipv6(t *testing.T) {
|
2019-11-23 08:42:05 -05:00
|
|
|
t.Skip("mavogel: need to fix ipv6 network state")
|
2018-10-29 01:36:21 -04:00
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2018-10-29 01:36:21 -04:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2018-10-29 01:36:21 -04:00
|
|
|
Config: testAccDockerNetworkIPv6Config,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2018-10-29 01:36:21 -04:00
|
|
|
testAccNetworkIPv6(&n, true),
|
|
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
// TODO mavogel: ipam config goes from 2->1
|
|
|
|
|
// probably suppress diff -> #219
|
|
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2018-10-29 01:36:21 -04:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccNetworkIPv6(network *types.NetworkResource, internal bool) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if !network.EnableIPv6 {
|
|
|
|
|
return fmt.Errorf("Bad value for attribute 'ipv6': %t", network.EnableIPv6)
|
|
|
|
|
}
|
|
|
|
|
if len(network.IPAM.Config) != 2 {
|
|
|
|
|
return fmt.Errorf("Bad value for IPAM configuration count: %d", len(network.IPAM.Config))
|
|
|
|
|
}
|
|
|
|
|
if network.IPAM.Config[1].Subnet != "fd00::1/64" {
|
2019-11-23 08:42:05 -05:00
|
|
|
return fmt.Errorf("Bad value for attribute 'subnet': %v", network.IPAM.Config[1].Subnet)
|
2018-10-29 01:36:21 -04:00
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkIPv6Config = `
|
|
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "bar"
|
|
|
|
|
ipv6 = true
|
|
|
|
|
ipam_config {
|
|
|
|
|
subnet = "fd00::1/64"
|
|
|
|
|
}
|
2019-11-23 08:42:05 -05:00
|
|
|
# TODO mavogel: Would work but BC - 219
|
|
|
|
|
# ipam_config {
|
|
|
|
|
# subnet = "10.0.1.0/24"
|
|
|
|
|
# }
|
2018-10-29 01:36:21 -04:00
|
|
|
}
|
|
|
|
|
`
|
|
|
|
|
|
2018-10-18 06:39:58 -04:00
|
|
|
func TestAccDockerNetwork_labels(t *testing.T) {
|
|
|
|
|
var n types.NetworkResource
|
2019-11-23 08:42:05 -05:00
|
|
|
resourceName := "docker_network.foo"
|
2018-10-18 06:39:58 -04:00
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
|
Providers: testAccProviders,
|
|
|
|
|
Steps: []resource.TestStep{
|
2019-03-01 16:02:17 -05:00
|
|
|
{
|
2018-10-18 06:39:58 -04:00
|
|
|
Config: testAccDockerNetworkLabelsConfig,
|
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
2019-11-23 08:42:05 -05:00
|
|
|
testAccNetwork(resourceName, &n),
|
2019-12-17 11:28:09 -05:00
|
|
|
testCheckLabelMap(resourceName, "labels",
|
2019-11-12 17:41:59 -05:00
|
|
|
map[string]string{
|
|
|
|
|
"com.docker.compose.network": "foo",
|
|
|
|
|
"com.docker.compose.project": "test",
|
|
|
|
|
},
|
|
|
|
|
),
|
2018-10-18 06:39:58 -04:00
|
|
|
),
|
|
|
|
|
},
|
2019-11-23 08:42:05 -05:00
|
|
|
{
|
|
|
|
|
ResourceName: resourceName,
|
|
|
|
|
ImportState: true,
|
|
|
|
|
ImportStateVerify: true,
|
|
|
|
|
},
|
2018-10-18 06:39:58 -04:00
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func testAccNetworkLabel(network *types.NetworkResource, name string, value string) resource.TestCheckFunc {
|
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
|
if network.Labels[name] != value {
|
|
|
|
|
return fmt.Errorf("Bad value for label '%s': %s", name, network.Labels[name])
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const testAccDockerNetworkLabelsConfig = `
|
2018-10-29 01:36:21 -04:00
|
|
|
resource "docker_network" "foo" {
|
|
|
|
|
name = "test_foo"
|
2019-11-12 17:41:59 -05:00
|
|
|
labels {
|
|
|
|
|
label = "com.docker.compose.network"
|
|
|
|
|
value = "foo"
|
|
|
|
|
}
|
|
|
|
|
labels {
|
|
|
|
|
label = "com.docker.compose.project"
|
|
|
|
|
value = "test"
|
2018-10-18 06:39:58 -04:00
|
|
|
}
|
2017-01-03 06:46:16 -05:00
|
|
|
}
|
|
|
|
|
`
|