2013-11-09 15:12:23 -05:00
|
|
|
package docker
|
|
|
|
|
|
|
|
import (
|
2018-01-22 19:03:49 -05:00
|
|
|
"context"
|
2013-11-09 15:12:23 -05:00
|
|
|
"errors"
|
|
|
|
"testing"
|
2018-01-22 20:21:10 -05:00
|
|
|
|
2020-11-17 19:31:03 -05:00
|
|
|
"github.com/hashicorp/packer/packer-plugin-sdk/multistep"
|
2013-11-09 15:12:23 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestStepPull_impl(t *testing.T) {
|
|
|
|
var _ multistep.Step = new(StepPull)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepPull(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepPull)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
driver := state.Get("driver").(*MockDriver)
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionContinue {
|
2013-11-09 15:12:23 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify we did the right thing
|
|
|
|
if !driver.PullCalled {
|
|
|
|
t.Fatal("should've pulled")
|
|
|
|
}
|
|
|
|
if driver.PullImage != config.Image {
|
|
|
|
t.Fatalf("bad: %#v", driver.PullImage)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestStepPull_error(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepPull)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
driver := state.Get("driver").(*MockDriver)
|
|
|
|
driver.PullError = errors.New("foo")
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionHalt {
|
2013-11-09 15:12:23 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify we have an error
|
|
|
|
if _, ok := state.GetOk("error"); !ok {
|
|
|
|
t.Fatal("should have error")
|
|
|
|
}
|
|
|
|
}
|
2013-11-09 20:21:24 -05:00
|
|
|
|
2014-09-05 18:24:12 -04:00
|
|
|
func TestStepPull_login(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepPull)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
driver := state.Get("driver").(*MockDriver)
|
|
|
|
|
|
|
|
config.Login = true
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionContinue {
|
2014-09-05 18:24:12 -04:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify we pulled
|
|
|
|
if !driver.PullCalled {
|
|
|
|
t.Fatal("should've pulled")
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify we logged in
|
|
|
|
if !driver.LoginCalled {
|
|
|
|
t.Fatal("should've logged in")
|
|
|
|
}
|
|
|
|
if !driver.LogoutCalled {
|
|
|
|
t.Fatal("should've logged out")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-11-09 20:21:24 -05:00
|
|
|
func TestStepPull_noPull(t *testing.T) {
|
|
|
|
state := testState(t)
|
|
|
|
step := new(StepPull)
|
|
|
|
defer step.Cleanup(state)
|
|
|
|
|
|
|
|
config := state.Get("config").(*Config)
|
|
|
|
config.Pull = false
|
|
|
|
|
|
|
|
driver := state.Get("driver").(*MockDriver)
|
|
|
|
|
|
|
|
// run the step
|
2018-01-22 19:03:49 -05:00
|
|
|
if action := step.Run(context.Background(), state); action != multistep.ActionContinue {
|
2013-11-09 20:21:24 -05:00
|
|
|
t.Fatalf("bad action: %#v", action)
|
|
|
|
}
|
|
|
|
|
|
|
|
// verify we did the right thing
|
|
|
|
if driver.PullCalled {
|
|
|
|
t.Fatal("shouldn't have pulled")
|
|
|
|
}
|
|
|
|
}
|