2016-03-04 05:14:55 -05:00
|
|
|
package arm
|
|
|
|
|
|
|
|
import (
|
2018-01-22 19:03:49 -05:00
|
|
|
"context"
|
2016-03-04 05:14:55 -05:00
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
2017-04-04 16:39:01 -04:00
|
|
|
"github.com/hashicorp/packer/builder/azure/common/constants"
|
2018-01-19 19:18:44 -05:00
|
|
|
"github.com/hashicorp/packer/helper/multistep"
|
2016-03-04 05:14:55 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestStepDeleteResourceGroupShouldFailIfDeleteFails(t *testing.T) {
|
|
|
|
var testSubject = &StepDeleteResourceGroup{
|
2017-11-06 00:16:58 -05:00
|
|
|
delete: func(multistep.StateBag, string, <-chan struct{}) error { return fmt.Errorf("!! Unit Test FAIL !!") },
|
2016-03-04 05:14:55 -05:00
|
|
|
say: func(message string) {},
|
|
|
|
error: func(e error) {},
|
|
|
|
}
|
|
|
|
|
|
|
|
stateBag := DeleteTestStateBagStepDeleteResourceGroup()
|
|
|
|
|
2018-01-22 19:03:49 -05:00
|
|
|
var result = testSubject.Run(context.Background(), stateBag)
|
2016-03-04 05:14:55 -05:00
|
|
|
if result != multistep.ActionHalt {
|
|
|
|
t.Fatalf("Expected the step to return 'ActionHalt', but got '%d'.", result)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, ok := stateBag.GetOk(constants.Error); ok == false {
|
|
|
|
t.Fatalf("Expected the step to set stateBag['%s'], but it was not.", constants.Error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepDeleteResourceGroupShouldPassIfDeletePasses(t *testing.T) {
|
|
|
|
var testSubject = &StepDeleteResourceGroup{
|
2017-11-06 00:16:58 -05:00
|
|
|
delete: func(multistep.StateBag, string, <-chan struct{}) error { return nil },
|
2016-03-04 05:14:55 -05:00
|
|
|
say: func(message string) {},
|
|
|
|
error: func(e error) {},
|
|
|
|
}
|
|
|
|
|
|
|
|
stateBag := DeleteTestStateBagStepDeleteResourceGroup()
|
|
|
|
|
2018-01-22 19:03:49 -05:00
|
|
|
var result = testSubject.Run(context.Background(), stateBag)
|
2016-03-04 05:14:55 -05:00
|
|
|
if result != multistep.ActionContinue {
|
|
|
|
t.Fatalf("Expected the step to return 'ActionContinue', but got '%d'.", result)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, ok := stateBag.GetOk(constants.Error); ok == true {
|
|
|
|
t.Fatalf("Expected the step to not set stateBag['%s'], but it was.", constants.Error)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-09 17:19:55 -04:00
|
|
|
func TestStepDeleteResourceGroupShouldDeleteStateBagArmResourceGroupCreated(t *testing.T) {
|
2016-03-04 05:14:55 -05:00
|
|
|
var testSubject = &StepDeleteResourceGroup{
|
2017-11-06 00:16:58 -05:00
|
|
|
delete: func(s multistep.StateBag, resourceGroupName string, cancelCh <-chan struct{}) error {
|
2016-03-04 05:14:55 -05:00
|
|
|
return nil
|
|
|
|
},
|
|
|
|
say: func(message string) {},
|
|
|
|
error: func(e error) {},
|
|
|
|
}
|
|
|
|
|
|
|
|
stateBag := DeleteTestStateBagStepDeleteResourceGroup()
|
2018-01-22 19:03:49 -05:00
|
|
|
testSubject.Run(context.Background(), stateBag)
|
2016-03-04 05:14:55 -05:00
|
|
|
|
2016-05-09 17:19:55 -04:00
|
|
|
value, ok := stateBag.GetOk(constants.ArmIsResourceGroupCreated)
|
|
|
|
if !ok {
|
2016-07-16 01:23:53 -04:00
|
|
|
t.Fatal("Expected the resource bag value arm.IsResourceGroupCreated to exist")
|
2016-03-04 05:14:55 -05:00
|
|
|
}
|
|
|
|
|
2016-05-09 17:19:55 -04:00
|
|
|
if value.(bool) {
|
|
|
|
t.Fatalf("Expected arm.IsResourceGroupCreated to be false, but got %q", value)
|
2016-03-04 05:14:55 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func DeleteTestStateBagStepDeleteResourceGroup() multistep.StateBag {
|
|
|
|
stateBag := new(multistep.BasicStateBag)
|
|
|
|
stateBag.Put(constants.ArmResourceGroupName, "Unit Test: ResourceGroupName")
|
2016-05-09 17:19:55 -04:00
|
|
|
stateBag.Put(constants.ArmIsResourceGroupCreated, "Unit Test: IsResourceGroupCreated")
|
2016-03-04 05:14:55 -05:00
|
|
|
|
|
|
|
return stateBag
|
|
|
|
}
|