mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-29 06:12:02 -05:00
parent
5ef52294f9
commit
cd558958a0
11 changed files with 96 additions and 45 deletions
|
@ -23,6 +23,10 @@ import (
|
||||||
"os/exec"
|
"os/exec"
|
||||||
"unicode/utf8"
|
"unicode/utf8"
|
||||||
|
|
||||||
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
"sync"
|
||||||
|
|
||||||
"github.com/miekg/mmark"
|
"github.com/miekg/mmark"
|
||||||
"github.com/mitchellh/mapstructure"
|
"github.com/mitchellh/mapstructure"
|
||||||
"github.com/russross/blackfriday"
|
"github.com/russross/blackfriday"
|
||||||
|
@ -30,9 +34,6 @@ import (
|
||||||
bp "github.com/spf13/hugo/bufferpool"
|
bp "github.com/spf13/hugo/bufferpool"
|
||||||
jww "github.com/spf13/jwalterweatherman"
|
jww "github.com/spf13/jwalterweatherman"
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
|
|
||||||
"strings"
|
|
||||||
"sync"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// SummaryLength is the length of the summary that Hugo extracts from a content.
|
// SummaryLength is the length of the summary that Hugo extracts from a content.
|
||||||
|
@ -167,11 +168,11 @@ func getHTMLRenderer(defaultFlags int, ctx *RenderingContext) blackfriday.Render
|
||||||
FootnoteReturnLinkContents: viper.GetString("FootnoteReturnLinkContents"),
|
FootnoteReturnLinkContents: viper.GetString("FootnoteReturnLinkContents"),
|
||||||
}
|
}
|
||||||
|
|
||||||
b := len(ctx.DocumentID) != 0
|
b := ctx.DocumentID != 0
|
||||||
|
|
||||||
if b && !ctx.getConfig().PlainIDAnchors {
|
if b && !ctx.getConfig().PlainIDAnchors {
|
||||||
renderParameters.FootnoteAnchorPrefix = ctx.DocumentID + ":" + renderParameters.FootnoteAnchorPrefix
|
renderParameters.FootnoteAnchorPrefix = fmt.Sprintf("%d:%s", ctx.DocumentID, renderParameters.FootnoteAnchorPrefix)
|
||||||
renderParameters.HeaderIDSuffix = ":" + ctx.DocumentID
|
renderParameters.HeaderIDSuffix = fmt.Sprintf(":%d", ctx.DocumentID)
|
||||||
}
|
}
|
||||||
|
|
||||||
htmlFlags := defaultFlags
|
htmlFlags := defaultFlags
|
||||||
|
@ -258,10 +259,10 @@ func getMmarkHTMLRenderer(defaultFlags int, ctx *RenderingContext) mmark.Rendere
|
||||||
FootnoteReturnLinkContents: viper.GetString("FootnoteReturnLinkContents"),
|
FootnoteReturnLinkContents: viper.GetString("FootnoteReturnLinkContents"),
|
||||||
}
|
}
|
||||||
|
|
||||||
b := len(ctx.DocumentID) != 0
|
b := ctx.DocumentID != 0
|
||||||
|
|
||||||
if b && !ctx.getConfig().PlainIDAnchors {
|
if b && !ctx.getConfig().PlainIDAnchors {
|
||||||
renderParameters.FootnoteAnchorPrefix = ctx.DocumentID + ":" + renderParameters.FootnoteAnchorPrefix
|
renderParameters.FootnoteAnchorPrefix = fmt.Sprintf("%d:%s", ctx.DocumentID, renderParameters.FootnoteAnchorPrefix)
|
||||||
// renderParameters.HeaderIDSuffix = ":" + ctx.DocumentId
|
// renderParameters.HeaderIDSuffix = ":" + ctx.DocumentId
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -343,7 +344,7 @@ func ExtractTOC(content []byte) (newcontent []byte, toc []byte) {
|
||||||
type RenderingContext struct {
|
type RenderingContext struct {
|
||||||
Content []byte
|
Content []byte
|
||||||
PageFmt string
|
PageFmt string
|
||||||
DocumentID string
|
DocumentID int
|
||||||
Config *Blackfriday
|
Config *Blackfriday
|
||||||
FileResolver FileResolverFunc
|
FileResolver FileResolverFunc
|
||||||
LinkResolver LinkResolverFunc
|
LinkResolver LinkResolverFunc
|
||||||
|
|
|
@ -172,15 +172,15 @@ func TestGetHTMLRendererAllFlags(t *testing.T) {
|
||||||
|
|
||||||
func TestGetHTMLRendererAnchors(t *testing.T) {
|
func TestGetHTMLRendererAnchors(t *testing.T) {
|
||||||
ctx := &RenderingContext{}
|
ctx := &RenderingContext{}
|
||||||
ctx.DocumentID = "testid"
|
ctx.DocumentID = 123
|
||||||
ctx.Config = ctx.getConfig()
|
ctx.Config = ctx.getConfig()
|
||||||
ctx.Config.PlainIDAnchors = false
|
ctx.Config.PlainIDAnchors = false
|
||||||
|
|
||||||
actualRenderer := getHTMLRenderer(0, ctx)
|
actualRenderer := getHTMLRenderer(0, ctx)
|
||||||
headerBuffer := &bytes.Buffer{}
|
headerBuffer := &bytes.Buffer{}
|
||||||
footnoteBuffer := &bytes.Buffer{}
|
footnoteBuffer := &bytes.Buffer{}
|
||||||
expectedFootnoteHref := []byte("href=\"#fn:testid:href\"")
|
expectedFootnoteHref := []byte("href=\"#fn:123:href\"")
|
||||||
expectedHeaderID := []byte("<h1 id=\"id:testid\"></h1>\n")
|
expectedHeaderID := []byte("<h1 id=\"id:123\"></h1>\n")
|
||||||
|
|
||||||
actualRenderer.Header(headerBuffer, func() bool { return true }, 1, "id")
|
actualRenderer.Header(headerBuffer, func() bool { return true }, 1, "id")
|
||||||
actualRenderer.FootnoteRef(footnoteBuffer, []byte("href"), 1)
|
actualRenderer.FootnoteRef(footnoteBuffer, []byte("href"), 1)
|
||||||
|
@ -196,14 +196,14 @@ func TestGetHTMLRendererAnchors(t *testing.T) {
|
||||||
|
|
||||||
func TestGetMmarkHTMLRenderer(t *testing.T) {
|
func TestGetMmarkHTMLRenderer(t *testing.T) {
|
||||||
ctx := &RenderingContext{}
|
ctx := &RenderingContext{}
|
||||||
ctx.DocumentID = "testid"
|
ctx.DocumentID = 321
|
||||||
ctx.Config = ctx.getConfig()
|
ctx.Config = ctx.getConfig()
|
||||||
ctx.Config.PlainIDAnchors = false
|
ctx.Config.PlainIDAnchors = false
|
||||||
actualRenderer := getMmarkHTMLRenderer(0, ctx)
|
actualRenderer := getMmarkHTMLRenderer(0, ctx)
|
||||||
|
|
||||||
headerBuffer := &bytes.Buffer{}
|
headerBuffer := &bytes.Buffer{}
|
||||||
footnoteBuffer := &bytes.Buffer{}
|
footnoteBuffer := &bytes.Buffer{}
|
||||||
expectedFootnoteHref := []byte("href=\"#fn:testid:href\"")
|
expectedFootnoteHref := []byte("href=\"#fn:321:href\"")
|
||||||
expectedHeaderID := []byte("<h1 id=\"id\"></h1>")
|
expectedHeaderID := []byte("<h1 id=\"id\"></h1>")
|
||||||
|
|
||||||
actualRenderer.FootnoteRef(footnoteBuffer, []byte("href"), 1)
|
actualRenderer.FootnoteRef(footnoteBuffer, []byte("href"), 1)
|
||||||
|
|
|
@ -25,8 +25,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestDefaultHandler(t *testing.T) {
|
func TestDefaultHandler(t *testing.T) {
|
||||||
viper.Reset()
|
setUp()
|
||||||
defer viper.Reset()
|
defer tearDown()
|
||||||
|
|
||||||
hugofs.InitMemFs()
|
hugofs.InitMemFs()
|
||||||
sources := []source.ByteSource{
|
sources := []source.ByteSource{
|
||||||
|
@ -63,14 +63,14 @@ func TestDefaultHandler(t *testing.T) {
|
||||||
doc string
|
doc string
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{filepath.FromSlash("sect/doc1.html"), "\n\n<h1 id=\"title:5d74edbb89ef198cd37882b687940cda\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
{filepath.FromSlash("sect/doc1.html"), "\n\n<h1 id=\"title:42\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
||||||
{filepath.FromSlash("sect/doc2.html"), "<!doctype html><html><body>more content</body></html>"},
|
{filepath.FromSlash("sect/doc2.html"), "<!doctype html><html><body>more content</body></html>"},
|
||||||
{filepath.FromSlash("sect/doc3.html"), "\n\n<h1 id=\"doc3:28c75a9e2162b8eccda73a1ab9ce80b4\">doc3</h1>\n\n<p><em>some</em> content</p>\n"},
|
{filepath.FromSlash("sect/doc3.html"), "\n\n<h1 id=\"doc3:42\">doc3</h1>\n\n<p><em>some</em> content</p>\n"},
|
||||||
{filepath.FromSlash("sect/doc3/img1.png"), string([]byte("‰PNG <20><><EFBFBD> IHDR<44><52><EFBFBD><01><><EFBFBD><08><><EFBFBD><EFBFBD>:~›U<E280BA><55><EFBFBD> IDATWcø<0F><01>ZMoñ<6F><C3B1><EFBFBD><EFBFBD>IEND®B`‚"))},
|
{filepath.FromSlash("sect/doc3/img1.png"), string([]byte("‰PNG <20><><EFBFBD> IHDR<44><52><EFBFBD><01><><EFBFBD><08><><EFBFBD><EFBFBD>:~›U<E280BA><55><EFBFBD> IDATWcø<0F><01>ZMoñ<6F><C3B1><EFBFBD><EFBFBD>IEND®B`‚"))},
|
||||||
{filepath.FromSlash("sect/img2.gif"), string([]byte("GIF89a<01><01>€<EFBFBD><E282AC>ÿÿÿ<C3BF><C3BF><EFBFBD>,<2C><><EFBFBD><EFBFBD><01><01><>D<01>;"))},
|
{filepath.FromSlash("sect/img2.gif"), string([]byte("GIF89a<01><01>€<EFBFBD><E282AC>ÿÿÿ<C3BF><C3BF><EFBFBD>,<2C><><EFBFBD><EFBFBD><01><01><>D<01>;"))},
|
||||||
{filepath.FromSlash("sect/img2.spf"), string([]byte("****FAKE-FILETYPE****"))},
|
{filepath.FromSlash("sect/img2.spf"), string([]byte("****FAKE-FILETYPE****"))},
|
||||||
{filepath.FromSlash("doc7.html"), "<html><body>doc7 content</body></html>"},
|
{filepath.FromSlash("doc7.html"), "<html><body>doc7 content</body></html>"},
|
||||||
{filepath.FromSlash("sect/doc8.html"), "\n\n<h1 id=\"title:0ae308ad73e2f37bd09874105281b5d8\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
{filepath.FromSlash("sect/doc8.html"), "\n\n<h1 id=\"title:42\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|
34
hugolib/hugolib_test.go
Normal file
34
hugolib/hugolib_test.go
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
// Copyright 2016 The Hugo Authors. All rights reserved.
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package hugolib
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/spf13/viper"
|
||||||
|
)
|
||||||
|
|
||||||
|
var stableNodeIDProvider nodeIDProviderFunc = func(n *Node) int {
|
||||||
|
return 42
|
||||||
|
}
|
||||||
|
|
||||||
|
// common test setup.
|
||||||
|
func setUp() {
|
||||||
|
viper.Reset()
|
||||||
|
nodeIDProvider = stableNodeIDProvider
|
||||||
|
}
|
||||||
|
|
||||||
|
// common test cleanup.
|
||||||
|
func tearDown() {
|
||||||
|
viper.Reset()
|
||||||
|
nodeIDProvider = defaultNodeIDProvider
|
||||||
|
}
|
|
@ -47,6 +47,15 @@ type Node struct {
|
||||||
// but that would lead to massive changes; do it simple for now.
|
// but that would lead to massive changes; do it simple for now.
|
||||||
var nodeIDCounter uint64
|
var nodeIDCounter uint64
|
||||||
|
|
||||||
|
type nodeIDProviderFunc func(n *Node) int
|
||||||
|
|
||||||
|
var defaultNodeIDProvider nodeIDProviderFunc = func(n *Node) int {
|
||||||
|
n.idInit.Do(func() { n.id = nextNodeID() })
|
||||||
|
return n.id
|
||||||
|
}
|
||||||
|
|
||||||
|
var nodeIDProvider nodeIDProviderFunc = defaultNodeIDProvider
|
||||||
|
|
||||||
func nextNodeID() int {
|
func nextNodeID() int {
|
||||||
return int(atomic.AddUint64(&nodeIDCounter, 1))
|
return int(atomic.AddUint64(&nodeIDCounter, 1))
|
||||||
}
|
}
|
||||||
|
@ -55,8 +64,7 @@ func nextNodeID() int {
|
||||||
// This is unique for a given Hugo build, but must not be considered stable.
|
// This is unique for a given Hugo build, but must not be considered stable.
|
||||||
// See UniqueID on Page for an identify that is stable for repeated builds.
|
// See UniqueID on Page for an identify that is stable for repeated builds.
|
||||||
func (n *Node) ID() int {
|
func (n *Node) ID() int {
|
||||||
n.idInit.Do(func() { n.id = nextNodeID() })
|
return nodeIDProvider(n)
|
||||||
return n.id
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (n *Node) Now() time.Time {
|
func (n *Node) Now() time.Time {
|
||||||
|
|
|
@ -43,14 +43,6 @@ func TestNodeSimpleMethods(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestNodeID(t *testing.T) {
|
func TestNodeID(t *testing.T) {
|
||||||
t.Parallel()
|
|
||||||
|
|
||||||
n1 := &Node{}
|
|
||||||
n2 := &Node{}
|
|
||||||
|
|
||||||
assert.True(t, n1.ID() > 0)
|
|
||||||
assert.Equal(t, n1.ID(), n1.ID())
|
|
||||||
assert.True(t, n2.ID() > n1.ID())
|
|
||||||
|
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
|
|
||||||
|
@ -58,8 +50,13 @@ func TestNodeID(t *testing.T) {
|
||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
go func(j int) {
|
go func(j int) {
|
||||||
for k := 0; k < 10; k++ {
|
for k := 0; k < 10; k++ {
|
||||||
n := &Node{}
|
n1 := &Node{}
|
||||||
assert.True(t, n.ID() > 0)
|
n2 := &Node{}
|
||||||
|
|
||||||
|
assert.True(t, n1.ID() > 0)
|
||||||
|
assert.Equal(t, n1.ID(), n1.ID())
|
||||||
|
assert.True(t, n2.ID() > n1.ID())
|
||||||
|
|
||||||
}
|
}
|
||||||
wg.Done()
|
wg.Done()
|
||||||
}(i)
|
}(i)
|
||||||
|
|
|
@ -265,7 +265,7 @@ func (p *Page) renderBytes(content []byte) []byte {
|
||||||
}
|
}
|
||||||
return helpers.RenderBytes(
|
return helpers.RenderBytes(
|
||||||
&helpers.RenderingContext{Content: content, PageFmt: p.determineMarkupType(),
|
&helpers.RenderingContext{Content: content, PageFmt: p.determineMarkupType(),
|
||||||
DocumentID: p.UniqueID(), Config: p.getRenderingConfig(), LinkResolver: fn, FileResolver: fileFn})
|
DocumentID: p.ID(), Config: p.getRenderingConfig(), LinkResolver: fn, FileResolver: fileFn})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Page) renderContent(content []byte) []byte {
|
func (p *Page) renderContent(content []byte) []byte {
|
||||||
|
@ -280,7 +280,7 @@ func (p *Page) renderContent(content []byte) []byte {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return helpers.RenderBytesWithTOC(&helpers.RenderingContext{Content: content, PageFmt: p.determineMarkupType(),
|
return helpers.RenderBytesWithTOC(&helpers.RenderingContext{Content: content, PageFmt: p.determineMarkupType(),
|
||||||
DocumentID: p.UniqueID(), Config: p.getRenderingConfig(), LinkResolver: fn, FileResolver: fileFn})
|
DocumentID: p.ID(), Config: p.getRenderingConfig(), LinkResolver: fn, FileResolver: fileFn})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Page) getRenderingConfig() *helpers.Blackfriday {
|
func (p *Page) getRenderingConfig() *helpers.Blackfriday {
|
||||||
|
|
|
@ -605,14 +605,17 @@ func TestPageWithAdditionalExtension(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTableOfContents(t *testing.T) {
|
func TestTableOfContents(t *testing.T) {
|
||||||
|
setUp()
|
||||||
|
defer tearDown()
|
||||||
|
|
||||||
p, _ := NewPage("tocpage.md")
|
p, _ := NewPage("tocpage.md")
|
||||||
_, err := p.ReadFrom(strings.NewReader(pageWithToC))
|
_, err := p.ReadFrom(strings.NewReader(pageWithToC))
|
||||||
p.Convert()
|
p.Convert()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("Unable to create a page with frontmatter and body content: %s", err)
|
t.Fatalf("Unable to create a page with frontmatter and body content: %s", err)
|
||||||
}
|
}
|
||||||
checkPageContent(t, p, "\n\n<p>For some moments the old man did not reply. He stood with bowed head, buried in deep thought. But at last he spoke.</p>\n\n<h2 id=\"aa:90b9174a5bdb091a9625b04adac96ca6\">AA</h2>\n\n<p>I have no idea, of course, how long it took me to reach the limit of the plain,\nbut at last I entered the foothills, following a pretty little canyon upward\ntoward the mountains. Beside me frolicked a laughing brooklet, hurrying upon\nits noisy way down to the silent sea. In its quieter pools I discovered many\nsmall fish, of four-or five-pound weight I should imagine. In appearance,\nexcept as to size and color, they were not unlike the whale of our own seas. As\nI watched them playing about I discovered, not only that they suckled their\nyoung, but that at intervals they rose to the surface to breathe as well as to\nfeed upon certain grasses and a strange, scarlet lichen which grew upon the\nrocks just above the water line.</p>\n\n<h3 id=\"aaa:90b9174a5bdb091a9625b04adac96ca6\">AAA</h3>\n\n<p>I remember I felt an extraordinary persuasion that I was being played with,\nthat presently, when I was upon the very verge of safety, this mysterious\ndeath–as swift as the passage of light–would leap after me from the pit about\nthe cylinder and strike me down. ## BB</p>\n\n<h3 id=\"bbb:90b9174a5bdb091a9625b04adac96ca6\">BBB</h3>\n\n<p>“You’re a great Granser,” he cried delightedly, “always making believe them little marks mean something.”</p>\n")
|
checkPageContent(t, p, "\n\n<p>For some moments the old man did not reply. He stood with bowed head, buried in deep thought. But at last he spoke.</p>\n\n<h2 id=\"aa:42\">AA</h2>\n\n<p>I have no idea, of course, how long it took me to reach the limit of the plain,\nbut at last I entered the foothills, following a pretty little canyon upward\ntoward the mountains. Beside me frolicked a laughing brooklet, hurrying upon\nits noisy way down to the silent sea. In its quieter pools I discovered many\nsmall fish, of four-or five-pound weight I should imagine. In appearance,\nexcept as to size and color, they were not unlike the whale of our own seas. As\nI watched them playing about I discovered, not only that they suckled their\nyoung, but that at intervals they rose to the surface to breathe as well as to\nfeed upon certain grasses and a strange, scarlet lichen which grew upon the\nrocks just above the water line.</p>\n\n<h3 id=\"aaa:42\">AAA</h3>\n\n<p>I remember I felt an extraordinary persuasion that I was being played with,\nthat presently, when I was upon the very verge of safety, this mysterious\ndeath–as swift as the passage of light–would leap after me from the pit about\nthe cylinder and strike me down. ## BB</p>\n\n<h3 id=\"bbb:42\">BBB</h3>\n\n<p>“You’re a great Granser,” he cried delightedly, “always making believe them little marks mean something.”</p>\n")
|
||||||
checkPageTOC(t, p, "<nav id=\"TableOfContents\">\n<ul>\n<li>\n<ul>\n<li><a href=\"#aa:90b9174a5bdb091a9625b04adac96ca6\">AA</a>\n<ul>\n<li><a href=\"#aaa:90b9174a5bdb091a9625b04adac96ca6\">AAA</a></li>\n<li><a href=\"#bbb:90b9174a5bdb091a9625b04adac96ca6\">BBB</a></li>\n</ul></li>\n</ul></li>\n</ul>\n</nav>")
|
checkPageTOC(t, p, "<nav id=\"TableOfContents\">\n<ul>\n<li>\n<ul>\n<li><a href=\"#aa:42\">AA</a>\n<ul>\n<li><a href=\"#aaa:42\">AAA</a></li>\n<li><a href=\"#bbb:42\">BBB</a></li>\n</ul></li>\n</ul></li>\n</ul>\n</nav>")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestPageWithMoreTag(t *testing.T) {
|
func TestPageWithMoreTag(t *testing.T) {
|
||||||
|
|
|
@ -235,7 +235,7 @@ func renderShortcode(sc shortcode, parent *ShortcodeWithPage, p *Page, t tpl.Tem
|
||||||
if sc.doMarkup {
|
if sc.doMarkup {
|
||||||
newInner := helpers.RenderBytes(&helpers.RenderingContext{
|
newInner := helpers.RenderBytes(&helpers.RenderingContext{
|
||||||
Content: []byte(inner), PageFmt: p.determineMarkupType(),
|
Content: []byte(inner), PageFmt: p.determineMarkupType(),
|
||||||
DocumentID: p.UniqueID(), Config: p.getRenderingConfig()})
|
DocumentID: p.ID(), Config: p.getRenderingConfig()})
|
||||||
|
|
||||||
// If the type is “unknown” or “markdown”, we assume the markdown
|
// If the type is “unknown” or “markdown”, we assume the markdown
|
||||||
// generation has been performed. Given the input: `a line`, markdown
|
// generation has been performed. Given the input: `a line`, markdown
|
||||||
|
|
|
@ -168,6 +168,9 @@ func TestInnerSC(t *testing.T) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestInnerSCWithMarkdown(t *testing.T) {
|
func TestInnerSCWithMarkdown(t *testing.T) {
|
||||||
|
setUp()
|
||||||
|
defer tearDown()
|
||||||
|
|
||||||
tem := tpl.New()
|
tem := tpl.New()
|
||||||
tem.AddInternalShortcode("inside.html", `<div{{with .Get "class"}} class="{{.}}"{{end}}>{{ .Inner }}</div>`)
|
tem.AddInternalShortcode("inside.html", `<div{{with .Get "class"}} class="{{.}}"{{end}}>{{ .Inner }}</div>`)
|
||||||
|
|
||||||
|
@ -176,10 +179,12 @@ func TestInnerSCWithMarkdown(t *testing.T) {
|
||||||
|
|
||||||
[link](http://spf13.com) and text
|
[link](http://spf13.com) and text
|
||||||
|
|
||||||
{{% /inside %}}`, "<div><h1 id=\"more-here:bec3ed8ba720b9073ab75abcf3ba5d97\">More Here</h1>\n\n<p><a href=\"http://spf13.com\">link</a> and text</p>\n</div>", tem)
|
{{% /inside %}}`, "<div><h1 id=\"more-here:42\">More Here</h1>\n\n<p><a href=\"http://spf13.com\">link</a> and text</p>\n</div>", tem)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestInnerSCWithAndWithoutMarkdown(t *testing.T) {
|
func TestInnerSCWithAndWithoutMarkdown(t *testing.T) {
|
||||||
|
setUp()
|
||||||
|
defer tearDown()
|
||||||
tem := tpl.New()
|
tem := tpl.New()
|
||||||
tem.AddInternalShortcode("inside.html", `<div{{with .Get "class"}} class="{{.}}"{{end}}>{{ .Inner }}</div>`)
|
tem.AddInternalShortcode("inside.html", `<div{{with .Get "class"}} class="{{.}}"{{end}}>{{ .Inner }}</div>`)
|
||||||
|
|
||||||
|
@ -198,7 +203,7 @@ And then:
|
||||||
This is **plain** text.
|
This is **plain** text.
|
||||||
|
|
||||||
{{< /inside >}}
|
{{< /inside >}}
|
||||||
`, "<div><h1 id=\"more-here:bec3ed8ba720b9073ab75abcf3ba5d97\">More Here</h1>\n\n<p><a href=\"http://spf13.com\">link</a> and text</p>\n</div>\n\nAnd then:\n\n<div>\n# More Here\n\nThis is **plain** text.\n\n</div>\n", tem)
|
`, "<div><h1 id=\"more-here:42\">More Here</h1>\n\n<p><a href=\"http://spf13.com\">link</a> and text</p>\n</div>\n\nAnd then:\n\n<div>\n# More Here\n\nThis is **plain** text.\n\n</div>\n", tem)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEmbeddedSC(t *testing.T) {
|
func TestEmbeddedSC(t *testing.T) {
|
||||||
|
|
|
@ -142,6 +142,9 @@ func NopCloser(w io.Writer) io.WriteCloser {
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestRenderThing(t *testing.T) {
|
func TestRenderThing(t *testing.T) {
|
||||||
|
setUp()
|
||||||
|
defer tearDown()
|
||||||
|
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
content string
|
content string
|
||||||
template string
|
template string
|
||||||
|
@ -149,7 +152,7 @@ func TestRenderThing(t *testing.T) {
|
||||||
}{
|
}{
|
||||||
{pageSimpleTitle, templateTitle, "simple template"},
|
{pageSimpleTitle, templateTitle, "simple template"},
|
||||||
{pageSimpleTitle, templateFunc, "simple-template"},
|
{pageSimpleTitle, templateFunc, "simple-template"},
|
||||||
{pageWithMd, templateContent, "\n\n<h1 id=\"heading-1:91b5c4a22fc6103c73bb91e4a40568f8\">heading 1</h1>\n\n<p>text</p>\n\n<h2 id=\"heading-2:91b5c4a22fc6103c73bb91e4a40568f8\">heading 2</h2>\n\n<p>more text</p>\n"},
|
{pageWithMd, templateContent, "\n\n<h1 id=\"heading-1:42\">heading 1</h1>\n\n<p>text</p>\n\n<h2 id=\"heading-2:42\">heading 2</h2>\n\n<p>more text</p>\n"},
|
||||||
{simplePageRFC3339Date, templateDate, "2013-05-17 16:59:30 +0000 UTC"},
|
{simplePageRFC3339Date, templateDate, "2013-05-17 16:59:30 +0000 UTC"},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -556,8 +559,8 @@ func doTestSectionNaming(t *testing.T, canonify, uglify, pluralize bool) {
|
||||||
|
|
||||||
}
|
}
|
||||||
func TestSkipRender(t *testing.T) {
|
func TestSkipRender(t *testing.T) {
|
||||||
viper.Reset()
|
setUp()
|
||||||
defer viper.Reset()
|
defer tearDown()
|
||||||
|
|
||||||
hugofs.InitMemFs()
|
hugofs.InitMemFs()
|
||||||
sources := []source.ByteSource{
|
sources := []source.ByteSource{
|
||||||
|
@ -593,14 +596,14 @@ func TestSkipRender(t *testing.T) {
|
||||||
doc string
|
doc string
|
||||||
expected string
|
expected string
|
||||||
}{
|
}{
|
||||||
{filepath.FromSlash("sect/doc1.html"), "\n\n<h1 id=\"title:5d74edbb89ef198cd37882b687940cda\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
{filepath.FromSlash("sect/doc1.html"), "\n\n<h1 id=\"title:42\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
||||||
{filepath.FromSlash("sect/doc2.html"), "<!doctype html><html><body>more content</body></html>"},
|
{filepath.FromSlash("sect/doc2.html"), "<!doctype html><html><body>more content</body></html>"},
|
||||||
{filepath.FromSlash("sect/doc3.html"), "\n\n<h1 id=\"doc3:28c75a9e2162b8eccda73a1ab9ce80b4\">doc3</h1>\n\n<p><em>some</em> content</p>\n"},
|
{filepath.FromSlash("sect/doc3.html"), "\n\n<h1 id=\"doc3:42\">doc3</h1>\n\n<p><em>some</em> content</p>\n"},
|
||||||
{filepath.FromSlash("sect/doc4.html"), "\n\n<h1 id=\"doc4:f8e6806123f341b8975509637645a4d3\">doc4</h1>\n\n<p><em>some content</em></p>\n"},
|
{filepath.FromSlash("sect/doc4.html"), "\n\n<h1 id=\"doc4:42\">doc4</h1>\n\n<p><em>some content</em></p>\n"},
|
||||||
{filepath.FromSlash("sect/doc5.html"), "<!doctype html><html><head><script src=\"script.js\"></script></head><body>body5</body></html>"},
|
{filepath.FromSlash("sect/doc5.html"), "<!doctype html><html><head><script src=\"script.js\"></script></head><body>body5</body></html>"},
|
||||||
{filepath.FromSlash("sect/doc6.html"), "<!doctype html><html><head><script src=\"http://auth/bub/script.js\"></script></head><body>body5</body></html>"},
|
{filepath.FromSlash("sect/doc6.html"), "<!doctype html><html><head><script src=\"http://auth/bub/script.js\"></script></head><body>body5</body></html>"},
|
||||||
{filepath.FromSlash("doc7.html"), "<html><body>doc7 content</body></html>"},
|
{filepath.FromSlash("doc7.html"), "<html><body>doc7 content</body></html>"},
|
||||||
{filepath.FromSlash("sect/doc8.html"), "\n\n<h1 id=\"title:0ae308ad73e2f37bd09874105281b5d8\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
{filepath.FromSlash("sect/doc8.html"), "\n\n<h1 id=\"title:42\">title</h1>\n\n<p>some <em>content</em></p>\n"},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
|
|
Loading…
Reference in a new issue