Commit 5371f665 authored by Mitchell Hashimoto's avatar Mitchell Hashimoto

packer: verify only one of 'only' or 'except' specified [GH-438]

parent 12ad2cf9
...@@ -554,6 +554,11 @@ func (t *TemplateOnlyExcept) Skip(name string) bool { ...@@ -554,6 +554,11 @@ func (t *TemplateOnlyExcept) Skip(name string) bool {
// Validates the only/except parameters. // Validates the only/except parameters.
func (t *TemplateOnlyExcept) Validate(b map[string]RawBuilderConfig) (e []error) { func (t *TemplateOnlyExcept) Validate(b map[string]RawBuilderConfig) (e []error) {
if len(t.Only) > 0 && len(t.Except) > 0 {
e = append(e,
fmt.Errorf("Only one of 'only' or 'except' may be specified."))
}
if len(t.Only) > 0 { if len(t.Only) > 0 {
for _, n := range t.Only { for _, n := range t.Only {
if _, ok := b[n]; !ok { if _, ok := b[n]; !ok {
......
...@@ -690,7 +690,67 @@ func TestTemplate_Build(t *testing.T) { ...@@ -690,7 +690,67 @@ func TestTemplate_Build(t *testing.T) {
} }
} }
func TestTemplateBuild_exeptPPInvalid(t *testing.T) { func TestTemplateBuild_exceptOnlyPP(t *testing.T) {
data := `
{
"builders": [
{
"name": "test1",
"type": "test-builder"
},
{
"name": "test2",
"type": "test-builder"
}
],
"post-processors": [
{
"type": "test-pp",
"except": ["test1"],
"only": ["test1"]
}
]
}
`
_, err := ParseTemplate([]byte(data))
if err == nil {
t.Fatal("should have error")
}
}
func TestTemplateBuild_exceptOnlyProv(t *testing.T) {
data := `
{
"builders": [
{
"name": "test1",
"type": "test-builder"
},
{
"name": "test2",
"type": "test-builder"
}
],
"provisioners": [
{
"type": "test-prov",
"except": ["test1"],
"only": ["test1"]
}
]
}
`
_, err := ParseTemplate([]byte(data))
if err == nil {
t.Fatal("should have error")
}
}
func TestTemplateBuild_exceptPPInvalid(t *testing.T) {
data := ` data := `
{ {
"builders": [ "builders": [
......
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