Fix unicode menu URLs
authorbep <bjorn.erik.pedersen@gmail.com>
Tue, 16 Dec 2014 11:08:16 +0000 (12:08 +0100)
committerbep <bjorn.erik.pedersen@gmail.com>
Fri, 26 Dec 2014 12:30:46 +0000 (13:30 +0100)
Menu urls like /categories/новости-проекта would turn into /categories/d0bdd0bed0b2d0bed181d182d0b8-d0bfd180d0bed0b5d0bad182d0b0, which is illegal, while the directory under the categories/ is created with the original name. It results in 404 not found error.

This commit fixes that by make sure that SanitizeUrl() is called last.

Fixes #719

hugolib/menu_test.go
hugolib/site.go

index f4758d31f4fea1119aa25ed630cdae1dca501744..1712e45203ecd4050121e1cfe3690d8c214ffd6f 100644 (file)
@@ -9,6 +9,7 @@ import (
        "github.com/spf13/hugo/hugofs"
        "github.com/spf13/hugo/source"
        "github.com/spf13/viper"
+       "github.com/stretchr/testify/assert"
 )
 
 const (
@@ -47,7 +48,11 @@ const (
 [[menu.tax]]
        name = "Tax RSS"
     url = "/two/key.xml"
-       identifier="xml"`
+       identifier="xml"
+[[menu.unicode]]
+   name = "Unicode Russian"
+   identifier = "unicode-russian"
+   url = "/новости-проекта"` // Russian => "news-project"
 )
 
 var MENU_PAGE_1 = []byte(`+++
@@ -139,6 +144,31 @@ func _TestPageMenu(t *testing.T) {
 
 }
 
+// issue #719
+func TestMenuWithUnicodeUrls(t *testing.T) {
+       for _, uglyUrls := range []bool{true, false} {
+               doTestMenuWithUnicodeUrls(t, uglyUrls)
+       }
+}
+
+func doTestMenuWithUnicodeUrls(t *testing.T, uglyUrls bool) {
+       viper.Set("UglyUrls", uglyUrls)
+       ts := setupMenuTests(t)
+       defer resetMenuTestState(ts)
+
+       unicodeRussian := ts.findTestMenuEntryById("unicode", "unicode-russian")
+
+       expectedBase := "http://foo.local/zoo/%D0%BD%D0%BE%D0%B2%D0%BE%D1%81%D1%82%D0%B8-%D0%BF%D1%80%D0%BE%D0%B5%D0%BA%D1%82%D0%B0"
+       var expected string
+       if uglyUrls {
+               expected = expectedBase + ".html"
+       } else {
+               expected = expectedBase + "/"
+       }
+
+       assert.Equal(t, expected, unicodeRussian.Url, "uglyUrls[%t]", uglyUrls)
+}
+
 func TestTaxonomyNodeMenu(t *testing.T) {
        ts := setupMenuTests(t)
        defer resetMenuTestState(ts)
index e2c62a4f52d92f65529a3efed06a9649888fc6c2..6ff64b48e7f4da5adc39f6f68521f588c7fac277 100644 (file)
@@ -1168,7 +1168,7 @@ func (s *Site) permalinkStr(plink string) string {
 }
 
 func (s *Site) prepUrl(in string) string {
-       return helpers.Urlize(s.PrettifyUrl(in))
+       return s.PrettifyUrl(helpers.Urlize(in))
 }
 
 func (s *Site) PrettifyUrl(in string) string {