2018-02-01 21:07:02 -06:00
|
|
|
package configs
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"path"
|
2018-02-06 20:05:14 -06:00
|
|
|
"reflect"
|
|
|
|
"testing"
|
2018-02-01 21:07:02 -06:00
|
|
|
|
2018-02-06 20:05:14 -06:00
|
|
|
"github.com/davecgh/go-spew/spew"
|
|
|
|
|
|
|
|
"github.com/hashicorp/hcl2/hcl"
|
2018-02-01 21:07:02 -06:00
|
|
|
"github.com/spf13/afero"
|
|
|
|
)
|
|
|
|
|
|
|
|
// testParser returns a parser that reads files from the given map, which
|
|
|
|
// is from paths to file contents.
|
|
|
|
//
|
|
|
|
// Since this function uses only in-memory objects, it should never fail.
|
|
|
|
// If any errors are encountered in practice, this function will panic.
|
|
|
|
func testParser(files map[string]string) *Parser {
|
|
|
|
fs := afero.Afero{Fs: afero.NewMemMapFs()}
|
|
|
|
|
|
|
|
for filePath, contents := range files {
|
|
|
|
dirPath := path.Dir(filePath)
|
|
|
|
err := fs.MkdirAll(dirPath, os.ModePerm)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
err = fs.WriteFile(filePath, []byte(contents), os.ModePerm)
|
|
|
|
if err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return NewParser(fs)
|
|
|
|
}
|
2018-02-06 20:05:14 -06:00
|
|
|
|
|
|
|
// testModuleFromFile reads a single file, wraps it in a module, and returns
|
|
|
|
// it. This is a helper for use in unit tests.
|
|
|
|
func testModuleFromFile(filename string) (*Module, hcl.Diagnostics) {
|
|
|
|
parser := NewParser(nil)
|
|
|
|
f, diags := parser.LoadConfigFile(filename)
|
|
|
|
mod, modDiags := NewModule([]*File{f}, nil)
|
|
|
|
diags = append(diags, modDiags...)
|
|
|
|
return mod, modDiags
|
|
|
|
}
|
|
|
|
|
|
|
|
// testModuleFromDir reads configuration from the given directory path as
|
|
|
|
// a module and returns it. This is a helper for use in unit tests.
|
|
|
|
func testModuleFromDir(path string) (*Module, hcl.Diagnostics) {
|
|
|
|
parser := NewParser(nil)
|
|
|
|
return parser.LoadConfigDir(path)
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertNoDiagnostics(t *testing.T, diags hcl.Diagnostics) bool {
|
|
|
|
t.Helper()
|
|
|
|
return assertDiagnosticCount(t, diags, 0)
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertDiagnosticCount(t *testing.T, diags hcl.Diagnostics, want int) bool {
|
|
|
|
t.Helper()
|
|
|
|
if len(diags) != 0 {
|
|
|
|
t.Errorf("wrong number of diagnostics %d; want %d", len(diags), want)
|
|
|
|
for _, diag := range diags {
|
|
|
|
t.Logf("- %s", diag)
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func assertDiagnosticSummary(t *testing.T, diags hcl.Diagnostics, want string) bool {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
for _, diag := range diags {
|
|
|
|
if diag.Summary == want {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Errorf("missing diagnostic summary %q", want)
|
|
|
|
for _, diag := range diags {
|
|
|
|
t.Logf("- %s", diag)
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2018-11-20 13:53:45 -06:00
|
|
|
func assertExactDiagnostics(t *testing.T, diags hcl.Diagnostics, want []string) bool {
|
|
|
|
t.Helper()
|
|
|
|
|
|
|
|
gotDiags := map[string]bool{}
|
|
|
|
wantDiags := map[string]bool{}
|
|
|
|
|
|
|
|
for _, diag := range diags {
|
|
|
|
gotDiags[diag.Error()] = true
|
|
|
|
}
|
|
|
|
for _, msg := range want {
|
|
|
|
wantDiags[msg] = true
|
|
|
|
}
|
|
|
|
|
|
|
|
bad := false
|
|
|
|
for got := range gotDiags {
|
|
|
|
if _, exists := wantDiags[got]; !exists {
|
|
|
|
t.Errorf("unexpected diagnostic: %s", got)
|
|
|
|
bad = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for want := range wantDiags {
|
|
|
|
if _, exists := gotDiags[want]; !exists {
|
|
|
|
t.Errorf("missing expected diagnostic: %s", want)
|
|
|
|
bad = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return bad
|
|
|
|
}
|
|
|
|
|
2018-02-06 20:05:14 -06:00
|
|
|
func assertResultDeepEqual(t *testing.T, got, want interface{}) bool {
|
|
|
|
t.Helper()
|
|
|
|
if !reflect.DeepEqual(got, want) {
|
|
|
|
t.Errorf("wrong result\ngot: %swant: %s", spew.Sdump(got), spew.Sdump(want))
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
2018-02-06 20:30:12 -06:00
|
|
|
|
|
|
|
func stringPtr(s string) *string {
|
|
|
|
return &s
|
|
|
|
}
|