Return error from HandleShortcodes
authorbep <bjorn.erik.pedersen@gmail.com>
Wed, 29 Apr 2015 17:08:34 +0000 (19:08 +0200)
committerbep <bjorn.erik.pedersen@gmail.com>
Wed, 29 Apr 2015 17:08:27 +0000 (19:08 +0200)
To be able to test for it.

hugolib/shortcode.go
hugolib/shortcode_test.go

index 74e10cd505b273bc9f346e9b7cd1a3c717f1fb10..722c86db0c884bff4cd14986991e654570ee62a0 100644 (file)
@@ -122,22 +122,22 @@ func (sc shortcode) String() string {
        return fmt.Sprintf("%s(%q, %t){%s}", sc.name, params, sc.doMarkup, sc.inner)
 }
 
-// handleShortcodes does all in  one go: extract, render and replace
+// HandleShortcodes does all in  one go: extract, render and replace
 // only used for testing
-func handleShortcodes(stringToParse string, page *Page, t tpl.Template) string {
+func HandleShortcodes(stringToParse string, page *Page, t tpl.Template) (string, error) {
        tmpContent, tmpShortcodes := extractAndRenderShortcodes(stringToParse, page, t)
 
        if len(tmpShortcodes) > 0 {
                tmpContentWithTokensReplaced, err := replaceShortcodeTokens([]byte(tmpContent), shortcodePlaceholderPrefix, true, tmpShortcodes)
 
                if err != nil {
-                       jww.ERROR.Printf("Fail to replace short code tokens in %s:\n%s", page.BaseFileName(), err.Error())
+                       return "", fmt.Errorf("Fail to replace short code tokens in %s:\n%s", page.BaseFileName(), err.Error())
                } else {
-                       return string(tmpContentWithTokensReplaced)
+                       return string(tmpContentWithTokensReplaced), nil
                }
        }
 
-       return string(tmpContent)
+       return string(tmpContent), nil
 }
 
 var isInnerShortcodeCache = struct {
index 231758da56bb3d1f335f6fa8aa75664ed6a678b6..b8cc49157a001886f432fc7f334960c578b552ca 100644 (file)
@@ -20,7 +20,11 @@ func pageFromString(in, filename string) (*Page, error) {
 func CheckShortCodeMatch(t *testing.T, input, expected string, template tpl.Template) {
 
        p, _ := pageFromString(SIMPLE_PAGE, "simple.md")
-       output := handleShortcodes(input, p, template)
+       output, err := HandleShortcodes(input, p, template)
+
+       if err != nil {
+               t.Fatalf("Shortcode rendered error %s. Expected: %q, Got: %q", err, expected, output)
+       }
 
        if output != expected {
                t.Fatalf("Shortcode render didn't match. Expected: %q, Got: %q", expected, output)