packer-cn/packer/rpc/build_test.go

183 lines
3.3 KiB
Go
Raw Normal View History

package rpc
import (
"context"
"errors"
"reflect"
"testing"
2017-04-04 16:39:01 -04:00
"github.com/hashicorp/packer/packer"
packersdk "github.com/hashicorp/packer/packer-plugin-sdk/packer"
)
var testBuildArtifact = &packersdk.MockArtifact{}
2013-05-22 01:38:41 -04:00
type testBuild struct {
nameCalled bool
prepareCalled bool
prepareWarnings []string
runFn func(context.Context)
runCalled bool
runUi packersdk.Ui
setDebugCalled bool
setForceCalled bool
setOnErrorCalled bool
errRunResult bool
}
2013-05-09 14:32:03 -04:00
func (b *testBuild) Name() string {
b.nameCalled = true
return "name"
}
func (b *testBuild) Prepare() ([]string, error) {
b.prepareCalled = true
return b.prepareWarnings, nil
}
func (b *testBuild) Run(ctx context.Context, ui packersdk.Ui) ([]packersdk.Artifact, error) {
b.runCalled = true
b.runUi = ui
if b.runFn != nil {
b.runFn(ctx)
}
if b.errRunResult {
return nil, errors.New("foo")
} else {
return []packersdk.Artifact{testBuildArtifact}, nil
}
}
2013-06-14 15:22:19 -04:00
func (b *testBuild) SetDebug(bool) {
b.setDebugCalled = true
}
func (b *testBuild) SetForce(bool) {
b.setForceCalled = true
}
func (b *testBuild) SetOnError(string) {
b.setOnErrorCalled = true
}
func TestBuild(t *testing.T) {
2013-12-10 16:18:48 -05:00
b := new(testBuild)
client, server := testClientServer(t)
defer client.Close()
defer server.Close()
server.RegisterBuild(b)
bClient := client.Build()
2013-05-09 14:32:03 -04:00
ctx := context.Background()
2013-05-09 14:32:03 -04:00
// Test Name
bClient.Name()
2013-10-16 23:04:57 -04:00
if !b.nameCalled {
t.Fatal("name should be called")
}
2013-05-09 14:32:03 -04:00
// Test Prepare
bClient.Prepare()
2013-10-16 23:04:57 -04:00
if !b.prepareCalled {
t.Fatal("prepare should be called")
}
// Test Run
ui := new(packersdk.MockUi)
artifacts, err := bClient.Run(ctx, ui)
2013-10-16 23:04:57 -04:00
if !b.runCalled {
t.Fatal("run should be called")
}
if err != nil {
t.Fatalf("err: %s", err)
}
if len(artifacts) != 1 {
t.Fatalf("bad: %#v", artifacts)
}
if artifacts[0].BuilderId() != "bid" {
t.Fatalf("bad: %#v", artifacts)
}
// Test run with an error
b.errRunResult = true
_, err = bClient.Run(ctx, ui)
2013-10-16 23:04:57 -04:00
if err == nil {
t.Fatal("should error")
}
2013-06-14 15:22:19 -04:00
// Test SetDebug
bClient.SetDebug(true)
2013-10-16 23:04:57 -04:00
if !b.setDebugCalled {
t.Fatal("should be called")
}
2013-06-14 15:22:19 -04:00
// Test SetForce
bClient.SetForce(true)
2013-10-16 23:04:57 -04:00
if !b.setForceCalled {
t.Fatal("should be called")
}
// Test SetOnError
bClient.SetOnError("ask")
if !b.setOnErrorCalled {
t.Fatal("should be called")
}
}
func TestBuild_cancel(t *testing.T) {
topCtx, cancelTopCtx := context.WithCancel(context.Background())
b := new(testBuild)
done := make(chan interface{})
b.runFn = func(ctx context.Context) {
cancelTopCtx()
<-ctx.Done()
close(done)
2013-10-16 23:04:57 -04:00
}
client, server := testClientServer(t)
defer client.Close()
defer server.Close()
server.RegisterBuild(b)
bClient := client.Build()
bClient.Prepare()
ui := new(packersdk.MockUi)
bClient.Run(topCtx, ui)
// if context cancellation is not propagated, this will timeout
<-done
}
func TestBuildPrepare_Warnings(t *testing.T) {
2013-12-10 16:18:48 -05:00
b := new(testBuild)
client, server := testClientServer(t)
defer client.Close()
defer server.Close()
server.RegisterBuild(b)
bClient := client.Build()
expected := []string{"foo"}
b.prepareWarnings = expected
warnings, err := bClient.Prepare()
if err != nil {
t.Fatalf("err: %s", err)
}
if !reflect.DeepEqual(warnings, expected) {
t.Fatalf("bad: %#v", warnings)
}
}
func TestBuild_ImplementsBuild(t *testing.T) {
2013-12-10 16:26:07 -05:00
var _ packer.Build = new(build)
}