add tests for SensitiveVars
This commit is contained in:
parent
ff6a039d5b
commit
8a6441a7a5
|
@ -312,7 +312,7 @@ func (c *Core) init() error {
|
||||||
def, err := interpolate.Render(v.Default, ctx)
|
def, err := interpolate.Render(v.Default, ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf(
|
return fmt.Errorf(
|
||||||
"error interpolating default value for '%s': %s",
|
"error interpolating default value for '%#v': %s",
|
||||||
v, err)
|
v, err)
|
||||||
}
|
}
|
||||||
c.secrets = append(c.secrets, def)
|
c.secrets = append(c.secrets, def)
|
||||||
|
|
|
@ -516,12 +516,67 @@ func TestCoreValidate(t *testing.T) {
|
||||||
Variables: tc.Vars,
|
Variables: tc.Vars,
|
||||||
Version: "1.0.0",
|
Version: "1.0.0",
|
||||||
})
|
})
|
||||||
|
|
||||||
if (err != nil) != tc.Err {
|
if (err != nil) != tc.Err {
|
||||||
t.Fatalf("err: %s\n\n%s", tc.File, err)
|
t.Fatalf("err: %s\n\n%s", tc.File, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestSensitiveVars(t *testing.T) {
|
||||||
|
cases := []struct {
|
||||||
|
File string
|
||||||
|
Vars map[string]string
|
||||||
|
SensitiveVars []string
|
||||||
|
Expected string
|
||||||
|
Err bool
|
||||||
|
}{
|
||||||
|
// hardcoded
|
||||||
|
{
|
||||||
|
"sensitive-variables.json",
|
||||||
|
map[string]string{"foo": "bar"},
|
||||||
|
[]string{"foo"},
|
||||||
|
"bar",
|
||||||
|
false,
|
||||||
|
},
|
||||||
|
// interpolated
|
||||||
|
{
|
||||||
|
"sensitive-variables.json",
|
||||||
|
map[string]string{"foo": "{{build_name}}"},
|
||||||
|
[]string{"foo"},
|
||||||
|
"test",
|
||||||
|
false,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tc := range cases {
|
||||||
|
f, err := os.Open(fixtureDir(tc.File))
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
tpl, err := template.Parse(f)
|
||||||
|
f.Close()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("err: %s\n\n%s", tc.File, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
_, err = NewCore(&CoreConfig{
|
||||||
|
Template: tpl,
|
||||||
|
Variables: tc.Vars,
|
||||||
|
Version: "1.0.0",
|
||||||
|
})
|
||||||
|
|
||||||
|
if (err != nil) != tc.Err {
|
||||||
|
t.Fatalf("err: %s\n\n%s", tc.File, err)
|
||||||
|
}
|
||||||
|
filtered := LogSecretFilter.get()
|
||||||
|
if filtered[0] != tc.Expected && len(filtered) != 1 {
|
||||||
|
t.Fatalf("not filtering sensitive vars; filtered is %#v", filtered)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func testComponentFinder() *ComponentFinder {
|
func testComponentFinder() *ComponentFinder {
|
||||||
builderFactory := func(n string) (Builder, error) { return new(MockBuilder), nil }
|
builderFactory := func(n string) (Builder, error) { return new(MockBuilder), nil }
|
||||||
ppFactory := func(n string) (PostProcessor, error) { return new(MockPostProcessor), nil }
|
ppFactory := func(n string) (PostProcessor, error) { return new(MockPostProcessor), nil }
|
||||||
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
{
|
||||||
|
"variables": {
|
||||||
|
"foo": "bar"
|
||||||
|
},
|
||||||
|
"sensitive-variables": [
|
||||||
|
"foo"
|
||||||
|
],
|
||||||
|
"builders": [{
|
||||||
|
"type": "test",
|
||||||
|
"value": "{{build_name}}"
|
||||||
|
}]
|
||||||
|
}
|
|
@ -7,7 +7,6 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"log"
|
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"sort"
|
"sort"
|
||||||
|
|
Loading…
Reference in New Issue