mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-21 20:46:30 -05:00
Pull Data Files tests into its own file
This commit is contained in:
parent
1e8e5d4e7a
commit
9cc3d67c57
2 changed files with 97 additions and 91 deletions
92
hugolib/datafiles_test.go
Normal file
92
hugolib/datafiles_test.go
Normal file
|
@ -0,0 +1,92 @@
|
||||||
|
package hugolib
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/hugo/parser"
|
||||||
|
"github.com/spf13/hugo/source"
|
||||||
|
"path/filepath"
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDataDirJSON(t *testing.T) {
|
||||||
|
sources := []source.ByteSource{
|
||||||
|
{filepath.FromSlash("test/foo.json"), []byte(`{ "bar": "foofoo" }`)},
|
||||||
|
{filepath.FromSlash("test.json"), []byte(`{ "hello": [ { "world": "foo" } ] }`)},
|
||||||
|
}
|
||||||
|
|
||||||
|
expected, err := parser.HandleJSONMetaData([]byte(`{ "test": { "hello": [{ "world": "foo" }] , "foo": { "bar":"foofoo" } } }`))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDataDirToml(t *testing.T) {
|
||||||
|
sources := []source.ByteSource{
|
||||||
|
{filepath.FromSlash("test/kung.toml"), []byte("[foo]\nbar = 1")},
|
||||||
|
}
|
||||||
|
|
||||||
|
expected, err := parser.HandleTOMLMetaData([]byte("[test]\n[test.kung]\n[test.kung.foo]\nbar = 1"))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error %s", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDataDirYAMLWithOverridenValue(t *testing.T) {
|
||||||
|
sources := []source.ByteSource{
|
||||||
|
// filepath.Walk walks the files in lexical order, '/' comes before '.'. Simulate this:
|
||||||
|
{filepath.FromSlash("a.yaml"), []byte("a: 1")},
|
||||||
|
{filepath.FromSlash("test/v1.yaml"), []byte("v1-2: 2")},
|
||||||
|
{filepath.FromSlash("test/v2.yaml"), []byte("v2:\n- 2\n- 3")},
|
||||||
|
{filepath.FromSlash("test.yaml"), []byte("v1: 1")},
|
||||||
|
}
|
||||||
|
|
||||||
|
expected := map[string]interface{}{"a": map[string]interface{}{"a": 1},
|
||||||
|
"test": map[string]interface{}{"v1": map[string]interface{}{"v1-2": 2}, "v2": map[string]interface{}{"v2": []interface{}{2, 3}}}}
|
||||||
|
|
||||||
|
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
||||||
|
}
|
||||||
|
|
||||||
|
// issue 892
|
||||||
|
func TestDataDirMultipleSources(t *testing.T) {
|
||||||
|
s1 := []source.ByteSource{
|
||||||
|
{filepath.FromSlash("test/first.toml"), []byte("bar = 1")},
|
||||||
|
}
|
||||||
|
|
||||||
|
s2 := []source.ByteSource{
|
||||||
|
{filepath.FromSlash("test/first.toml"), []byte("bar = 2")},
|
||||||
|
{filepath.FromSlash("test/second.toml"), []byte("tender = 2")},
|
||||||
|
}
|
||||||
|
|
||||||
|
expected, _ := parser.HandleTOMLMetaData([]byte("[test.first]\nbar = 1\n[test.second]\ntender=2"))
|
||||||
|
|
||||||
|
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: s1}, &source.InMemorySource{ByteSource: s2}})
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDataDirUnknownFormat(t *testing.T) {
|
||||||
|
sources := []source.ByteSource{
|
||||||
|
{filepath.FromSlash("test.roml"), []byte("boo")},
|
||||||
|
}
|
||||||
|
s := &Site{}
|
||||||
|
err := s.loadData([]source.Input{&source.InMemorySource{ByteSource: sources}})
|
||||||
|
if err == nil {
|
||||||
|
t.Fatalf("Should return an error")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func doTestDataDir(t *testing.T, expected interface{}, sources []source.Input) {
|
||||||
|
s := &Site{}
|
||||||
|
err := s.loadData(sources)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("Error loading data: %s", err)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(expected, s.Data) {
|
||||||
|
t.Errorf("Expected structure\n%#v got\n%#v", expected, s.Data)
|
||||||
|
}
|
||||||
|
}
|
|
@ -3,13 +3,6 @@ package hugolib
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"github.com/spf13/hugo/parser"
|
|
||||||
"html/template"
|
|
||||||
"io"
|
|
||||||
"path/filepath"
|
|
||||||
"strings"
|
|
||||||
"testing"
|
|
||||||
|
|
||||||
"github.com/spf13/afero"
|
"github.com/spf13/afero"
|
||||||
"github.com/spf13/hugo/helpers"
|
"github.com/spf13/hugo/helpers"
|
||||||
"github.com/spf13/hugo/hugofs"
|
"github.com/spf13/hugo/hugofs"
|
||||||
|
@ -17,7 +10,11 @@ import (
|
||||||
"github.com/spf13/hugo/target"
|
"github.com/spf13/hugo/target"
|
||||||
"github.com/spf13/hugo/tpl"
|
"github.com/spf13/hugo/tpl"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
"reflect"
|
"html/template"
|
||||||
|
"io"
|
||||||
|
"path/filepath"
|
||||||
|
"strings"
|
||||||
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -906,86 +903,3 @@ func TestWeightedTaxonomies(t *testing.T) {
|
||||||
t.Errorf("Pages in unexpected order, 'bza' expected first, got '%v'", s.Taxonomies["categories"]["e"][0].Page.Title)
|
t.Errorf("Pages in unexpected order, 'bza' expected first, got '%v'", s.Taxonomies["categories"]["e"][0].Page.Title)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestDataDirJSON(t *testing.T) {
|
|
||||||
sources := []source.ByteSource{
|
|
||||||
{filepath.FromSlash("test/foo.json"), []byte(`{ "bar": "foofoo" }`)},
|
|
||||||
{filepath.FromSlash("test.json"), []byte(`{ "hello": [ { "world": "foo" } ] }`)},
|
|
||||||
}
|
|
||||||
|
|
||||||
expected, err := parser.HandleJSONMetaData([]byte(`{ "test": { "hello": [{ "world": "foo" }] , "foo": { "bar":"foofoo" } } }`))
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Error %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDataDirToml(t *testing.T) {
|
|
||||||
sources := []source.ByteSource{
|
|
||||||
{filepath.FromSlash("test/kung.toml"), []byte("[foo]\nbar = 1")},
|
|
||||||
}
|
|
||||||
|
|
||||||
expected, err := parser.HandleTOMLMetaData([]byte("[test]\n[test.kung]\n[test.kung.foo]\nbar = 1"))
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Error %s", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDataDirYAMLWithOverridenValue(t *testing.T) {
|
|
||||||
sources := []source.ByteSource{
|
|
||||||
// filepath.Walk walks the files in lexical order, '/' comes before '.'. Simulate this:
|
|
||||||
{filepath.FromSlash("a.yaml"), []byte("a: 1")},
|
|
||||||
{filepath.FromSlash("test/v1.yaml"), []byte("v1-2: 2")},
|
|
||||||
{filepath.FromSlash("test/v2.yaml"), []byte("v2:\n- 2\n- 3")},
|
|
||||||
{filepath.FromSlash("test.yaml"), []byte("v1: 1")},
|
|
||||||
}
|
|
||||||
|
|
||||||
expected := map[string]interface{}{"a": map[string]interface{}{"a": 1},
|
|
||||||
"test": map[string]interface{}{"v1": map[string]interface{}{"v1-2": 2}, "v2": map[string]interface{}{"v2": []interface{}{2, 3}}}}
|
|
||||||
|
|
||||||
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: sources}})
|
|
||||||
}
|
|
||||||
|
|
||||||
// issue 892
|
|
||||||
func TestDataDirMultipleSources(t *testing.T) {
|
|
||||||
s1 := []source.ByteSource{
|
|
||||||
{filepath.FromSlash("test/first.toml"), []byte("bar = 1")},
|
|
||||||
}
|
|
||||||
|
|
||||||
s2 := []source.ByteSource{
|
|
||||||
{filepath.FromSlash("test/first.toml"), []byte("bar = 2")},
|
|
||||||
{filepath.FromSlash("test/second.toml"), []byte("tender = 2")},
|
|
||||||
}
|
|
||||||
|
|
||||||
expected, _ := parser.HandleTOMLMetaData([]byte("[test.first]\nbar = 1\n[test.second]\ntender=2"))
|
|
||||||
|
|
||||||
doTestDataDir(t, expected, []source.Input{&source.InMemorySource{ByteSource: s1}, &source.InMemorySource{ByteSource: s2}})
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDataDirUnknownFormat(t *testing.T) {
|
|
||||||
sources := []source.ByteSource{
|
|
||||||
{filepath.FromSlash("test.roml"), []byte("boo")},
|
|
||||||
}
|
|
||||||
s := &Site{}
|
|
||||||
err := s.loadData([]source.Input{&source.InMemorySource{ByteSource: sources}})
|
|
||||||
if err == nil {
|
|
||||||
t.Fatalf("Should return an error")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func doTestDataDir(t *testing.T, expected interface{}, sources []source.Input) {
|
|
||||||
s := &Site{}
|
|
||||||
err := s.loadData(sources)
|
|
||||||
if err != nil {
|
|
||||||
t.Fatalf("Error loading data: %s", err)
|
|
||||||
}
|
|
||||||
if !reflect.DeepEqual(expected, s.Data) {
|
|
||||||
t.Errorf("Expected structure\n%#v got\n%#v", expected, s.Data)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue