bug fix and add test
This commit is contained in:
parent
42910a5f8c
commit
8a7d43dd44
|
@ -2,18 +2,39 @@ package command
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/hashicorp/packer/packer"
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFix(t *testing.T) {
|
func TestFix(t *testing.T) {
|
||||||
|
s := &strings.Builder{}
|
||||||
|
ui := &packer.BasicUi{
|
||||||
|
Writer: s,
|
||||||
|
}
|
||||||
c := &FixCommand{
|
c := &FixCommand{
|
||||||
Meta: testMeta(t),
|
Meta: testMeta(t),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c.Ui = ui
|
||||||
|
|
||||||
args := []string{filepath.Join(testFixture("fix"), "template.json")}
|
args := []string{filepath.Join(testFixture("fix"), "template.json")}
|
||||||
if code := c.Run(args); code != 0 {
|
if code := c.Run(args); code != 0 {
|
||||||
fatalCommand(t, c.Meta)
|
fatalCommand(t, c.Meta)
|
||||||
}
|
}
|
||||||
|
expected := `{
|
||||||
|
"builders": [
|
||||||
|
{
|
||||||
|
"type": "dummy"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"push": {
|
||||||
|
"name": "foo/bar"
|
||||||
|
}
|
||||||
|
}`
|
||||||
|
assert.Equal(t, expected, strings.TrimSpace(s.String()))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestFix_invalidTemplate(t *testing.T) {
|
func TestFix_invalidTemplate(t *testing.T) {
|
||||||
|
|
|
@ -5,6 +5,10 @@ import "github.com/mitchellh/mapstructure"
|
||||||
type FixerDockerEmail struct{}
|
type FixerDockerEmail struct{}
|
||||||
|
|
||||||
func (FixerDockerEmail) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
func (FixerDockerEmail) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
||||||
|
if input["post-processors"] == nil {
|
||||||
|
return input, nil
|
||||||
|
}
|
||||||
|
|
||||||
// Our template type we'll use for this fixer only
|
// Our template type we'll use for this fixer only
|
||||||
type template struct {
|
type template struct {
|
||||||
Builders []map[string]interface{}
|
Builders []map[string]interface{}
|
||||||
|
@ -27,7 +31,7 @@ func (FixerDockerEmail) Fix(input map[string]interface{}) (map[string]interface{
|
||||||
}
|
}
|
||||||
|
|
||||||
// Go through each post-processor and delete `docker_login` if present
|
// Go through each post-processor and delete `docker_login` if present
|
||||||
pps := tpl.postProcessors()
|
pps := tpl.ppList()
|
||||||
|
|
||||||
for _, pp := range pps {
|
for _, pp := range pps {
|
||||||
_, ok := pp["login_email"]
|
_, ok := pp["login_email"]
|
||||||
|
@ -38,7 +42,7 @@ func (FixerDockerEmail) Fix(input map[string]interface{}) (map[string]interface{
|
||||||
}
|
}
|
||||||
|
|
||||||
input["builders"] = tpl.Builders
|
input["builders"] = tpl.Builders
|
||||||
input["post-processors"] = pps
|
input["post-processors"] = tpl.PostProcessors
|
||||||
return input, nil
|
return input, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,9 @@ import (
|
||||||
type FixerManifestFilename struct{}
|
type FixerManifestFilename struct{}
|
||||||
|
|
||||||
func (FixerManifestFilename) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
func (FixerManifestFilename) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
||||||
|
if input["post-processors"] == nil {
|
||||||
|
return input, nil
|
||||||
|
}
|
||||||
|
|
||||||
// Our template type we'll use for this fixer only
|
// Our template type we'll use for this fixer only
|
||||||
type template struct {
|
type template struct {
|
||||||
|
@ -21,7 +24,7 @@ func (FixerManifestFilename) Fix(input map[string]interface{}) (map[string]inter
|
||||||
}
|
}
|
||||||
|
|
||||||
// Go through each post-processor and get out all the complex configs
|
// Go through each post-processor and get out all the complex configs
|
||||||
pps := tpl.postProcessors()
|
pps := tpl.ppList()
|
||||||
|
|
||||||
for _, pp := range pps {
|
for _, pp := range pps {
|
||||||
ppTypeRaw, ok := pp["type"]
|
ppTypeRaw, ok := pp["type"]
|
||||||
|
@ -47,7 +50,7 @@ func (FixerManifestFilename) Fix(input map[string]interface{}) (map[string]inter
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
input["post-processors"] = pps
|
input["post-processors"] = tpl.PostProcessors
|
||||||
return input, nil
|
return input, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
package fix
|
package fix
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFixerManifestPPFilename_Impl(t *testing.T) {
|
func TestFixerManifestPPFilename_Impl(t *testing.T) {
|
||||||
|
@ -43,11 +44,7 @@ func TestFixerManifestPPFilename_Fix(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
output, err := f.Fix(input)
|
output, err := f.Fix(input)
|
||||||
if err != nil {
|
assert.NoError(t, err)
|
||||||
t.Fatalf("err: %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !reflect.DeepEqual(output, expected) {
|
assert.Equal(t, expected, output)
|
||||||
t.Fatalf("unexpected: %#v\nexpected: %#v\n", output, expected)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
package fix
|
package fix
|
||||||
|
|
||||||
import (
|
import "github.com/mitchellh/mapstructure"
|
||||||
"github.com/mitchellh/mapstructure"
|
|
||||||
)
|
|
||||||
|
|
||||||
// FixerVagrantPPOverride is a Fixer that replaces the provider-specific
|
// FixerVagrantPPOverride is a Fixer that replaces the provider-specific
|
||||||
// overrides for the Vagrant post-processor with the new style introduced
|
// overrides for the Vagrant post-processor with the new style introduced
|
||||||
|
@ -10,6 +8,10 @@ import (
|
||||||
type FixerVagrantPPOverride struct{}
|
type FixerVagrantPPOverride struct{}
|
||||||
|
|
||||||
func (FixerVagrantPPOverride) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
func (FixerVagrantPPOverride) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
||||||
|
if input["post-processors"] == nil {
|
||||||
|
return input, nil
|
||||||
|
}
|
||||||
|
|
||||||
// Our template type we'll use for this fixer only
|
// Our template type we'll use for this fixer only
|
||||||
type template struct {
|
type template struct {
|
||||||
PP `mapstructure:",squash"`
|
PP `mapstructure:",squash"`
|
||||||
|
@ -21,7 +23,7 @@ func (FixerVagrantPPOverride) Fix(input map[string]interface{}) (map[string]inte
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
pps := tpl.postProcessors()
|
pps := tpl.ppList()
|
||||||
|
|
||||||
// Go through each post-processor and make the fix if necessary
|
// Go through each post-processor and make the fix if necessary
|
||||||
possible := []string{"aws", "digitalocean", "virtualbox", "vmware"}
|
possible := []string{"aws", "digitalocean", "virtualbox", "vmware"}
|
||||||
|
@ -52,7 +54,7 @@ func (FixerVagrantPPOverride) Fix(input map[string]interface{}) (map[string]inte
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
input["post-processors"] = pps
|
input["post-processors"] = tpl.PostProcessors
|
||||||
return input, nil
|
return input, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
package fix
|
package fix
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"reflect"
|
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFixerVagrantPPOverride_Impl(t *testing.T) {
|
func TestFixerVagrantPPOverride_Impl(t *testing.T) {
|
||||||
|
@ -69,11 +70,7 @@ func TestFixerVagrantPPOverride_Fix(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
output, err := f.Fix(input)
|
output, err := f.Fix(input)
|
||||||
if err != nil {
|
assert.NoError(t, err)
|
||||||
t.Fatalf("err: %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
if !reflect.DeepEqual(output, expected) {
|
assert.Equal(t, expected, output)
|
||||||
t.Fatalf("unexpected: %#v\nexpected: %#v\n", output, expected)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,7 +6,7 @@ type PP struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
// postProcessors converts the variable structure of the template to a list
|
// postProcessors converts the variable structure of the template to a list
|
||||||
func (pp *PP) postProcessors() []map[string]interface{} {
|
func (pp *PP) ppList() []map[string]interface{} {
|
||||||
pps := make([]map[string]interface{}, 0, len(pp.PostProcessors))
|
pps := make([]map[string]interface{}, 0, len(pp.PostProcessors))
|
||||||
for _, rawPP := range pp.PostProcessors {
|
for _, rawPP := range pp.PostProcessors {
|
||||||
switch pp := rawPP.(type) {
|
switch pp := rawPP.(type) {
|
||||||
|
|
Loading…
Reference in New Issue