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 {
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)