summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSteve Francia <steve.francia@gmail.com>2013-08-13 07:44:43 -0700
committerSteve Francia <steve.francia@gmail.com>2013-08-13 07:44:43 -0700
commitca5a94a98866a664fb68be06b609537a619a19ea (patch)
treef7d2557a5498773e2e35d1f5d96742eddd4e4d9d
parentc661d9803e861fa46146ad5a6a8d700317bc9499 (diff)
parent2d11d1bd671ef20fe833855d87506fd2b7ffa515 (diff)
Merge pull request #37 from noahcampbell/master
Test GetParam and the various incarnations of frontmatter.
-rw-r--r--hugolib/page_index_test.go79
1 files changed, 79 insertions, 0 deletions
diff --git a/hugolib/page_index_test.go b/hugolib/page_index_test.go
new file mode 100644
index 000000000..49c7504c7
--- /dev/null
+++ b/hugolib/page_index_test.go
@@ -0,0 +1,79 @@
+package hugolib
+
+import (
+ "strings"
+ "testing"
+)
+
+var PAGE_YAML_WITH_INDEXES_A = `---
+tags: ['a', 'b', 'c']
+categories: 'd'
+---
+YAML frontmatter with tags and categories index.`
+
+var PAGE_YAML_WITH_INDEXES_B = `---
+tags:
+ - "a"
+ - "b"
+ - "c"
+categories: 'd'
+---
+YAML frontmatter with tags and categories index.`
+
+var PAGE_JSON_WITH_INDEXES = `{
+ "categories": "d",
+ "tags": [
+ "a",
+ "b",
+ "c"
+ ]
+}
+JSON Front Matter with tags and categories`
+
+var PAGE_TOML_WITH_INDEXES = `+++
+tags = [ "a", "b", "c" ]
+categories = "d"
++++
+TOML Front Matter with tags and categories`
+
+func TestParseIndexes(t *testing.T) {
+ for _, test := range []string{PAGE_TOML_WITH_INDEXES,
+ PAGE_JSON_WITH_INDEXES,
+ PAGE_YAML_WITH_INDEXES_A,
+ PAGE_YAML_WITH_INDEXES_B,
+ } {
+ p, err := ReadFrom(strings.NewReader(test), "page/with/index")
+ if err != nil {
+ t.Fatalf("Failed parsing page: %s", err)
+ }
+
+ param := p.GetParam("tags")
+ params := param.([]string)
+
+ expected := []string{"a", "b", "c"}
+ if !compareStringSlice(params, expected) {
+ t.Errorf("Expected %s: got: %s", expected, params)
+ }
+
+ param = p.GetParam("categories")
+ singleparam := param.(string)
+
+ if singleparam != "d" {
+ t.Fatalf("Expected: d, got: %s", singleparam)
+ }
+ }
+}
+
+func compareStringSlice(a, b []string) bool {
+ if len(a) != len(b) {
+ return false
+ }
+
+ for i, v := range a {
+ if b[i] != v {
+ return false
+ }
+ }
+
+ return true
+}