Skip to content

Commit ab82a27

Browse files
committed
Fix URLs for bundle resources in multihost mode
Fixes #4217
1 parent f25d8a9 commit ab82a27

File tree

6 files changed

+42
-17
lines changed

6 files changed

+42
-17
lines changed

‎helpers/pathspec.go‎

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -35,8 +35,8 @@ type PathSpec struct {
3535
uglyURLs bool
3636
canonifyURLs bool
3737

38-
language *Language
39-
languages Languages
38+
Language *Language
39+
Languages Languages
4040

4141
// pagination path handling
4242
paginatePath string
@@ -70,7 +70,7 @@ type PathSpec struct {
7070
}
7171

7272
func (p PathSpec) String() string {
73-
return fmt.Sprintf("PathSpec, language %q, prefix %q, multilingual: %T", p.language.Lang, p.getLanguagePrefix(), p.multilingual)
73+
return fmt.Sprintf("PathSpec, language %q, prefix %q, multilingual: %T", p.Language.Lang, p.getLanguagePrefix(), p.multilingual)
7474
}
7575

7676
// NewPathSpec creats a new PathSpec from the given filesystems and Language.
@@ -113,8 +113,8 @@ func NewPathSpec(fs *hugofs.Fs, cfg config.Provider) (*PathSpec, error) {
113113
uglyURLs: cfg.GetBool("uglyURLs"),
114114
canonifyURLs: cfg.GetBool("canonifyURLs"),
115115
multilingual: cfg.GetBool("multilingual"),
116-
language: language,
117-
languages: languages,
116+
Language: language,
117+
Languages: languages,
118118
defaultContentLanguageInSubdir: cfg.GetBool("defaultContentLanguageInSubdir"),
119119
defaultContentLanguage: cfg.GetString("defaultContentLanguage"),
120120
paginatePath: cfg.GetString("paginatePath"),

‎helpers/pathspec_test.go‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -50,7 +50,7 @@ func TestNewPathSpecFromConfig(t *testing.T) {
5050
require.True(t, p.removePathAccents)
5151
require.True(t, p.uglyURLs)
5252
require.Equal(t, "no", p.defaultContentLanguage)
53-
require.Equal(t, "no", p.language.Lang)
53+
require.Equal(t, "no", p.Language.Lang)
5454
require.Equal(t, "side", p.paginatePath)
5555

5656
require.Equal(t, "http://base.com", p.BaseURL.String())

‎helpers/url.go‎

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -208,7 +208,7 @@ func (p *PathSpec) getLanguagePrefix() string {
208208
defaultLang := p.defaultContentLanguage
209209
defaultInSubDir := p.defaultContentLanguageInSubdir
210210

211-
currentLang := p.language.Lang
211+
currentLang := p.Language.Lang
212212
if currentLang == "" || (currentLang == defaultLang && !defaultInSubDir) {
213213
return ""
214214
}
@@ -221,7 +221,7 @@ func (p *PathSpec) GetLangSubDir(lang string) string {
221221
return ""
222222
}
223223

224-
if p.languages.IsMultihost() {
224+
if p.Languages.IsMultihost() {
225225
return ""
226226
}
227227

‎hugolib/hugo_sites_build_test.go‎

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -394,7 +394,7 @@ func doTestMultiSitesBuild(t *testing.T, configTemplate, configSuffix string) {
394394
}
395395

396396
// Check bundles
397-
bundleFr := enSite.getPage(KindPage, "bundles/b1/index.md")
397+
bundleFr := frSite.getPage(KindPage, "bundles/b1/index.md")
398398
require.NotNil(t, bundleFr)
399399
require.Equal(t, "/blog/fr/bundles/b1/", bundleFr.RelPermalink())
400400
require.Equal(t, 1, len(bundleFr.Resources))

‎hugolib/hugo_sites_multihost_test.go‎

Lines changed: 28 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
package hugolib
22

33
import (
4+
"path/filepath"
45
"testing"
56

67
"github.com/spf13/afero"
@@ -26,7 +27,7 @@ tag = "tags"
2627
[Languages]
2728
[Languages.en]
2829
staticDir2 = ["ens1", "ens2"]
29-
baseURL = "https://example.com"
30+
baseURL = "https://example.com/docs"
3031
weight = 10
3132
title = "In English"
3233
languageName = "English"
@@ -65,7 +66,7 @@ languageName = "Nynorsk"
6566
s1h := s1.getPage(KindHome)
6667
assert.True(s1h.IsTranslated())
6768
assert.Len(s1h.Translations(), 2)
68-
assert.Equal("https://example.com/", s1h.Permalink())
69+
assert.Equal("https://example.com/docs/", s1h.Permalink())
6970

7071
// For “regular multilingual” we kept the aliases pages with url in front matter
7172
// as a literal value that we use as is.
@@ -76,12 +77,12 @@ languageName = "Nynorsk"
7677
pageWithURLInFrontMatter := s1.getPage(KindPage, "sect/doc3.en.md")
7778
assert.NotNil(pageWithURLInFrontMatter)
7879
assert.Equal("/superbob", pageWithURLInFrontMatter.URL())
79-
assert.Equal("/superbob/", pageWithURLInFrontMatter.RelPermalink())
80+
assert.Equal("/docs/superbob/", pageWithURLInFrontMatter.RelPermalink())
8081
th.assertFileContent("public/en/superbob/index.html", "doc3|Hello|en")
8182

8283
// check alias:
83-
th.assertFileContent("public/en/al/alias1/index.html", `content="0; url=https://example.com/superbob/"`)
84-
th.assertFileContent("public/en/al/alias2/index.html", `content="0; url=https://example.com/superbob/"`)
84+
th.assertFileContent("public/en/al/alias1/index.html", `content="0; url=https://example.com/docs/superbob/"`)
85+
th.assertFileContent("public/en/al/alias2/index.html", `content="0; url=https://example.com/docs/superbob/"`)
8586

8687
s2 := sites.Sites[1]
8788
assert.Equal([]string{"s1", "s2", "frs1", "frs2"}, s2.StaticDirs())
@@ -93,9 +94,29 @@ languageName = "Nynorsk"
9394
th.assertFileContentStraight("public/en/index.html", "Default Home Page")
9495

9596
// Check paginators
96-
th.assertFileContent("public/en/page/1/index.html", `refresh" content="0; url=https://example.com/"`)
97+
th.assertFileContent("public/en/page/1/index.html", `refresh" content="0; url=https://example.com/docs/"`)
9798
th.assertFileContent("public/nn/page/1/index.html", `refresh" content="0; url=https://example.no/"`)
98-
th.assertFileContent("public/en/sect/page/2/index.html", "List Page 2", "Hello", "https://example.com/sect/", "\"/sect/page/3/")
99+
th.assertFileContent("public/en/sect/page/2/index.html", "List Page 2", "Hello", "https://example.com/docs/sect/", "\"/docs/sect/page/3/")
99100
th.assertFileContent("public/fr/sect/page/2/index.html", "List Page 2", "Bonjour", "https://example.fr/sect/")
100101

102+
// Check bundles
103+
104+
bundleEn := s1.getPage(KindPage, "bundles/b1/index.en.md")
105+
require.NotNil(t, bundleEn)
106+
require.Equal(t, "/docs/bundles/b1/", bundleEn.RelPermalink())
107+
require.Equal(t, 1, len(bundleEn.Resources))
108+
logoEn := bundleEn.Resources.GetByPrefix("logo")
109+
require.NotNil(t, logoEn)
110+
require.Equal(t, "/docs/bundles/b1/logo.png", logoEn.RelPermalink())
111+
require.Contains(t, readFileFromFs(t, fs.Destination, filepath.FromSlash("public/en/bundles/b1/logo.png")), "PNG Data")
112+
113+
bundleFr := s2.getPage(KindPage, "bundles/b1/index.md")
114+
require.NotNil(t, bundleFr)
115+
require.Equal(t, "/bundles/b1/", bundleFr.RelPermalink())
116+
require.Equal(t, 1, len(bundleFr.Resources))
117+
logoFr := bundleFr.Resources.GetByPrefix("logo")
118+
require.NotNil(t, logoFr)
119+
require.Equal(t, "/bundles/b1/logo.png", logoFr.RelPermalink())
120+
require.Contains(t, readFileFromFs(t, fs.Destination, filepath.FromSlash("public/fr/bundles/b1/logo.png")), "PNG Data")
121+
101122
}

‎resource/resource.go‎

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -273,7 +273,11 @@ func (l *genericResource) Publish() error {
273273
}
274274

275275
func (l *genericResource) target() string {
276-
return l.relPermalinkForRel(l.rel, false)
276+
target := l.relPermalinkForRel(l.rel, false)
277+
if l.spec.PathSpec.Languages.IsMultihost() {
278+
target = path.Join(l.spec.PathSpec.Language.Lang, target)
279+
}
280+
return target
277281
}
278282

279283
func (r *Spec) newGenericResource(

0 commit comments

Comments
 (0)