hugolib: Fix bundle path when slug is set
authorBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Fri, 31 May 2019 07:40:58 +0000 (09:40 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sun, 9 Jun 2019 14:55:08 +0000 (16:55 +0200)
Fixes #4870

hugolib/page__paths.go
hugolib/pagebundler_test.go
hugolib/testhelpers_test.go
resources/page/page_paths.go

index adbdb4668c7c17c7bb4fbe7598159adb930deaec..a9152f44aba13e02cb94d48ffc70ea94e67bb21a 100644 (file)
@@ -15,6 +15,9 @@ package hugolib
 
 import (
        "net/url"
+       "strings"
+
+       "github.com/gohugoio/hugo/helpers"
 
        "github.com/gohugoio/hugo/resources/page"
 )
@@ -95,8 +98,9 @@ func (l pagePaths) OutputFormats() page.OutputFormats {
 
 func createTargetPathDescriptor(s *Site, p page.Page, pm *pageMeta) (page.TargetPathDescriptor, error) {
        var (
-               dir      string
-               baseName string
+               dir             string
+               baseName        string
+               contentBaseName string
        )
 
        d := s.Deps
@@ -104,6 +108,14 @@ func createTargetPathDescriptor(s *Site, p page.Page, pm *pageMeta) (page.Target
        if !p.File().IsZero() {
                dir = p.File().Dir()
                baseName = p.File().TranslationBaseName()
+               contentBaseName = p.File().ContentBaseName()
+       }
+
+       if baseName != contentBaseName {
+               // See https://github.com/gohugoio/hugo/issues/4870
+               // A leaf bundle
+               dir = strings.TrimSuffix(dir, contentBaseName+helpers.FilePathSeparator)
+               baseName = contentBaseName
        }
 
        alwaysInSubDir := p.Kind() == kindSitemap
index 64c1529d8928e3ab19c086eea2cdfdfca3d01429..79e0a107d6080fcf3c2e77e848be01f20f06d54d 100644 (file)
@@ -460,7 +460,7 @@ HEADLESS {{< myShort >}}
        assert.Equal(1, len(s.headlessPages))
 
        regular := s.getPage(page.KindPage, "a/index")
-       assert.Equal("/a/s1/", regular.RelPermalink())
+       assert.Equal("/s1/", regular.RelPermalink())
 
        headless := s.getPage(page.KindPage, "b/index")
        assert.NotNil(headless)
@@ -481,12 +481,12 @@ HEADLESS {{< myShort >}}
 
        th := testHelper{s.Cfg, s.Fs, t}
 
-       th.assertFileContent(filepath.FromSlash(workDir+"/public/a/s1/index.html"), "TheContent")
-       th.assertFileContent(filepath.FromSlash(workDir+"/public/a/s1/l1.png"), "PNG")
+       th.assertFileContent(filepath.FromSlash(workDir+"/public/s1/index.html"), "TheContent")
+       th.assertFileContent(filepath.FromSlash(workDir+"/public/s1/l1.png"), "PNG")
 
-       th.assertFileNotExist(workDir + "/public/b/s2/index.html")
+       th.assertFileNotExist(workDir + "/public/s2/index.html")
        // But the bundled resources needs to be published
-       th.assertFileContent(filepath.FromSlash(workDir+"/public/b/s2/l1.png"), "PNG")
+       th.assertFileContent(filepath.FromSlash(workDir+"/public/s2/l1.png"), "PNG")
 
 }
 
@@ -942,3 +942,32 @@ date: 2017-01-15
        b.AssertFileContent("public/mybundle/data.json", "My changed data")
 
 }
+
+// https://github.com/gohugoio/hugo/issues/4870
+func TestBundleSlug(t *testing.T) {
+       t.Parallel()
+       assert := require.New(t)
+
+       const pageTemplate = `---
+title: Title
+slug: %s
+---
+`
+
+       b := newTestSitesBuilder(t)
+
+       b.WithTemplatesAdded("index.html", `{{ range .Site.RegularPages }}|{{ .RelPermalink }}{{ end }}|`)
+       b.WithSimpleConfigFile().
+               WithContent("about/services1/misc.md", fmt.Sprintf(pageTemplate, "this-is-the-slug")).
+               WithContent("about/services2/misc/index.md", fmt.Sprintf(pageTemplate, "this-is-another-slug"))
+
+       b.CreateSites().Build(BuildCfg{})
+
+       b.AssertHome(
+               "|/about/services1/this-is-the-slug/|/",
+               "|/about/services2/this-is-another-slug/|")
+
+       assert.True(b.CheckExists("public/about/services1/this-is-the-slug/index.html"))
+       assert.True(b.CheckExists("public/about/services2/this-is-another-slug/index.html"))
+
+}
index fe0f824f2c912cffdd392228dbaaaa3afcf13c47..8c72e10d0c1201972830ed02c962d8894b821d86 100644 (file)
@@ -549,6 +549,10 @@ func (s *sitesBuilder) AssertFileContentFn(filename string, f func(s string) boo
        }
 }
 
+func (s *sitesBuilder) AssertHome(matches ...string) {
+       s.AssertFileContent("public/index.html", matches...)
+}
+
 func (s *sitesBuilder) AssertFileContent(filename string, matches ...string) {
        content := s.FileContent(filename)
        for _, match := range matches {
index fd231e72b48e7e6b76f5f905b01923662e5dc7b4..247c4dfcbfca4e1e6db789adc311da2db284fa62 100644 (file)
@@ -221,6 +221,8 @@ func CreateTargetPaths(d TargetPathDescriptor) (tp TargetPaths) {
 
                link = pagePath
 
+               // TODO(bep) this should not happen after the fix in https://github.com/gohugoio/hugo/issues/4870
+               // but we may need some more testing before we can remove it.
                if baseNameSameAsType {
                        link = strings.TrimSuffix(link, d.BaseName)
                }