Commit 386d72c3 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer: no more asserts lib

parent 19867b75
package packer package packer
import ( import (
"cgl.tideland.biz/asserts"
"reflect" "reflect"
"testing" "testing"
) )
...@@ -41,32 +40,43 @@ func testDefaultPackerConfig() map[string]interface{} { ...@@ -41,32 +40,43 @@ func testDefaultPackerConfig() map[string]interface{} {
} }
} }
func TestBuild_Name(t *testing.T) { func TestBuild_Name(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
build := testBuild() build := testBuild()
assert.Equal(build.Name(), "test", "should have a name") if build.Name() != "test" {
t.Fatalf("bad: %s", build.Name())
}
} }
func TestBuild_Prepare(t *testing.T) { func TestBuild_Prepare(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
packerConfig := testDefaultPackerConfig() packerConfig := testDefaultPackerConfig()
build := testBuild() build := testBuild()
builder := build.builder.(*TestBuilder) builder := build.builder.(*TestBuilder)
build.Prepare(nil) build.Prepare(nil)
assert.True(builder.prepareCalled, "prepare should be called") if !builder.prepareCalled {
assert.Equal(builder.prepareConfig, []interface{}{42, packerConfig}, "prepare config should be 42") t.Fatal("should be called")
}
if !reflect.DeepEqual(builder.prepareConfig, []interface{}{42, packerConfig}) {
t.Fatalf("bad: %#v", builder.prepareConfig)
}
coreProv := build.provisioners[0] coreProv := build.provisioners[0]
prov := coreProv.provisioner.(*MockProvisioner) prov := coreProv.provisioner.(*MockProvisioner)
assert.True(prov.PrepCalled, "prepare should be called") if !prov.PrepCalled {
assert.Equal(prov.PrepConfigs, []interface{}{42, packerConfig}, "prepare should be called with proper config") t.Fatal("prep should be called")
}
if !reflect.DeepEqual(prov.PrepConfigs, []interface{}{42, packerConfig}) {
t.Fatalf("bad: %#v", prov.PrepConfigs)
}
corePP := build.postProcessors[0][0] corePP := build.postProcessors[0][0]
pp := corePP.processor.(*TestPostProcessor) pp := corePP.processor.(*TestPostProcessor)
assert.True(pp.configCalled, "config should be called") if !pp.configCalled {
assert.Equal(pp.configVal, []interface{}{make(map[string]interface{}), packerConfig}, "config should have right value") t.Fatal("should be called")
}
if !reflect.DeepEqual(pp.configVal, []interface{}{make(map[string]interface{}), packerConfig}) {
t.Fatalf("bad: %#v", pp.configVal)
}
} }
func TestBuild_Prepare_Twice(t *testing.T) { func TestBuild_Prepare_Twice(t *testing.T) {
...@@ -90,8 +100,6 @@ func TestBuild_Prepare_Twice(t *testing.T) { ...@@ -90,8 +100,6 @@ func TestBuild_Prepare_Twice(t *testing.T) {
} }
func TestBuild_Prepare_Debug(t *testing.T) { func TestBuild_Prepare_Debug(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
packerConfig := testDefaultPackerConfig() packerConfig := testDefaultPackerConfig()
packerConfig[DebugConfigKey] = true packerConfig[DebugConfigKey] = true
...@@ -100,13 +108,21 @@ func TestBuild_Prepare_Debug(t *testing.T) { ...@@ -100,13 +108,21 @@ func TestBuild_Prepare_Debug(t *testing.T) {
build.SetDebug(true) build.SetDebug(true)
build.Prepare(nil) build.Prepare(nil)
assert.True(builder.prepareCalled, "prepare should be called") if !builder.prepareCalled {
assert.Equal(builder.prepareConfig, []interface{}{42, packerConfig}, "prepare config should be 42") t.Fatalf("should be called")
}
if !reflect.DeepEqual(builder.prepareConfig, []interface{}{42, packerConfig}) {
t.Fatalf("bad: %#v", builder.prepareConfig)
}
coreProv := build.provisioners[0] coreProv := build.provisioners[0]
prov := coreProv.provisioner.(*MockProvisioner) prov := coreProv.provisioner.(*MockProvisioner)
assert.True(prov.PrepCalled, "prepare should be called") if !prov.PrepCalled {
assert.Equal(prov.PrepConfigs, []interface{}{42, packerConfig}, "prepare should be called with proper config") t.Fatal("prepare should be called")
}
if !reflect.DeepEqual(prov.PrepConfigs, []interface{}{42, packerConfig}) {
t.Fatalf("bad: %#v", prov.PrepConfigs)
}
} }
func TestBuildPrepare_variables_default(t *testing.T) { func TestBuildPrepare_variables_default(t *testing.T) {
...@@ -186,37 +202,49 @@ func TestBuildPrepare_variablesRequired(t *testing.T) { ...@@ -186,37 +202,49 @@ func TestBuildPrepare_variablesRequired(t *testing.T) {
} }
func TestBuild_Run(t *testing.T) { func TestBuild_Run(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
cache := &TestCache{} cache := &TestCache{}
ui := testUi() ui := testUi()
build := testBuild() build := testBuild()
build.Prepare(nil) build.Prepare(nil)
artifacts, err := build.Run(ui, cache) artifacts, err := build.Run(ui, cache)
assert.Nil(err, "should not error") if err != nil {
assert.Equal(len(artifacts), 2, "should have two artifacts") t.Fatalf("err: %s", err)
}
if len(artifacts) != 2 {
t.Fatalf("bad: %#v", artifacts)
}
// Verify builder was run // Verify builder was run
builder := build.builder.(*TestBuilder) builder := build.builder.(*TestBuilder)
assert.True(builder.runCalled, "run should be called") if !builder.runCalled {
t.Fatal("should be called")
}
// Verify hooks are disapatchable // Verify hooks are disapatchable
dispatchHook := builder.runHook dispatchHook := builder.runHook
dispatchHook.Run("foo", nil, nil, 42) dispatchHook.Run("foo", nil, nil, 42)
hook := build.hooks["foo"][0].(*MockHook) hook := build.hooks["foo"][0].(*MockHook)
assert.True(hook.RunCalled, "run should be called") if !hook.RunCalled {
assert.Equal(hook.RunData, 42, "should have correct data") t.Fatal("should be called")
}
if hook.RunData != 42 {
t.Fatalf("bad: %#v", hook.RunData)
}
// Verify provisioners run // Verify provisioners run
dispatchHook.Run(HookProvision, nil, nil, 42) dispatchHook.Run(HookProvision, nil, nil, 42)
prov := build.provisioners[0].provisioner.(*MockProvisioner) prov := build.provisioners[0].provisioner.(*MockProvisioner)
assert.True(prov.ProvCalled, "provision should be called") if !prov.ProvCalled {
t.Fatal("should be called")
}
// Verify post-processor was run // Verify post-processor was run
pp := build.postProcessors[0][0].processor.(*TestPostProcessor) pp := build.postProcessors[0][0].processor.(*TestPostProcessor)
assert.True(pp.ppCalled, "post processor should be called") if !pp.ppCalled {
t.Fatal("should be called")
}
} }
func TestBuild_Run_Artifacts(t *testing.T) { func TestBuild_Run_Artifacts(t *testing.T) {
...@@ -356,23 +384,26 @@ func TestBuild_Run_Artifacts(t *testing.T) { ...@@ -356,23 +384,26 @@ func TestBuild_Run_Artifacts(t *testing.T) {
} }
func TestBuild_RunBeforePrepare(t *testing.T) { func TestBuild_RunBeforePrepare(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
defer func() { defer func() {
p := recover() p := recover()
assert.NotNil(p, "should panic") if p == nil {
assert.Equal(p.(string), "Prepare must be called first", "right panic") t.Fatal("should panic")
}
if p.(string) != "Prepare must be called first" {
t.Fatalf("bad: %s", p.(string))
}
}() }()
testBuild().Run(testUi(), &TestCache{}) testBuild().Run(testUi(), &TestCache{})
} }
func TestBuild_Cancel(t *testing.T) { func TestBuild_Cancel(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
build := testBuild() build := testBuild()
build.Cancel() build.Cancel()
builder := build.builder.(*TestBuilder) builder := build.builder.(*TestBuilder)
assert.True(builder.cancelCalled, "cancel should be called") if !builder.cancelCalled {
t.Fatal("cancel should be called")
}
} }
...@@ -80,7 +80,7 @@ func TestConfigTemplateProcess_uuid(t *testing.T) { ...@@ -80,7 +80,7 @@ func TestConfigTemplateProcess_uuid(t *testing.T) {
t.Fatalf("err: %s", err) t.Fatalf("err: %s", err)
} }
if len(result) != 32 { if len(result) != 36 {
t.Fatalf("err: %s", result) t.Fatalf("err: %s", result)
} }
} }
......
This diff is collapsed.
package packer package packer
import ( import (
"cgl.tideland.biz/asserts"
"sync" "sync"
"testing" "testing"
"time" "time"
...@@ -42,12 +41,7 @@ func (h *CancelHook) Cancel() { ...@@ -42,12 +41,7 @@ func (h *CancelHook) Cancel() {
} }
func TestDispatchHook_Implements(t *testing.T) { func TestDispatchHook_Implements(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true) var _ Hook = new(DispatchHook)
var r Hook
c := &DispatchHook{}
assert.Implementor(c, &r, "should be a Hook")
} }
func TestDispatchHook_Run_NoHooks(t *testing.T) { func TestDispatchHook_Run_NoHooks(t *testing.T) {
...@@ -57,8 +51,6 @@ func TestDispatchHook_Run_NoHooks(t *testing.T) { ...@@ -57,8 +51,6 @@ func TestDispatchHook_Run_NoHooks(t *testing.T) {
} }
func TestDispatchHook_Run(t *testing.T) { func TestDispatchHook_Run(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
hook := &MockHook{} hook := &MockHook{}
mapping := make(map[string][]Hook) mapping := make(map[string][]Hook)
...@@ -66,9 +58,15 @@ func TestDispatchHook_Run(t *testing.T) { ...@@ -66,9 +58,15 @@ func TestDispatchHook_Run(t *testing.T) {
dh := &DispatchHook{Mapping: mapping} dh := &DispatchHook{Mapping: mapping}
dh.Run("foo", nil, nil, 42) dh.Run("foo", nil, nil, 42)
assert.True(hook.RunCalled, "run should be called") if !hook.RunCalled {
assert.Equal(hook.RunName, "foo", "should be proper event") t.Fatal("should be called")
assert.Equal(hook.RunData, 42, "should be correct data") }
if hook.RunName != "foo" {
t.Fatalf("bad: %s", hook.RunName)
}
if hook.RunData != 42 {
t.Fatalf("bad: %#v", hook.RunData)
}
} }
func TestDispatchHook_cancel(t *testing.T) { func TestDispatchHook_cancel(t *testing.T) {
......
package packer package packer
import ( import (
"cgl.tideland.biz/asserts"
"errors" "errors"
"testing" "testing"
) )
...@@ -15,8 +14,6 @@ func TestMultiError_Impl(t *testing.T) { ...@@ -15,8 +14,6 @@ func TestMultiError_Impl(t *testing.T) {
} }
func TestMultiErrorError(t *testing.T) { func TestMultiErrorError(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
expected := `2 error(s) occurred: expected := `2 error(s) occurred:
* foo * foo
...@@ -28,7 +25,9 @@ func TestMultiErrorError(t *testing.T) { ...@@ -28,7 +25,9 @@ func TestMultiErrorError(t *testing.T) {
} }
multi := &MultiError{errors} multi := &MultiError{errors}
assert.Equal(multi.Error(), expected, "should have proper error") if multi.Error() != expected {
t.Fatalf("bad: %s", multi.Error())
}
} }
func TestMultiErrorAppend_MultiError(t *testing.T) { func TestMultiErrorAppend_MultiError(t *testing.T) {
......
This diff is collapsed.
...@@ -2,7 +2,6 @@ package packer ...@@ -2,7 +2,6 @@ package packer
import ( import (
"bytes" "bytes"
"cgl.tideland.biz/asserts"
"strings" "strings"
"testing" "testing"
) )
...@@ -38,25 +37,40 @@ func TestColoredUi(t *testing.T) { ...@@ -38,25 +37,40 @@ func TestColoredUi(t *testing.T) {
} }
func TestTargettedUi(t *testing.T) { func TestTargettedUi(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
bufferUi := testUi() bufferUi := testUi()
targettedUi := &TargettedUi{ targettedUi := &TargettedUi{
Target: "foo", Target: "foo",
Ui: bufferUi, Ui: bufferUi,
} }
var actual, expected string
targettedUi.Say("foo") targettedUi.Say("foo")
assert.Equal(readWriter(bufferUi), "==> foo: foo\n", "should have prefix") actual = readWriter(bufferUi)
expected = "==> foo: foo\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
targettedUi.Message("foo") targettedUi.Message("foo")
assert.Equal(readWriter(bufferUi), " foo: foo\n", "should have prefix") actual = readWriter(bufferUi)
expected = " foo: foo\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
targettedUi.Error("bar") targettedUi.Error("bar")
assert.Equal(readWriter(bufferUi), "==> foo: bar\n", "should have prefix") actual = readWriter(bufferUi)
expected = "==> foo: bar\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
targettedUi.Say("foo\nbar") targettedUi.Say("foo\nbar")
assert.Equal(readWriter(bufferUi), "==> foo: foo\n==> foo: bar\n", "should multiline") actual = readWriter(bufferUi)
expected = "==> foo: foo\n==> foo: bar\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
} }
func TestColoredUi_ImplUi(t *testing.T) { func TestColoredUi_ImplUi(t *testing.T) {
...@@ -84,27 +98,42 @@ func TestBasicUi_ImplUi(t *testing.T) { ...@@ -84,27 +98,42 @@ func TestBasicUi_ImplUi(t *testing.T) {
} }
func TestBasicUi_Error(t *testing.T) { func TestBasicUi_Error(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
bufferUi := testUi() bufferUi := testUi()
var actual, expected string
bufferUi.Error("foo") bufferUi.Error("foo")
assert.Equal(readWriter(bufferUi), "foo\n", "basic output") actual = readWriter(bufferUi)
expected = "foo\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
bufferUi.Error("5") bufferUi.Error("5")
assert.Equal(readWriter(bufferUi), "5\n", "formatting") actual = readWriter(bufferUi)
expected = "5\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
} }
func TestBasicUi_Say(t *testing.T) { func TestBasicUi_Say(t *testing.T) {
assert := asserts.NewTestingAsserts(t, true)
bufferUi := testUi() bufferUi := testUi()
var actual, expected string
bufferUi.Say("foo") bufferUi.Say("foo")
assert.Equal(readWriter(bufferUi), "foo\n", "basic output") actual = readWriter(bufferUi)
expected = "foo\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
bufferUi.Say("5") bufferUi.Say("5")
assert.Equal(readWriter(bufferUi), "5\n", "formatting") actual = readWriter(bufferUi)
expected = "5\n"
if actual != expected {
t.Fatalf("bad: %#v", actual)
}
} }
func TestMachineReadableUi_ImplUi(t *testing.T) { func TestMachineReadableUi_ImplUi(t *testing.T) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment