mirror of
https://github.com/opentofu/opentofu.git
synced 2025-02-25 18:45:20 -06:00
[clc] collapse tests, code in server dep for lbp
This commit is contained in:
parent
8de8c6884d
commit
c857b8af58
@ -109,6 +109,7 @@ func resourceCLCLoadBalancerUpdate(d *schema.ResourceData, meta interface{}) err
|
|||||||
update.Status = d.Get("status").(string)
|
update.Status = d.Get("status").(string)
|
||||||
}
|
}
|
||||||
if update.Name != "" || update.Description != "" || update.Status != "" {
|
if update.Name != "" || update.Description != "" || update.Status != "" {
|
||||||
|
update.Name = d.Get("name").(string) // required on every PUT
|
||||||
err := client.LB.Update(dc, id, update)
|
err := client.LB.Update(dc, id, update)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Failed updating load balancer under %v/%v: %v", dc, id, err)
|
return fmt.Errorf("Failed updating load balancer under %v/%v: %v", dc, id, err)
|
||||||
|
@ -29,6 +29,15 @@ func TestAccLBPoolBasic(t *testing.T) {
|
|||||||
resource.TestCheckResourceAttr("clc_load_balancer_pool.acc_test_pool", "port", "80"),
|
resource.TestCheckResourceAttr("clc_load_balancer_pool.acc_test_pool", "port", "80"),
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
|
resource.TestStep{
|
||||||
|
Config: testAccCheckLBPConfigUpdates,
|
||||||
|
Check: resource.ComposeTestCheckFunc(
|
||||||
|
testAccCheckLBPExists("clc_load_balancer_pool.acc_test_pool", &pool),
|
||||||
|
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lbp", "description", "description modified"),
|
||||||
|
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lbp", "status", "disabled"),
|
||||||
|
resource.TestCheckResourceAttr("clc_load_balancer_pool.acc_test_pool", "nodes.0.privatePort", "8080"),
|
||||||
|
),
|
||||||
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -85,7 +94,7 @@ resource "clc_group" "acc_test_lbp_group" {
|
|||||||
# need a server here because we need to reference an ip owned by this account
|
# need a server here because we need to reference an ip owned by this account
|
||||||
resource "clc_server" "acc_test_lbp_server" {
|
resource "clc_server" "acc_test_lbp_server" {
|
||||||
name_template = "node"
|
name_template = "node"
|
||||||
description = "load balanced in ${clc_load_balancer.acc_test_lbp.id}"
|
description = "load balanced"
|
||||||
source_server_id = "UBUNTU-14-64-TEMPLATE"
|
source_server_id = "UBUNTU-14-64-TEMPLATE"
|
||||||
type = "standard"
|
type = "standard"
|
||||||
group_id = "${clc_group.acc_test_lbp_group.id}"
|
group_id = "${clc_group.acc_test_lbp_group.id}"
|
||||||
@ -101,6 +110,7 @@ resource "clc_load_balancer" "acc_test_lbp" {
|
|||||||
name = "acc_test_lb"
|
name = "acc_test_lb"
|
||||||
description = "load balancer test"
|
description = "load balancer test"
|
||||||
status = "enabled"
|
status = "enabled"
|
||||||
|
depends_on = ["clc_server.acc_test_lbp_server"]
|
||||||
}
|
}
|
||||||
|
|
||||||
resource "clc_load_balancer_pool" "acc_test_pool" {
|
resource "clc_load_balancer_pool" "acc_test_pool" {
|
||||||
@ -113,5 +123,51 @@ resource "clc_load_balancer_pool" "acc_test_pool" {
|
|||||||
ipAddress = "${clc_server.acc_test_lbp_server.private_ip_address}"
|
ipAddress = "${clc_server.acc_test_lbp_server.private_ip_address}"
|
||||||
privatePort = 80
|
privatePort = 80
|
||||||
}
|
}
|
||||||
|
depends_on = ["clc_server.acc_test_lbp_server"]
|
||||||
|
}
|
||||||
|
`
|
||||||
|
|
||||||
|
const testAccCheckLBPConfigUpdates = `
|
||||||
|
variable "dc" { default = "IL1" }
|
||||||
|
|
||||||
|
resource "clc_group" "acc_test_lbp_group" {
|
||||||
|
location_id = "${var.dc}"
|
||||||
|
name = "acc_test_lbp_group"
|
||||||
|
parent = "Default Group"
|
||||||
|
}
|
||||||
|
|
||||||
|
# need a server here because we need to reference an ip owned by this account
|
||||||
|
resource "clc_server" "acc_test_lbp_server" {
|
||||||
|
name_template = "node"
|
||||||
|
description = "load balanced"
|
||||||
|
source_server_id = "UBUNTU-14-64-TEMPLATE"
|
||||||
|
type = "standard"
|
||||||
|
group_id = "${clc_group.acc_test_lbp_group.id}"
|
||||||
|
cpu = 1
|
||||||
|
memory_mb = 1024
|
||||||
|
password = "Green123$"
|
||||||
|
power_state = "started"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "clc_load_balancer" "acc_test_lbp" {
|
||||||
|
data_center = "${var.dc}"
|
||||||
|
name = "acc_test_lb"
|
||||||
|
description = "description modified"
|
||||||
|
status = "disabled"
|
||||||
|
depends_on = ["clc_server.acc_test_lbp_server"]
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "clc_load_balancer_pool" "acc_test_pool" {
|
||||||
|
port = 80
|
||||||
|
data_center = "${var.dc}"
|
||||||
|
load_balancer = "${clc_load_balancer.acc_test_lbp.id}"
|
||||||
|
nodes
|
||||||
|
{
|
||||||
|
status = "enabled"
|
||||||
|
ipAddress = "${clc_server.acc_test_lbp_server.private_ip_address}"
|
||||||
|
privatePort = 8080
|
||||||
|
}
|
||||||
|
depends_on = ["clc_server.acc_test_lbp_server"]
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
|
@ -1,101 +1,3 @@
|
|||||||
package clc
|
package clc
|
||||||
|
|
||||||
import (
|
// clc_load_balancer covered by clc_load_balancer_pool tests: resource_clc_load_balancer_pool_test.go
|
||||||
"fmt"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
clc "github.com/CenturyLinkCloud/clc-sdk"
|
|
||||||
lb "github.com/CenturyLinkCloud/clc-sdk/lb"
|
|
||||||
"github.com/hashicorp/terraform/helper/resource"
|
|
||||||
"github.com/hashicorp/terraform/terraform"
|
|
||||||
)
|
|
||||||
|
|
||||||
// things to test:
|
|
||||||
// updates name/desc
|
|
||||||
// toggles status
|
|
||||||
// created w/o pool
|
|
||||||
|
|
||||||
func TestAccLoadBalancerBasic(t *testing.T) {
|
|
||||||
var resp lb.LoadBalancer
|
|
||||||
resource.Test(t, resource.TestCase{
|
|
||||||
PreCheck: func() { testAccPreCheck(t) },
|
|
||||||
Providers: testAccProviders,
|
|
||||||
CheckDestroy: testAccCheckLBDestroy,
|
|
||||||
Steps: []resource.TestStep{
|
|
||||||
resource.TestStep{
|
|
||||||
Config: testAccCheckLBConfigBasic,
|
|
||||||
Check: resource.ComposeTestCheckFunc(
|
|
||||||
testAccCheckLBExists("clc_load_balancer.acc_test_lb", &resp),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "name", "acc_test_lb"),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "data_center", testAccDC),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "status", "enabled"),
|
|
||||||
),
|
|
||||||
},
|
|
||||||
// update simple attrs
|
|
||||||
resource.TestStep{
|
|
||||||
Config: testAccCheckLBConfigNameDesc,
|
|
||||||
Check: resource.ComposeTestCheckFunc(
|
|
||||||
testAccCheckLBExists("clc_load_balancer.acc_test_lb", &resp),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "name", "foobar"),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "description", "foobar"),
|
|
||||||
resource.TestCheckResourceAttr("clc_load_balancer.acc_test_lb", "status", "disabled"),
|
|
||||||
),
|
|
||||||
},
|
|
||||||
},
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
func testAccCheckLBDestroy(s *terraform.State) error {
|
|
||||||
client := testAccProvider.Meta().(*clc.Client)
|
|
||||||
for _, rs := range s.RootModule().Resources {
|
|
||||||
if rs.Type != "clc_load_balancer" {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
if _, err := client.LB.Get(testAccDC, rs.Primary.ID); err == nil {
|
|
||||||
return fmt.Errorf("LB still exists")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func testAccCheckLBExists(n string, resp *lb.LoadBalancer) resource.TestCheckFunc {
|
|
||||||
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")
|
|
||||||
}
|
|
||||||
client := testAccProvider.Meta().(*clc.Client)
|
|
||||||
l, err := client.LB.Get(testAccDC, rs.Primary.ID)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if l.ID != rs.Primary.ID {
|
|
||||||
return fmt.Errorf("LB not found")
|
|
||||||
}
|
|
||||||
*resp = *l
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const testAccCheckLBConfigBasic = `
|
|
||||||
variable "dc" { default = "IL1" }
|
|
||||||
|
|
||||||
resource "clc_load_balancer" "acc_test_lb" {
|
|
||||||
data_center = "${var.dc}"
|
|
||||||
name = "acc_test_lb"
|
|
||||||
description = "load balancer test"
|
|
||||||
status = "enabled"
|
|
||||||
}`
|
|
||||||
|
|
||||||
const testAccCheckLBConfigNameDesc = `
|
|
||||||
variable "dc" { default = "IL1" }
|
|
||||||
|
|
||||||
resource "clc_load_balancer" "acc_test_lb" {
|
|
||||||
data_center = "${var.dc}"
|
|
||||||
name = "foobar"
|
|
||||||
description = "foobar"
|
|
||||||
status = "disabled"
|
|
||||||
}`
|
|
||||||
|
Loading…
Reference in New Issue
Block a user