terraform/builtin/providers/aws/resource_aws_eip_test.go

233 lines
5.2 KiB
Go
Raw Normal View History

2014-07-14 23:59:08 +02:00
package aws
import (
"fmt"
2014-07-28 18:04:58 +02:00
"strings"
2014-07-14 23:59:08 +02:00
"testing"
"github.com/awslabs/aws-sdk-go/aws"
"github.com/awslabs/aws-sdk-go/aws/awserr"
"github.com/awslabs/aws-sdk-go/service/ec2"
2014-07-14 23:59:08 +02:00
"github.com/hashicorp/terraform/helper/resource"
"github.com/hashicorp/terraform/terraform"
)
func TestAccAWSEIP_normal(t *testing.T) {
2014-07-14 23:59:08 +02:00
var conf ec2.Address
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccCheckAWSEIPDestroy,
Steps: []resource.TestStep{
resource.TestStep{
Config: testAccAWSEIPConfig,
Check: resource.ComposeTestCheckFunc(
testAccCheckAWSEIPExists("aws_eip.bar", &conf),
testAccCheckAWSEIPAttributes(&conf),
),
},
},
})
}
func TestAccAWSEIP_instance(t *testing.T) {
var conf ec2.Address
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccCheckAWSEIPDestroy,
Steps: []resource.TestStep{
resource.TestStep{
Config: testAccAWSEIPInstanceConfig,
Check: resource.ComposeTestCheckFunc(
testAccCheckAWSEIPExists("aws_eip.bar", &conf),
testAccCheckAWSEIPAttributes(&conf),
),
},
resource.TestStep{
Config: testAccAWSEIPInstanceConfig2,
Check: resource.ComposeTestCheckFunc(
testAccCheckAWSEIPExists("aws_eip.bar", &conf),
testAccCheckAWSEIPAttributes(&conf),
),
},
},
})
}
2015-04-26 04:30:37 +02:00
func TestAccAWSEIP_network_interface(t *testing.T) {
var conf ec2.Address
resource.Test(t, resource.TestCase{
PreCheck: func() { testAccPreCheck(t) },
Providers: testAccProviders,
CheckDestroy: testAccCheckAWSEIPDestroy,
Steps: []resource.TestStep{
resource.TestStep{
Config: testAccAWSEIPNetworkInterfaceConfig,
Check: resource.ComposeTestCheckFunc(
testAccCheckAWSEIPExists("aws_eip.bar", &conf),
testAccCheckAWSEIPAttributes(&conf),
testAccCheckAWSEIPAssociated(&conf),
),
},
},
})
}
2014-07-14 23:59:08 +02:00
func testAccCheckAWSEIPDestroy(s *terraform.State) error {
2015-04-16 22:05:55 +02:00
conn := testAccProvider.Meta().(*AWSClient).ec2conn
2014-07-14 23:59:08 +02:00
2014-09-17 02:44:42 +02:00
for _, rs := range s.RootModule().Resources {
2014-07-14 23:59:08 +02:00
if rs.Type != "aws_eip" {
continue
2014-07-15 00:30:31 +02:00
}
2014-07-14 23:59:08 +02:00
req := &ec2.DescribeAddressesInput{
PublicIPs: []*string{aws.String(rs.Primary.ID)},
}
describe, err := conn.DescribeAddresses(req)
2014-07-14 23:59:08 +02:00
if err == nil {
2014-07-15 00:30:31 +02:00
if len(describe.Addresses) != 0 &&
*describe.Addresses[0].PublicIP == rs.Primary.ID {
2014-07-14 23:59:08 +02:00
return fmt.Errorf("EIP still exists")
}
}
// Verify the error
providerErr, ok := err.(awserr.Error)
2014-07-14 23:59:08 +02:00
if !ok {
return err
}
2014-07-15 00:30:31 +02:00
if providerErr.Code() != "InvalidAllocationID.NotFound" {
2014-07-15 00:30:31 +02:00
return fmt.Errorf("Unexpected error: %s", err)
2014-07-14 23:59:08 +02:00
}
}
return nil
}
func testAccCheckAWSEIPAttributes(conf *ec2.Address) resource.TestCheckFunc {
return func(s *terraform.State) error {
if *conf.PublicIP == "" {
2014-07-14 23:59:08 +02:00
return fmt.Errorf("empty public_ip")
}
return nil
}
}
2015-04-26 04:30:37 +02:00
func testAccCheckAWSEIPAssociated(conf *ec2.Address) resource.TestCheckFunc {
return func(s *terraform.State) error {
if *conf.AssociationID == "" {
return fmt.Errorf("empty association_id")
}
return nil
}
}
2014-07-15 00:30:31 +02:00
func testAccCheckAWSEIPExists(n string, res *ec2.Address) resource.TestCheckFunc {
2014-07-14 23:59:08 +02:00
return func(s *terraform.State) error {
2014-09-17 02:44:42 +02:00
rs, ok := s.RootModule().Resources[n]
2014-07-14 23:59:08 +02:00
if !ok {
return fmt.Errorf("Not found: %s", n)
}
2014-09-17 02:44:42 +02:00
if rs.Primary.ID == "" {
2014-07-14 23:59:08 +02:00
return fmt.Errorf("No EIP ID is set")
}
2015-04-16 22:05:55 +02:00
conn := testAccProvider.Meta().(*AWSClient).ec2conn
2014-07-14 23:59:08 +02:00
2014-09-17 02:44:42 +02:00
if strings.Contains(rs.Primary.ID, "eipalloc") {
req := &ec2.DescribeAddressesInput{
AllocationIDs: []*string{aws.String(rs.Primary.ID)},
}
describe, err := conn.DescribeAddresses(req)
2014-07-28 18:04:58 +02:00
if err != nil {
return err
}
2014-07-14 23:59:08 +02:00
2014-07-28 18:04:58 +02:00
if len(describe.Addresses) != 1 ||
*describe.Addresses[0].AllocationID != rs.Primary.ID {
2014-07-28 18:04:58 +02:00
return fmt.Errorf("EIP not found")
}
*res = *describe.Addresses[0]
2014-07-14 23:59:08 +02:00
2014-07-28 18:04:58 +02:00
} else {
req := &ec2.DescribeAddressesInput{
PublicIPs: []*string{aws.String(rs.Primary.ID)},
}
describe, err := conn.DescribeAddresses(req)
2014-07-28 18:04:58 +02:00
if err != nil {
return err
}
2014-07-14 23:59:08 +02:00
2014-07-28 18:04:58 +02:00
if len(describe.Addresses) != 1 ||
*describe.Addresses[0].PublicIP != rs.Primary.ID {
2014-07-28 18:04:58 +02:00
return fmt.Errorf("EIP not found")
}
*res = *describe.Addresses[0]
2014-07-28 18:04:58 +02:00
}
2014-07-14 23:59:08 +02:00
return nil
}
}
const testAccAWSEIPConfig = `
resource "aws_eip" "bar" {
}
`
const testAccAWSEIPInstanceConfig = `
resource "aws_instance" "foo" {
# us-west-2
ami = "ami-4fccb37f"
instance_type = "m1.small"
}
resource "aws_eip" "bar" {
instance = "${aws_instance.foo.id}"
}
`
const testAccAWSEIPInstanceConfig2 = `
resource "aws_instance" "bar" {
# us-west-2
ami = "ami-4fccb37f"
instance_type = "m1.small"
}
resource "aws_eip" "bar" {
instance = "${aws_instance.bar.id}"
}
`
2015-04-26 04:30:37 +02:00
const testAccAWSEIPNetworkInterfaceConfig = `
resource "aws_vpc" "bar" {
cidr_block = "10.0.0.0/24"
}
resource "aws_internet_gateway" "bar" {
vpc_id = "${aws_vpc.bar.id}"
}
resource "aws_subnet" "bar" {
vpc_id = "${aws_vpc.bar.id}"
availability_zone = "us-west-2a"
cidr_block = "10.0.0.0/24"
}
resource "aws_network_interface" "bar" {
subnet_id = "${aws_subnet.bar.id}"
private_ips = ["10.0.0.10"]
security_groups = [ "${aws_vpc.bar.default_security_group_id}" ]
}
resource "aws_eip" "bar" {
vpc = "true"
network_interface = "${aws_network_interface.bar.id}"
}
`