github.com/danp/terraform@v0.9.5-0.20170426144147-39d740081351/builtin/providers/azurerm/resource_arm_loadbalancer_rule_test.go (about) 1 package azurerm 2 3 import ( 4 "fmt" 5 "os" 6 "testing" 7 8 "github.com/Azure/azure-sdk-for-go/arm/network" 9 "github.com/hashicorp/terraform/helper/acctest" 10 "github.com/hashicorp/terraform/helper/resource" 11 "github.com/hashicorp/terraform/terraform" 12 ) 13 14 func TestResourceAzureRMLoadBalancerRuleNameLabel_validation(t *testing.T) { 15 cases := []struct { 16 Value string 17 ErrCount int 18 }{ 19 { 20 Value: "-word", 21 ErrCount: 1, 22 }, 23 { 24 Value: "testing-", 25 ErrCount: 1, 26 }, 27 { 28 Value: "test#test", 29 ErrCount: 1, 30 }, 31 { 32 Value: acctest.RandStringFromCharSet(81, "abcdedfed"), 33 ErrCount: 1, 34 }, 35 { 36 Value: "test.rule", 37 ErrCount: 0, 38 }, 39 { 40 Value: "test_rule", 41 ErrCount: 0, 42 }, 43 { 44 Value: "test-rule", 45 ErrCount: 0, 46 }, 47 { 48 Value: "TestRule", 49 ErrCount: 0, 50 }, 51 { 52 Value: "Test123Rule", 53 ErrCount: 0, 54 }, 55 { 56 Value: "TestRule", 57 ErrCount: 0, 58 }, 59 } 60 61 for _, tc := range cases { 62 _, errors := validateArmLoadBalancerRuleName(tc.Value, "azurerm_lb_rule") 63 64 if len(errors) != tc.ErrCount { 65 t.Fatalf("Expected the Azure RM LoadBalancer Rule Name Label to trigger a validation error") 66 } 67 } 68 } 69 70 func TestAccAzureRMLoadBalancerRule_basic(t *testing.T) { 71 var lb network.LoadBalancer 72 ri := acctest.RandInt() 73 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 74 75 subscriptionID := os.Getenv("ARM_SUBSCRIPTION_ID") 76 lbRule_id := fmt.Sprintf( 77 "/subscriptions/%s/resourceGroups/acctestrg-%d/providers/Microsoft.Network/loadBalancers/arm-test-loadbalancer-%d/loadBalancingRules/%s", 78 subscriptionID, ri, ri, lbRuleName) 79 80 resource.Test(t, resource.TestCase{ 81 PreCheck: func() { testAccPreCheck(t) }, 82 Providers: testAccProviders, 83 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 84 Steps: []resource.TestStep{ 85 { 86 Config: testAccAzureRMLoadBalancerRule_basic(ri, lbRuleName), 87 Check: resource.ComposeTestCheckFunc( 88 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 89 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 90 resource.TestCheckResourceAttr( 91 "azurerm_lb_rule.test", "id", lbRule_id), 92 ), 93 }, 94 }, 95 }) 96 } 97 98 func TestAccAzureRMLoadBalancerRule_removal(t *testing.T) { 99 var lb network.LoadBalancer 100 ri := acctest.RandInt() 101 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 102 103 resource.Test(t, resource.TestCase{ 104 PreCheck: func() { testAccPreCheck(t) }, 105 Providers: testAccProviders, 106 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 107 Steps: []resource.TestStep{ 108 { 109 Config: testAccAzureRMLoadBalancerRule_basic(ri, lbRuleName), 110 Check: resource.ComposeTestCheckFunc( 111 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 112 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 113 ), 114 }, 115 { 116 Config: testAccAzureRMLoadBalancerRule_removal(ri), 117 Check: resource.ComposeTestCheckFunc( 118 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 119 testCheckAzureRMLoadBalancerRuleNotExists(lbRuleName, &lb), 120 ), 121 }, 122 }, 123 }) 124 } 125 126 // https://github.com/hashicorp/terraform/issues/9424 127 func TestAccAzureRMLoadBalancerRule_inconsistentReads(t *testing.T) { 128 var lb network.LoadBalancer 129 ri := acctest.RandInt() 130 backendPoolName := fmt.Sprintf("LbPool-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 131 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 132 probeName := fmt.Sprintf("LbProbe-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 133 134 resource.Test(t, resource.TestCase{ 135 PreCheck: func() { testAccPreCheck(t) }, 136 Providers: testAccProviders, 137 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 138 Steps: []resource.TestStep{ 139 { 140 Config: testAccAzureRMLoadBalancerRule_inconsistentRead(ri, backendPoolName, probeName, lbRuleName), 141 Check: resource.ComposeTestCheckFunc( 142 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 143 testCheckAzureRMLoadBalancerBackEndAddressPoolExists(backendPoolName, &lb), 144 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 145 testCheckAzureRMLoadBalancerProbeExists(probeName, &lb), 146 ), 147 }, 148 }, 149 }) 150 } 151 152 func TestAccAzureRMLoadBalancerRule_update(t *testing.T) { 153 var lb network.LoadBalancer 154 ri := acctest.RandInt() 155 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 156 lbRule2Name := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 157 158 subscriptionID := os.Getenv("ARM_SUBSCRIPTION_ID") 159 lbRuleID := fmt.Sprintf( 160 "/subscriptions/%s/resourceGroups/acctestrg-%d/providers/Microsoft.Network/loadBalancers/arm-test-loadbalancer-%d/loadBalancingRules/%s", 161 subscriptionID, ri, ri, lbRuleName) 162 163 lbRule2ID := fmt.Sprintf( 164 "/subscriptions/%s/resourceGroups/acctestrg-%d/providers/Microsoft.Network/loadBalancers/arm-test-loadbalancer-%d/loadBalancingRules/%s", 165 subscriptionID, ri, ri, lbRule2Name) 166 167 resource.Test(t, resource.TestCase{ 168 PreCheck: func() { testAccPreCheck(t) }, 169 Providers: testAccProviders, 170 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 171 Steps: []resource.TestStep{ 172 { 173 Config: testAccAzureRMLoadBalancerRule_multipleRules(ri, lbRuleName, lbRule2Name), 174 Check: resource.ComposeTestCheckFunc( 175 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 176 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 177 testCheckAzureRMLoadBalancerRuleExists(lbRule2Name, &lb), 178 resource.TestCheckResourceAttr("azurerm_lb_rule.test", "id", lbRuleID), 179 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "id", lbRule2ID), 180 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "frontend_port", "3390"), 181 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "backend_port", "3390"), 182 ), 183 }, 184 { 185 Config: testAccAzureRMLoadBalancerRule_multipleRulesUpdate(ri, lbRuleName, lbRule2Name), 186 Check: resource.ComposeTestCheckFunc( 187 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 188 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 189 testCheckAzureRMLoadBalancerRuleExists(lbRule2Name, &lb), 190 resource.TestCheckResourceAttr("azurerm_lb_rule.test", "id", lbRuleID), 191 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "id", lbRule2ID), 192 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "frontend_port", "3391"), 193 resource.TestCheckResourceAttr("azurerm_lb_rule.test2", "backend_port", "3391"), 194 ), 195 }, 196 }, 197 }) 198 } 199 200 func TestAccAzureRMLoadBalancerRule_reapply(t *testing.T) { 201 var lb network.LoadBalancer 202 ri := acctest.RandInt() 203 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 204 205 deleteRuleState := func(s *terraform.State) error { 206 return s.Remove("azurerm_lb_rule.test") 207 } 208 209 resource.Test(t, resource.TestCase{ 210 PreCheck: func() { testAccPreCheck(t) }, 211 Providers: testAccProviders, 212 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 213 Steps: []resource.TestStep{ 214 { 215 Config: testAccAzureRMLoadBalancerRule_basic(ri, lbRuleName), 216 Check: resource.ComposeTestCheckFunc( 217 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 218 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 219 deleteRuleState, 220 ), 221 ExpectNonEmptyPlan: true, 222 }, 223 { 224 Config: testAccAzureRMLoadBalancerRule_basic(ri, lbRuleName), 225 Check: resource.ComposeTestCheckFunc( 226 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 227 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 228 ), 229 }, 230 }, 231 }) 232 } 233 234 func TestAccAzureRMLoadBalancerRule_disappears(t *testing.T) { 235 var lb network.LoadBalancer 236 ri := acctest.RandInt() 237 lbRuleName := fmt.Sprintf("LbRule-%s", acctest.RandStringFromCharSet(8, acctest.CharSetAlpha)) 238 239 resource.Test(t, resource.TestCase{ 240 PreCheck: func() { testAccPreCheck(t) }, 241 Providers: testAccProviders, 242 CheckDestroy: testCheckAzureRMLoadBalancerDestroy, 243 Steps: []resource.TestStep{ 244 { 245 Config: testAccAzureRMLoadBalancerRule_basic(ri, lbRuleName), 246 Check: resource.ComposeTestCheckFunc( 247 testCheckAzureRMLoadBalancerExists("azurerm_lb.test", &lb), 248 testCheckAzureRMLoadBalancerRuleExists(lbRuleName, &lb), 249 testCheckAzureRMLoadBalancerRuleDisappears(lbRuleName, &lb), 250 ), 251 ExpectNonEmptyPlan: true, 252 }, 253 }, 254 }) 255 } 256 257 func testCheckAzureRMLoadBalancerRuleExists(lbRuleName string, lb *network.LoadBalancer) resource.TestCheckFunc { 258 return func(s *terraform.State) error { 259 _, _, exists := findLoadBalancerRuleByName(lb, lbRuleName) 260 if !exists { 261 return fmt.Errorf("A LoadBalancer Rule with name %q cannot be found.", lbRuleName) 262 } 263 264 return nil 265 } 266 } 267 268 func testCheckAzureRMLoadBalancerRuleNotExists(lbRuleName string, lb *network.LoadBalancer) resource.TestCheckFunc { 269 return func(s *terraform.State) error { 270 _, _, exists := findLoadBalancerRuleByName(lb, lbRuleName) 271 if exists { 272 return fmt.Errorf("A LoadBalancer Rule with name %q has been found.", lbRuleName) 273 } 274 275 return nil 276 } 277 } 278 279 func testCheckAzureRMLoadBalancerRuleDisappears(ruleName string, lb *network.LoadBalancer) resource.TestCheckFunc { 280 return func(s *terraform.State) error { 281 conn := testAccProvider.Meta().(*ArmClient).loadBalancerClient 282 283 _, i, exists := findLoadBalancerRuleByName(lb, ruleName) 284 if !exists { 285 return fmt.Errorf("A Rule with name %q cannot be found.", ruleName) 286 } 287 288 currentRules := *lb.LoadBalancerPropertiesFormat.LoadBalancingRules 289 rules := append(currentRules[:i], currentRules[i+1:]...) 290 lb.LoadBalancerPropertiesFormat.LoadBalancingRules = &rules 291 292 id, err := parseAzureResourceID(*lb.ID) 293 if err != nil { 294 return err 295 } 296 297 _, err = conn.CreateOrUpdate(id.ResourceGroup, *lb.Name, *lb, make(chan struct{})) 298 if err != nil { 299 return fmt.Errorf("Error Creating/Updating LoadBalancer %s", err) 300 } 301 302 _, err = conn.Get(id.ResourceGroup, *lb.Name, "") 303 return err 304 } 305 } 306 307 func testAccAzureRMLoadBalancerRule_basic(rInt int, lbRuleName string) string { 308 return fmt.Sprintf(` 309 resource "azurerm_resource_group" "test" { 310 name = "acctestrg-%d" 311 location = "West US" 312 } 313 314 resource "azurerm_public_ip" "test" { 315 name = "test-ip-%d" 316 location = "West US" 317 resource_group_name = "${azurerm_resource_group.test.name}" 318 public_ip_address_allocation = "static" 319 } 320 321 resource "azurerm_lb" "test" { 322 name = "arm-test-loadbalancer-%d" 323 location = "West US" 324 resource_group_name = "${azurerm_resource_group.test.name}" 325 326 frontend_ip_configuration { 327 name = "one-%d" 328 public_ip_address_id = "${azurerm_public_ip.test.id}" 329 } 330 } 331 332 resource "azurerm_lb_rule" "test" { 333 location = "West US" 334 resource_group_name = "${azurerm_resource_group.test.name}" 335 loadbalancer_id = "${azurerm_lb.test.id}" 336 name = "%s" 337 protocol = "Tcp" 338 frontend_port = 3389 339 backend_port = 3389 340 frontend_ip_configuration_name = "one-%d" 341 } 342 343 `, rInt, rInt, rInt, rInt, lbRuleName, rInt) 344 } 345 346 func testAccAzureRMLoadBalancerRule_removal(rInt int) string { 347 return fmt.Sprintf(` 348 resource "azurerm_resource_group" "test" { 349 name = "acctestrg-%d" 350 location = "West US" 351 } 352 353 resource "azurerm_public_ip" "test" { 354 name = "test-ip-%d" 355 location = "West US" 356 resource_group_name = "${azurerm_resource_group.test.name}" 357 public_ip_address_allocation = "static" 358 } 359 360 resource "azurerm_lb" "test" { 361 name = "arm-test-loadbalancer-%d" 362 location = "West US" 363 resource_group_name = "${azurerm_resource_group.test.name}" 364 365 frontend_ip_configuration { 366 name = "one-%d" 367 public_ip_address_id = "${azurerm_public_ip.test.id}" 368 } 369 } 370 `, rInt, rInt, rInt, rInt) 371 } 372 373 // https://github.com/hashicorp/terraform/issues/9424 374 func testAccAzureRMLoadBalancerRule_inconsistentRead(rInt int, backendPoolName, probeName, lbRuleName string) string { 375 return fmt.Sprintf(` 376 resource "azurerm_resource_group" "test" { 377 name = "acctestrg-%d" 378 location = "West US" 379 } 380 381 resource "azurerm_public_ip" "test" { 382 name = "test-ip-%d" 383 location = "West US" 384 resource_group_name = "${azurerm_resource_group.test.name}" 385 public_ip_address_allocation = "static" 386 } 387 388 resource "azurerm_lb" "test" { 389 name = "arm-test-loadbalancer-%d" 390 location = "West US" 391 resource_group_name = "${azurerm_resource_group.test.name}" 392 393 frontend_ip_configuration { 394 name = "one-%d" 395 public_ip_address_id = "${azurerm_public_ip.test.id}" 396 } 397 } 398 399 resource "azurerm_lb_backend_address_pool" "teset" { 400 name = "%s" 401 location = "West US" 402 resource_group_name = "${azurerm_resource_group.test.name}" 403 loadbalancer_id = "${azurerm_lb.test.id}" 404 } 405 406 resource "azurerm_lb_probe" "test" { 407 name = "%s" 408 location = "West US" 409 resource_group_name = "${azurerm_resource_group.test.name}" 410 loadbalancer_id = "${azurerm_lb.test.id}" 411 protocol = "Tcp" 412 port = 443 413 } 414 415 resource "azurerm_lb_rule" "test" { 416 name = "%s" 417 location = "West US" 418 resource_group_name = "${azurerm_resource_group.test.name}" 419 loadbalancer_id = "${azurerm_lb.test.id}" 420 protocol = "Tcp" 421 frontend_port = 3389 422 backend_port = 3389 423 frontend_ip_configuration_name = "one-%d" 424 } 425 `, rInt, rInt, rInt, rInt, backendPoolName, probeName, lbRuleName, rInt) 426 } 427 428 func testAccAzureRMLoadBalancerRule_multipleRules(rInt int, lbRuleName, lbRule2Name string) string { 429 return fmt.Sprintf(` 430 resource "azurerm_resource_group" "test" { 431 name = "acctestrg-%d" 432 location = "West US" 433 } 434 435 resource "azurerm_public_ip" "test" { 436 name = "test-ip-%d" 437 location = "West US" 438 resource_group_name = "${azurerm_resource_group.test.name}" 439 public_ip_address_allocation = "static" 440 } 441 442 resource "azurerm_lb" "test" { 443 name = "arm-test-loadbalancer-%d" 444 location = "West US" 445 resource_group_name = "${azurerm_resource_group.test.name}" 446 447 frontend_ip_configuration { 448 name = "one-%d" 449 public_ip_address_id = "${azurerm_public_ip.test.id}" 450 } 451 } 452 453 resource "azurerm_lb_rule" "test" { 454 location = "West US" 455 resource_group_name = "${azurerm_resource_group.test.name}" 456 loadbalancer_id = "${azurerm_lb.test.id}" 457 name = "%s" 458 protocol = "Udp" 459 frontend_port = 3389 460 backend_port = 3389 461 frontend_ip_configuration_name = "one-%d" 462 } 463 464 resource "azurerm_lb_rule" "test2" { 465 location = "West US" 466 resource_group_name = "${azurerm_resource_group.test.name}" 467 loadbalancer_id = "${azurerm_lb.test.id}" 468 name = "%s" 469 protocol = "Udp" 470 frontend_port = 3390 471 backend_port = 3390 472 frontend_ip_configuration_name = "one-%d" 473 } 474 475 `, rInt, rInt, rInt, rInt, lbRuleName, rInt, lbRule2Name, rInt) 476 } 477 478 func testAccAzureRMLoadBalancerRule_multipleRulesUpdate(rInt int, lbRuleName, lbRule2Name string) string { 479 return fmt.Sprintf(` 480 resource "azurerm_resource_group" "test" { 481 name = "acctestrg-%d" 482 location = "West US" 483 } 484 485 resource "azurerm_public_ip" "test" { 486 name = "test-ip-%d" 487 location = "West US" 488 resource_group_name = "${azurerm_resource_group.test.name}" 489 public_ip_address_allocation = "static" 490 } 491 492 resource "azurerm_lb" "test" { 493 name = "arm-test-loadbalancer-%d" 494 location = "West US" 495 resource_group_name = "${azurerm_resource_group.test.name}" 496 497 frontend_ip_configuration { 498 name = "one-%d" 499 public_ip_address_id = "${azurerm_public_ip.test.id}" 500 } 501 } 502 503 resource "azurerm_lb_rule" "test" { 504 location = "West US" 505 resource_group_name = "${azurerm_resource_group.test.name}" 506 loadbalancer_id = "${azurerm_lb.test.id}" 507 name = "%s" 508 protocol = "Udp" 509 frontend_port = 3389 510 backend_port = 3389 511 frontend_ip_configuration_name = "one-%d" 512 } 513 514 resource "azurerm_lb_rule" "test2" { 515 location = "West US" 516 resource_group_name = "${azurerm_resource_group.test.name}" 517 loadbalancer_id = "${azurerm_lb.test.id}" 518 name = "%s" 519 protocol = "Udp" 520 frontend_port = 3391 521 backend_port = 3391 522 frontend_ip_configuration_name = "one-%d" 523 } 524 525 `, rInt, rInt, rInt, rInt, lbRuleName, rInt, lbRule2Name, rInt) 526 }