From 28a13111b8f7d6746e95c830e16f6e09cbd73c76 Mon Sep 17 00:00:00 2001 From: Chris Bednarski Date: Mon, 13 Jul 2015 14:57:35 -0700 Subject: [PATCH 1/4] Add stub for validate test --- command/test-fixtures/validate/template.json | 10 ++++++ command/validate_test.go | 32 ++++++++++++++++++++ 2 files changed, 42 insertions(+) create mode 100644 command/test-fixtures/validate/template.json create mode 100644 command/validate_test.go diff --git a/command/test-fixtures/validate/template.json b/command/test-fixtures/validate/template.json new file mode 100644 index 000000000..1d9e251e5 --- /dev/null +++ b/command/test-fixtures/validate/template.json @@ -0,0 +1,10 @@ +{ + "builders":[ + { + "type":"file", + "target":"chocolate.txt", + "content":"chocolate" + } + ], + "min_packer_version":"0.8.0" +} diff --git a/command/validate_test.go b/command/validate_test.go new file mode 100644 index 000000000..479181fdc --- /dev/null +++ b/command/validate_test.go @@ -0,0 +1,32 @@ +package command + +import ( + "path/filepath" + "testing" +) + +func TestValidateCommand(t *testing.T) { + c := &ValidateCommand{ + Meta: testMetaFile(t), + } + + args := []string{ + filepath.Join(testFixture("validate"), "template.json"), + } + + defer cleanup() + + if code := c.Run(args); code != 0 { + fatalCommand(t, c.Meta) + } + + if !fileExists("chocolate.txt") { + t.Error("Expected to find chocolate.txt") + } + if !fileExists("vanilla.txt") { + t.Error("Expected to find vanilla.txt") + } + if fileExists("cherry.txt") { + t.Error("Expected NOT to find cherry.txt") + } +} From da20c3645479c45d4720490f2fb9c40aff397986 Mon Sep 17 00:00:00 2001 From: Chris Bednarski Date: Mon, 13 Jul 2015 18:04:50 -0700 Subject: [PATCH 2/4] Removed unused variable breaking gorename --- command/push_test.go | 2 -- 1 file changed, 2 deletions(-) diff --git a/command/push_test.go b/command/push_test.go index f1b7fd306..9d7b79be7 100644 --- a/command/push_test.go +++ b/command/push_test.go @@ -122,10 +122,8 @@ func TestPush_noName(t *testing.T) { func TestPush_cliName(t *testing.T) { var actual []string - var actualOpts *uploadOpts uploadFn := func(r io.Reader, opts *uploadOpts) (<-chan struct{}, <-chan error, error) { actual = testArchive(t, r) - actualOpts = opts doneCh := make(chan struct{}) close(doneCh) From 78174dae4eb01047ccb025e361e29b6fcb188bb9 Mon Sep 17 00:00:00 2001 From: Chris Bednarski Date: Mon, 13 Jul 2015 19:03:36 -0700 Subject: [PATCH 3/4] Don't override packer's build version from a config file; fixes #2385 --- command/meta.go | 1 - 1 file changed, 1 deletion(-) diff --git a/command/meta.go b/command/meta.go index 1c0864f92..d22efcaba 100644 --- a/command/meta.go +++ b/command/meta.go @@ -43,7 +43,6 @@ func (m *Meta) Core(tpl *template.Template) (*packer.Core, error) { config := *m.CoreConfig config.Template = tpl config.Variables = m.flagVars - config.Version = m.Version // Init the core core, err := packer.NewCore(&config) From b3eacc5c2b460e985ff8da86b995171a6df6db94 Mon Sep 17 00:00:00 2001 From: Chris Bednarski Date: Mon, 13 Jul 2015 19:32:28 -0700 Subject: [PATCH 4/4] Updated test to verify expected behavior --- command/command_test.go | 7 ++++ command/test-fixtures/validate/template.json | 2 +- command/validate_test.go | 40 +++++++++++++------- packer/core.go | 3 +- 4 files changed, 35 insertions(+), 17 deletions(-) diff --git a/command/command_test.go b/command/command_test.go index 126897810..4ba4b8787 100644 --- a/command/command_test.go +++ b/command/command_test.go @@ -20,6 +20,13 @@ func fatalCommand(t *testing.T, m Meta) { err.String()) } +func outputCommand(t *testing.T, m Meta) (string, string) { + ui := m.Ui.(*packer.BasicUi) + out := ui.Writer.(*bytes.Buffer) + err := ui.ErrorWriter.(*bytes.Buffer) + return out.String(), err.String() +} + func testFixture(n string) string { return filepath.Join(fixturesDir, n) } diff --git a/command/test-fixtures/validate/template.json b/command/test-fixtures/validate/template.json index 1d9e251e5..75b3f6251 100644 --- a/command/test-fixtures/validate/template.json +++ b/command/test-fixtures/validate/template.json @@ -6,5 +6,5 @@ "content":"chocolate" } ], - "min_packer_version":"0.8.0" + "min_packer_version":"101.0.0" } diff --git a/command/validate_test.go b/command/validate_test.go index 479181fdc..b15e5f155 100644 --- a/command/validate_test.go +++ b/command/validate_test.go @@ -5,28 +5,40 @@ import ( "testing" ) -func TestValidateCommand(t *testing.T) { +func TestValidateCommandOKVersion(t *testing.T) { c := &ValidateCommand{ Meta: testMetaFile(t), } - args := []string{ filepath.Join(testFixture("validate"), "template.json"), } - defer cleanup() - + // This should pass with a valid configuration version + c.CoreConfig.Version = "102.0.0" if code := c.Run(args); code != 0 { fatalCommand(t, c.Meta) } - - if !fileExists("chocolate.txt") { - t.Error("Expected to find chocolate.txt") - } - if !fileExists("vanilla.txt") { - t.Error("Expected to find vanilla.txt") - } - if fileExists("cherry.txt") { - t.Error("Expected NOT to find cherry.txt") - } +} + +func TestValidateCommandBadVersion(t *testing.T) { + c := &ValidateCommand{ + Meta: testMetaFile(t), + } + args := []string{ + filepath.Join(testFixture("validate"), "template.json"), + } + + // This should fail with an invalid configuration version + c.CoreConfig.Version = "100.0.0" + if code := c.Run(args); code != 1 { + t.Errorf("Expected exit code 1") + } + + stdout, stderr := outputCommand(t, c.Meta) + expected := `Error initializing core: This template requires Packer version 101.0.0 or higher; using 100.0.0 +` + if stderr != expected { + t.Fatalf("Expected:\n%s\nFound:\n%s\n", expected, stderr) + } + t.Log(stdout) } diff --git a/packer/core.go b/packer/core.go index f9bf87b9d..496fce6bd 100644 --- a/packer/core.go +++ b/packer/core.go @@ -246,8 +246,7 @@ func (c *Core) validate() error { if versionActual.LessThan(versionMin) { return fmt.Errorf( - "This template requires a minimum Packer version of %s,\n"+ - "but version %s is running.", + "This template requires Packer version %s or higher; using %s", versionMin, versionActual) }