2020-10-28 06:14:03 -04:00
|
|
|
package qemu
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-12-01 18:30:31 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/communicator"
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2020-12-02 13:50:37 -05:00
|
|
|
packersdk "github.com/hashicorp/packer/packer-plugin-sdk/packer"
|
2020-10-28 06:14:03 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
func Test_Shutdown_Null_success(t *testing.T) {
|
|
|
|
state := new(multistep.BasicStateBag)
|
2020-12-02 13:50:37 -05:00
|
|
|
state.Put("ui", packersdk.TestUi(t))
|
2020-10-28 06:14:03 -04:00
|
|
|
driverMock := new(DriverMock)
|
|
|
|
driverMock.WaitForShutdownState = true
|
|
|
|
state.Put("driver", driverMock)
|
|
|
|
|
|
|
|
step := &stepShutdown{
|
|
|
|
ShutdownCommand: "",
|
|
|
|
ShutdownTimeout: 5 * time.Minute,
|
|
|
|
Comm: &communicator.Config{
|
|
|
|
Type: "none",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
action := step.Run(context.TODO(), state)
|
|
|
|
if action != multistep.ActionContinue {
|
|
|
|
t.Fatalf("Should have successfully shut down.")
|
|
|
|
}
|
|
|
|
err := state.Get("error")
|
|
|
|
if err != nil {
|
|
|
|
err = err.(error)
|
|
|
|
t.Fatalf("Shutdown shouldn't have errored; err: %v", err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_Shutdown_Null_failure(t *testing.T) {
|
|
|
|
state := new(multistep.BasicStateBag)
|
2020-12-02 13:50:37 -05:00
|
|
|
state.Put("ui", packersdk.TestUi(t))
|
2020-10-28 06:14:03 -04:00
|
|
|
driverMock := new(DriverMock)
|
|
|
|
driverMock.WaitForShutdownState = false
|
|
|
|
state.Put("driver", driverMock)
|
|
|
|
|
|
|
|
step := &stepShutdown{
|
|
|
|
ShutdownCommand: "",
|
|
|
|
ShutdownTimeout: 5 * time.Minute,
|
|
|
|
Comm: &communicator.Config{
|
|
|
|
Type: "none",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
action := step.Run(context.TODO(), state)
|
|
|
|
if action != multistep.ActionHalt {
|
|
|
|
t.Fatalf("Shouldn't have successfully shut down.")
|
|
|
|
}
|
|
|
|
err := state.Get("error")
|
|
|
|
if err == nil {
|
|
|
|
t.Fatalf("Shutdown should have errored")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Test_Shutdown_NoShutdownCommand(t *testing.T) {
|
|
|
|
state := new(multistep.BasicStateBag)
|
2020-12-02 13:50:37 -05:00
|
|
|
state.Put("ui", packersdk.TestUi(t))
|
2020-10-28 06:14:03 -04:00
|
|
|
driverMock := new(DriverMock)
|
|
|
|
state.Put("driver", driverMock)
|
|
|
|
|
|
|
|
step := &stepShutdown{
|
|
|
|
ShutdownCommand: "",
|
|
|
|
ShutdownTimeout: 5 * time.Minute,
|
|
|
|
Comm: &communicator.Config{
|
|
|
|
Type: "ssh",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
action := step.Run(context.TODO(), state)
|
|
|
|
if action != multistep.ActionContinue {
|
|
|
|
t.Fatalf("Should have successfully shut down.")
|
|
|
|
}
|
|
|
|
|
|
|
|
if !driverMock.StopCalled {
|
|
|
|
t.Fatalf("should have called Stop through the driver.")
|
|
|
|
}
|
|
|
|
err := state.Get("error")
|
|
|
|
if err != nil {
|
|
|
|
err = err.(error)
|
|
|
|
t.Fatalf("Shutdown shouldn't have errored; err: %v", err)
|
|
|
|
}
|
|
|
|
}
|