Fixing all tests to pass with new Viper Config
authorspf13 <steve.francia@gmail.com>
Mon, 7 Apr 2014 15:44:13 +0000 (11:44 -0400)
committerspf13 <steve.francia@gmail.com>
Mon, 7 Apr 2014 15:44:51 +0000 (11:44 -0400)
commands/hugo.go
hugolib/page_permalink_test.go
hugolib/rss_test.go
hugolib/site_test.go
hugolib/site_url_test.go
hugolib/siteinfo_test.go

index 0e84093c1dc6e8b9826afd78ec5cbb5f333b2c9f..2a6bd8e6e877128b95c9e60dc63722f522ba44f7 100644 (file)
@@ -80,7 +80,7 @@ func init() {
 }
 
 func InitializeConfig() {
-       viper.SetConfigName(CfgFile) // config
+       viper.SetConfigName(CfgFile)
        viper.AddConfigPath(Source)
        viper.ReadInConfig()
 
index a4fed5b1998611c3344cd8d42c4c9391995c2b65..5bbf07da8d63d3b8ae1a1ad02e79e1f55ac85a7b 100644 (file)
@@ -3,6 +3,8 @@ package hugolib
 import (
        "html/template"
        "testing"
+
+       "github.com/spf13/viper"
 )
 
 func TestPermalink(t *testing.T) {
@@ -32,6 +34,7 @@ func TestPermalink(t *testing.T) {
        }
 
        for _, test := range tests {
+               viper.Set("uglyurls", test.uglyurls)
                p := &Page{
                        Node: Node{
                                UrlPath: UrlPath{
@@ -40,9 +43,6 @@ func TestPermalink(t *testing.T) {
                                },
                                Site: SiteInfo{
                                        BaseUrl: test.base,
-                                       Config: &Config{
-                                               UglyUrls: test.uglyurls,
-                                       },
                                },
                        },
                        File: File{FileName: test.file, Dir: test.dir, Extension: "html"},
index 5f21db8874c586ee718227bf63e65f70c5f0de19..8bcb155bd1264e43c6f74ddb5dcf417c1c928580 100644 (file)
@@ -2,9 +2,11 @@ package hugolib
 
 import (
        "bytes"
+       "testing"
+
        "github.com/spf13/hugo/source"
        "github.com/spf13/hugo/target"
-       "testing"
+       "github.com/spf13/viper"
 )
 
 const RSS_TEMPLATE = `<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
@@ -31,9 +33,9 @@ const RSS_TEMPLATE = `<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom
 func TestRSSOutput(t *testing.T) {
        files := make(map[string][]byte)
        target := &target.InMemoryTarget{Files: files}
+       viper.Set("baseurl", "http://auth/bub/")
        s := &Site{
                Target: target,
-               Config: Config{BaseUrl: "http://auth/bub/"},
                Source: &source.InMemorySource{ByteSource: WEIGHTED_SOURCES},
        }
        s.initializeSiteInfo()
index b56d0f329123ecffda50e1e0332ed4f87df02825..b5409b104c000622229de8406cb390c887668f52 100644 (file)
@@ -3,12 +3,15 @@ package hugolib
 import (
        "bytes"
        "fmt"
-       "github.com/spf13/hugo/source"
-       "github.com/spf13/hugo/target"
        "html/template"
        "io"
        "strings"
        "testing"
+
+       "github.com/spf13/hugo/helpers"
+       "github.com/spf13/hugo/source"
+       "github.com/spf13/hugo/target"
+       "github.com/spf13/viper"
 )
 
 const (
@@ -200,11 +203,9 @@ func TestTargetPath(t *testing.T) {
        if true {
                return
        }
+
        for _, test := range tests {
-               s := &Site{
-                       Config: Config{ContentDir: "content"},
-               }
-               p := pageMust(ReadFrom(strings.NewReader(test.content), s.Config.GetAbsPath(test.doc)))
+               p := pageMust(ReadFrom(strings.NewReader(test.content), helpers.AbsPathify(test.doc)))
 
                expected := test.expectedOutFile
 
@@ -232,13 +233,11 @@ func TestSkipRender(t *testing.T) {
                {"sect/doc8.html", []byte("---\nmarkup: md\n---\n# title\nsome *content*"), "sect"},
        }
 
+       viper.Set("verbose", true)
+       viper.Set("CanonifyUrls", true)
+       viper.Set("baseurl", "http://auth/bub")
        s := &Site{
                Target: target,
-               Config: Config{
-                       Verbose:      true,
-                       BaseUrl:      "http://auth/bub",
-                       CanonifyUrls: true,
-               },
                Source: &source.InMemorySource{ByteSource: sources},
        }
 
@@ -295,15 +294,13 @@ func TestAbsUrlify(t *testing.T) {
                {"content/blue/doc2.html", []byte("---\nf: t\n---\n<!doctype html><html><body>more content</body></html>"), "blue"},
        }
        for _, canonify := range []bool{true, false} {
+               viper.Set("CanonifyUrls", canonify)
+               viper.Set("BaseUrl", "http://auth/bub")
                s := &Site{
                        Target: target,
-                       Config: Config{
-                               BaseUrl:      "http://auth/bub",
-                               CanonifyUrls: canonify,
-                       },
                        Source: &source.InMemorySource{ByteSource: sources},
                }
-               t.Logf("Rendering with BaseUrl %q and CanonifyUrls set %v", s.Config.BaseUrl, canonify)
+               t.Logf("Rendering with BaseUrl %q and CanonifyUrls set %v", viper.GetString("baseUrl"), canonify)
                s.initializeSiteInfo()
                s.prepTemplates()
                must(s.addTemplate("blue/single.html", TEMPLATE_WITH_URL_ABS))
@@ -335,7 +332,7 @@ func TestAbsUrlify(t *testing.T) {
 
                        expected := test.expected
                        if !canonify {
-                               expected = strings.Replace(expected, s.Config.BaseUrl, "", -1)
+                               expected = strings.Replace(expected, viper.GetString("baseurl"), "", -1)
                        }
                        if string(content) != expected {
                                t.Errorf("AbsUrlify content expected:\n%q\ngot\n%q", expected, string(content))
@@ -380,9 +377,10 @@ var WEIGHTED_SOURCES = []source.ByteSource{
 func TestOrderedPages(t *testing.T) {
        files := make(map[string][]byte)
        target := &target.InMemoryTarget{Files: files}
+
+       viper.Set("baseurl", "http://auth/bub")
        s := &Site{
                Target: target,
-               Config: Config{BaseUrl: "http://auth/bub/"},
                Source: &source.InMemorySource{ByteSource: WEIGHTED_SOURCES},
        }
        s.initializeSiteInfo()
@@ -466,9 +464,11 @@ func TestWeightedIndexes(t *testing.T) {
 
        indexes["tag"] = "tags"
        indexes["category"] = "categories"
+
+       viper.Set("baseurl", "http://auth/bub")
+       viper.Set("indexes", indexes)
        s := &Site{
                Target: target,
-               Config: Config{BaseUrl: "http://auth/bub/", Indexes: indexes},
                Source: &source.InMemorySource{ByteSource: sources},
        }
        s.initializeSiteInfo()
index ef661961b63d36e15453c67aa0f1df8758a0b9c0..f248d6df184bcbee6489f9fcdd61427603b58185 100644 (file)
@@ -1,10 +1,12 @@
 package hugolib
 
 import (
-       "github.com/spf13/hugo/source"
-       "github.com/spf13/hugo/target"
        "html/template"
        "testing"
+
+       "github.com/spf13/hugo/source"
+       "github.com/spf13/hugo/target"
+       "github.com/spf13/viper"
 )
 
 const SLUG_DOC_1 = "---\ntitle: slug doc 1\nslug: slug-doc-1\naliases:\n - sd1/foo/\n - sd2\n - sd3/\n - sd4.html\n---\nslug doc 1 content\n"
@@ -51,10 +53,11 @@ func TestPageCount(t *testing.T) {
        files := make(map[string][]byte)
        target := &target.InMemoryTarget{Files: files}
        alias := &InMemoryAliasTarget{files: files}
+
+       viper.Set("uglyurls", false)
        s := &Site{
                Target: target,
                Alias:  alias,
-               Config: Config{UglyUrls: false},
                Source: &source.InMemorySource{ByteSource: urlFakeSource},
        }
        s.initializeSiteInfo()
index c0ae5657563816a292225a5adb10c668e86a5863..7d765e5802bbe2003461bb4564c602c930396c05 100644 (file)
@@ -3,14 +3,15 @@ package hugolib
 import (
        "bytes"
        "testing"
+
+       "github.com/spf13/viper"
 )
 
 const SITE_INFO_PARAM_TEMPLATE = `{{ .Site.Params.MyGlobalParam }}`
 
 func TestSiteInfoParams(t *testing.T) {
-       s := &Site{
-               Config: Config{Params: map[string]interface{}{"MyGlobalParam": "FOOBAR_PARAM"}},
-       }
+       viper.Set("Params", map[string]interface{}{"MyGlobalParam": "FOOBAR_PARAM"})
+       s := &Site{}
 
        s.initialize()
        if s.Info.Params["MyGlobalParam"] != "FOOBAR_PARAM" {