github.com/pmcatominey/terraform@v0.7.0-rc2.0.20160708105029-1401a52a5cc5/builtin/providers/openstack/resource_openstack_lb_pool_v2_test.go (about) 1 package openstack 2 3 import ( 4 "fmt" 5 "log" 6 "testing" 7 8 "github.com/hashicorp/terraform/helper/resource" 9 "github.com/hashicorp/terraform/terraform" 10 "github.com/rackspace/gophercloud/openstack/networking/v2/extensions/lbaas_v2/pools" 11 ) 12 13 func TestAccLBV2Pool_basic(t *testing.T) { 14 var pool pools.Pool 15 16 resource.Test(t, resource.TestCase{ 17 PreCheck: func() { testAccPreCheck(t) }, 18 Providers: testAccProviders, 19 CheckDestroy: testAccCheckLBV2PoolDestroy, 20 Steps: []resource.TestStep{ 21 resource.TestStep{ 22 Config: TestAccLBV2PoolConfig_basic, 23 Check: resource.ComposeTestCheckFunc( 24 testAccCheckLBV2PoolExists(t, "openstack_lb_pool_v2.pool_1", &pool), 25 ), 26 }, 27 resource.TestStep{ 28 Config: TestAccLBV2PoolConfig_update, 29 Check: resource.ComposeTestCheckFunc( 30 resource.TestCheckResourceAttr("openstack_lb_pool_v2.pool_1", "name", "tf_test_pool_update"), 31 ), 32 }, 33 }, 34 }) 35 } 36 37 func testAccCheckLBV2PoolDestroy(s *terraform.State) error { 38 config := testAccProvider.Meta().(*Config) 39 networkingClient, err := config.networkingV2Client(OS_REGION_NAME) 40 if err != nil { 41 return fmt.Errorf("(testAccCheckLBV2PoolDestroy) Error creating OpenStack networking client: %s", err) 42 } 43 44 for _, rs := range s.RootModule().Resources { 45 log.Printf("[FINDME] rs TYPE is: %T", rs) 46 47 if rs.Type != "openstack_lb_pool_v2" { 48 continue 49 } 50 51 _, err := pools.Get(networkingClient, rs.Primary.ID).Extract() 52 if err == nil { 53 return fmt.Errorf("Pool still exists: %s", rs.Primary.ID) 54 } 55 } 56 57 return nil 58 } 59 60 func testAccCheckLBV2PoolExists(t *testing.T, n string, pool *pools.Pool) resource.TestCheckFunc { 61 return func(s *terraform.State) error { 62 rs, ok := s.RootModule().Resources[n] 63 if !ok { 64 return fmt.Errorf("Not found: %s", n) 65 } 66 67 if rs.Primary.ID == "" { 68 return fmt.Errorf("No ID is set") 69 } 70 71 config := testAccProvider.Meta().(*Config) 72 networkingClient, err := config.networkingV2Client(OS_REGION_NAME) 73 if err != nil { 74 return fmt.Errorf("(testAccCheckLBV2PoolExists) Error creating OpenStack networking client: %s", err) 75 } 76 77 found, err := pools.Get(networkingClient, rs.Primary.ID).Extract() 78 if err != nil { 79 return err 80 } 81 82 if found.ID != rs.Primary.ID { 83 return fmt.Errorf("Member not found") 84 } 85 86 *pool = *found 87 88 return nil 89 } 90 } 91 92 var TestAccLBV2PoolConfig_basic = fmt.Sprintf(` 93 resource "openstack_networking_network_v2" "network_1" { 94 name = "tf_test_network" 95 admin_state_up = "true" 96 } 97 98 resource "openstack_networking_subnet_v2" "subnet_1" { 99 network_id = "${openstack_networking_network_v2.network_1.id}" 100 cidr = "192.168.199.0/24" 101 ip_version = 4 102 name = "tf_test_subnet" 103 } 104 105 resource "openstack_lb_loadbalancer_v2" "loadbalancer_1" { 106 vip_subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" 107 name = "tf_test_loadbalancer_v2" 108 } 109 110 resource "openstack_lb_listener_v2" "listener_1" { 111 protocol = "HTTP" 112 protocol_port = 8080 113 loadbalancer_id = "${openstack_lb_loadbalancer_v2.loadbalancer_1.id}" 114 name = "tf_test_listener" 115 } 116 117 resource "openstack_lb_pool_v2" "pool_1" { 118 protocol = "HTTP" 119 lb_method = "ROUND_ROBIN" 120 listener_id = "${openstack_lb_listener_v2.listener_1.id}" 121 name = "tf_test_pool" 122 }`) 123 124 var TestAccLBV2PoolConfig_update = fmt.Sprintf(` 125 resource "openstack_networking_network_v2" "network_1" { 126 name = "tf_test_network" 127 admin_state_up = "true" 128 } 129 130 resource "openstack_networking_subnet_v2" "subnet_1" { 131 network_id = "${openstack_networking_network_v2.network_1.id}" 132 cidr = "192.168.199.0/24" 133 ip_version = 4 134 name = "tf_test_subnet" 135 } 136 137 resource "openstack_lb_loadbalancer_v2" "loadbalancer_1" { 138 vip_subnet_id = "${openstack_networking_subnet_v2.subnet_1.id}" 139 name = "tf_test_loadbalancer_v2" 140 } 141 142 resource "openstack_lb_listener_v2" "listener_1" { 143 protocol = "HTTP" 144 protocol_port = 8080 145 loadbalancer_id = "${openstack_lb_loadbalancer_v2.loadbalancer_1.id}" 146 name = "tf_test_listener" 147 } 148 149 resource "openstack_lb_pool_v2" "pool_1" { 150 protocol = "HTTP" 151 lb_method = "LEAST_CONNECTIONS" 152 listener_id = "${openstack_lb_listener_v2.listener_1.id}" 153 name = "tf_test_pool_update" 154 admin_state_up = "true" 155 }`)