2016-08-13 20:37:46 +02:00
|
|
|
package azurerm
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2016-09-21 17:06:51 +02:00
|
|
|
"net/http"
|
2016-08-13 20:37:46 +02:00
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/terraform/helper/acctest"
|
|
|
|
"github.com/hashicorp/terraform/helper/resource"
|
|
|
|
"github.com/hashicorp/terraform/terraform"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestAccAzureRMVirtualNetworkPeering_basic(t *testing.T) {
|
|
|
|
ri := acctest.RandInt()
|
|
|
|
config := fmt.Sprintf(testAccAzureRMVirtualNetworkPeering_basic, ri, ri, ri, ri, ri)
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
CheckDestroy: testCheckAzureRMVirtualNetworkPeeringDestroy,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: config,
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test1"),
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test2"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_virtual_network_access", "true"),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-09-29 18:14:20 +02:00
|
|
|
func TestAccAzureRMVirtualNetworkPeering_disappears(t *testing.T) {
|
|
|
|
ri := acctest.RandInt()
|
|
|
|
config := fmt.Sprintf(testAccAzureRMVirtualNetworkPeering_basic, ri, ri, ri, ri, ri)
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
CheckDestroy: testCheckAzureRMVirtualNetworkPeeringDestroy,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: config,
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test1"),
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test2"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_virtual_network_access", "true"),
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringDisappears("azurerm_virtual_network_peering.test1"),
|
|
|
|
),
|
|
|
|
ExpectNonEmptyPlan: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2016-08-13 20:37:46 +02:00
|
|
|
func TestAccAzureRMVirtualNetworkPeering_update(t *testing.T) {
|
|
|
|
ri := acctest.RandInt()
|
|
|
|
preConfig := fmt.Sprintf(testAccAzureRMVirtualNetworkPeering_basic, ri, ri, ri, ri, ri)
|
|
|
|
postConfig := fmt.Sprintf(testAccAzureRMVirtualNetworkPeering_basicUpdate, ri, ri, ri, ri, ri)
|
|
|
|
|
|
|
|
resource.Test(t, resource.TestCase{
|
|
|
|
PreCheck: func() { testAccPreCheck(t) },
|
|
|
|
Providers: testAccProviders,
|
|
|
|
CheckDestroy: testCheckAzureRMVirtualNetworkPeeringDestroy,
|
|
|
|
Steps: []resource.TestStep{
|
|
|
|
resource.TestStep{
|
|
|
|
Config: preConfig,
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test1"),
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test2"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_forwarded_traffic", "false"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_forwarded_traffic", "false"),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
|
|
|
|
resource.TestStep{
|
|
|
|
Config: postConfig,
|
|
|
|
Check: resource.ComposeTestCheckFunc(
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test1"),
|
|
|
|
testCheckAzureRMVirtualNetworkPeeringExists("azurerm_virtual_network_peering.test2"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_virtual_network_access", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test1", "allow_forwarded_traffic", "true"),
|
|
|
|
resource.TestCheckResourceAttr(
|
|
|
|
"azurerm_virtual_network_peering.test2", "allow_forwarded_traffic", "true"),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func testCheckAzureRMVirtualNetworkPeeringExists(name string) resource.TestCheckFunc {
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
// Ensure we have enough information in state to look up in API
|
|
|
|
rs, ok := s.RootModule().Resources[name]
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("Not found: %s", name)
|
|
|
|
}
|
|
|
|
|
|
|
|
name := rs.Primary.Attributes["name"]
|
|
|
|
vnetName := rs.Primary.Attributes["virtual_network_name"]
|
|
|
|
resourceGroup, hasResourceGroup := rs.Primary.Attributes["resource_group_name"]
|
|
|
|
if !hasResourceGroup {
|
|
|
|
return fmt.Errorf("Bad: no resource group found in state for virtual network peering: %s", name)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure resource group/virtual network peering combination exists in API
|
|
|
|
conn := testAccProvider.Meta().(*ArmClient).vnetPeeringsClient
|
|
|
|
|
|
|
|
resp, err := conn.Get(resourceGroup, vnetName, name)
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Bad: Get on vnetPeeringsClient: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.StatusCode == http.StatusNotFound {
|
|
|
|
return fmt.Errorf("Bad: Virtual Network Peering %q (resource group: %q) does not exist", name, resourceGroup)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-29 18:14:20 +02:00
|
|
|
func testCheckAzureRMVirtualNetworkPeeringDisappears(name string) resource.TestCheckFunc {
|
|
|
|
return func(s *terraform.State) error {
|
|
|
|
// Ensure we have enough information in state to look up in API
|
|
|
|
rs, ok := s.RootModule().Resources[name]
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("Not found: %s", name)
|
|
|
|
}
|
|
|
|
|
|
|
|
name := rs.Primary.Attributes["name"]
|
|
|
|
vnetName := rs.Primary.Attributes["virtual_network_name"]
|
|
|
|
resourceGroup, hasResourceGroup := rs.Primary.Attributes["resource_group_name"]
|
|
|
|
if !hasResourceGroup {
|
|
|
|
return fmt.Errorf("Bad: no resource group found in state for virtual network peering: %s", name)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Ensure resource group/virtual network peering combination exists in API
|
|
|
|
conn := testAccProvider.Meta().(*ArmClient).vnetPeeringsClient
|
|
|
|
|
|
|
|
_, err := conn.Delete(resourceGroup, vnetName, name, make(chan struct{}))
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("Bad: Delete on vnetPeeringsClient: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-13 20:37:46 +02:00
|
|
|
func testCheckAzureRMVirtualNetworkPeeringDestroy(s *terraform.State) error {
|
|
|
|
conn := testAccProvider.Meta().(*ArmClient).vnetPeeringsClient
|
|
|
|
|
|
|
|
for _, rs := range s.RootModule().Resources {
|
|
|
|
if rs.Type != "azurerm_virtual_network_peering" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
name := rs.Primary.Attributes["name"]
|
|
|
|
vnetName := rs.Primary.Attributes["virtual_network_name"]
|
|
|
|
resourceGroup := rs.Primary.Attributes["resource_group_name"]
|
|
|
|
|
|
|
|
resp, err := conn.Get(resourceGroup, vnetName, name)
|
|
|
|
if err != nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
if resp.StatusCode != http.StatusNotFound {
|
|
|
|
return fmt.Errorf("Virtual Network Peering sitll exists:\n%#v", resp.Properties)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var testAccAzureRMVirtualNetworkPeering_basic = `
|
|
|
|
resource "azurerm_resource_group" "test" {
|
2016-09-28 12:27:07 +02:00
|
|
|
name = "acctestRG-%d"
|
2016-08-13 20:37:46 +02:00
|
|
|
location = "West US"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network" "test1" {
|
|
|
|
name = "acctestvirtnet-1-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
address_space = ["10.0.1.0/24"]
|
|
|
|
location = "${azurerm_resource_group.test.location}"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network" "test2" {
|
|
|
|
name = "acctestvirtnet-2-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
address_space = ["10.0.2.0/24"]
|
|
|
|
location = "${azurerm_resource_group.test.location}"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network_peering" "test1" {
|
|
|
|
name = "acctestpeer-1-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
virtual_network_name = "${azurerm_virtual_network.test1.name}"
|
|
|
|
remote_virtual_network_id = "${azurerm_virtual_network.test2.id}"
|
|
|
|
allow_virtual_network_access = true
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network_peering" "test2" {
|
|
|
|
name = "acctestpeer-2-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
virtual_network_name = "${azurerm_virtual_network.test2.name}"
|
|
|
|
remote_virtual_network_id = "${azurerm_virtual_network.test1.id}"
|
|
|
|
allow_virtual_network_access = true
|
|
|
|
}
|
|
|
|
`
|
|
|
|
|
|
|
|
var testAccAzureRMVirtualNetworkPeering_basicUpdate = `
|
|
|
|
resource "azurerm_resource_group" "test" {
|
2016-09-28 12:27:07 +02:00
|
|
|
name = "acctestRG-%d"
|
2016-08-13 20:37:46 +02:00
|
|
|
location = "West US"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network" "test1" {
|
|
|
|
name = "acctestvirtnet-1-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
address_space = ["10.0.1.0/24"]
|
|
|
|
location = "${azurerm_resource_group.test.location}"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network" "test2" {
|
|
|
|
name = "acctestvirtnet-2-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
address_space = ["10.0.2.0/24"]
|
|
|
|
location = "${azurerm_resource_group.test.location}"
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network_peering" "test1" {
|
|
|
|
name = "acctestpeer-1-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
virtual_network_name = "${azurerm_virtual_network.test1.name}"
|
|
|
|
remote_virtual_network_id = "${azurerm_virtual_network.test2.id}"
|
|
|
|
allow_forwarded_traffic = true
|
|
|
|
allow_virtual_network_access = true
|
|
|
|
}
|
|
|
|
|
|
|
|
resource "azurerm_virtual_network_peering" "test2" {
|
|
|
|
name = "acctestpeer-2-%d"
|
|
|
|
resource_group_name = "${azurerm_resource_group.test.name}"
|
|
|
|
virtual_network_name = "${azurerm_virtual_network.test2.name}"
|
|
|
|
remote_virtual_network_id = "${azurerm_virtual_network.test1.id}"
|
|
|
|
allow_forwarded_traffic = true
|
|
|
|
allow_virtual_network_access = true
|
|
|
|
}
|
|
|
|
`
|