mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-21 20:46:30 -05:00
54141f71dd
The current "rendering language" is needed outside of Site. This commit moves the Language type to the helpers package, and then used to get correct correct language configuration in the markdownify template func. This commit also adds two new template funcs: relLangURL and absLangURL. See #2309
284 lines
8.6 KiB
Go
284 lines
8.6 KiB
Go
// Copyright 2015 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 helpers
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"testing"
|
|
|
|
"github.com/spf13/viper"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestURLize(t *testing.T) {
|
|
tests := []struct {
|
|
input string
|
|
expected string
|
|
}{
|
|
{" foo bar ", "foo-bar"},
|
|
{"foo.bar/foo_bar-foo", "foo.bar/foo_bar-foo"},
|
|
{"foo,bar:foobar", "foobarfoobar"},
|
|
{"foo/bar.html", "foo/bar.html"},
|
|
{"трям/трям", "%D1%82%D1%80%D1%8F%D0%BC/%D1%82%D1%80%D1%8F%D0%BC"},
|
|
{"100%-google", "100-google"},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
output := URLize(test.input)
|
|
if output != test.expected {
|
|
t.Errorf("Expected %#v, got %#v\n", test.expected, output)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestAbsURL(t *testing.T) {
|
|
for _, addLanguage := range []bool{true, false} {
|
|
for _, m := range []bool{true, false} {
|
|
for _, l := range []string{"en", "fr"} {
|
|
doTestAbsURL(t, addLanguage, m, l)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func doTestAbsURL(t *testing.T, addLanguage, multilingual bool, lang string) {
|
|
viper.Reset()
|
|
viper.Set("Multilingual", multilingual)
|
|
viper.Set("CurrentContentLanguage", NewLanguage(lang))
|
|
tests := []struct {
|
|
input string
|
|
baseURL string
|
|
expected string
|
|
}{
|
|
{"/test/foo", "http://base/", "http://base/MULTItest/foo"},
|
|
{"", "http://base/ace/", "http://base/ace/MULTI"},
|
|
{"/test/2/foo/", "http://base", "http://base/MULTItest/2/foo/"},
|
|
{"http://abs", "http://base/", "http://abs"},
|
|
{"schema://abs", "http://base/", "schema://abs"},
|
|
{"//schemaless", "http://base/", "//schemaless"},
|
|
{"test/2/foo/", "http://base/path", "http://base/path/MULTItest/2/foo/"},
|
|
{"/test/2/foo/", "http://base/path", "http://base/MULTItest/2/foo/"},
|
|
{"http//foo", "http://base/path", "http://base/path/MULTIhttp/foo"},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
viper.Set("BaseURL", test.baseURL)
|
|
output := AbsURL(test.input, addLanguage)
|
|
expected := test.expected
|
|
if multilingual && addLanguage {
|
|
expected = strings.Replace(expected, "MULTI", lang+"/", 1)
|
|
} else {
|
|
expected = strings.Replace(expected, "MULTI", "", 1)
|
|
}
|
|
if output != expected {
|
|
t.Errorf("Expected %#v, got %#v\n", expected, output)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestIsAbsURL(t *testing.T) {
|
|
for i, this := range []struct {
|
|
a string
|
|
b bool
|
|
}{
|
|
{"http://gohugo.io", true},
|
|
{"https://gohugo.io", true},
|
|
{"//gohugo.io", true},
|
|
{"http//gohugo.io", false},
|
|
{"/content", false},
|
|
{"content", false},
|
|
} {
|
|
require.True(t, IsAbsURL(this.a) == this.b, fmt.Sprintf("Test %d", i))
|
|
}
|
|
}
|
|
|
|
func TestRelURL(t *testing.T) {
|
|
for _, addLanguage := range []bool{true, false} {
|
|
for _, m := range []bool{true, false} {
|
|
for _, l := range []string{"en", "fr"} {
|
|
doTestRelURL(t, addLanguage, m, l)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
func doTestRelURL(t *testing.T, addLanguage, multilingual bool, lang string) {
|
|
viper.Reset()
|
|
viper.Set("Multilingual", multilingual)
|
|
viper.Set("CurrentContentLanguage", NewLanguage(lang))
|
|
|
|
tests := []struct {
|
|
input string
|
|
baseURL string
|
|
canonify bool
|
|
expected string
|
|
}{
|
|
{"/test/foo", "http://base/", false, "MULTI/test/foo"},
|
|
{"test.css", "http://base/sub", false, "/subMULTI/test.css"},
|
|
{"test.css", "http://base/sub", true, "MULTI/test.css"},
|
|
{"/test/", "http://base/", false, "MULTI/test/"},
|
|
{"/test/", "http://base/sub/", false, "/subMULTI/test/"},
|
|
{"/test/", "http://base/sub/", true, "MULTI/test/"},
|
|
{"", "http://base/ace/", false, "/aceMULTI/"},
|
|
{"", "http://base/ace", false, "/aceMULTI"},
|
|
{"http://abs", "http://base/", false, "http://abs"},
|
|
{"//schemaless", "http://base/", false, "//schemaless"},
|
|
}
|
|
|
|
for i, test := range tests {
|
|
viper.Set("BaseURL", test.baseURL)
|
|
viper.Set("canonifyURLs", test.canonify)
|
|
|
|
output := RelURL(test.input, addLanguage)
|
|
|
|
expected := test.expected
|
|
if multilingual && addLanguage {
|
|
expected = strings.Replace(expected, "MULTI", "/"+lang, 1)
|
|
} else {
|
|
expected = strings.Replace(expected, "MULTI", "", 1)
|
|
}
|
|
|
|
if output != expected {
|
|
t.Errorf("[%d][%t] Expected %#v, got %#v\n", i, test.canonify, expected, output)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestSanitizeURL(t *testing.T) {
|
|
tests := []struct {
|
|
input string
|
|
expected string
|
|
}{
|
|
{"http://foo.bar/", "http://foo.bar"},
|
|
{"http://foo.bar", "http://foo.bar"}, // issue #1105
|
|
{"http://foo.bar/zoo/", "http://foo.bar/zoo"}, // issue #931
|
|
}
|
|
|
|
for i, test := range tests {
|
|
o1 := SanitizeURL(test.input)
|
|
o2 := SanitizeURLKeepTrailingSlash(test.input)
|
|
|
|
expected2 := test.expected
|
|
|
|
if strings.HasSuffix(test.input, "/") && !strings.HasSuffix(expected2, "/") {
|
|
expected2 += "/"
|
|
}
|
|
|
|
if o1 != test.expected {
|
|
t.Errorf("[%d] 1: Expected %#v, got %#v\n", i, test.expected, o1)
|
|
}
|
|
if o2 != expected2 {
|
|
t.Errorf("[%d] 2: Expected %#v, got %#v\n", i, expected2, o2)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestMakePermalink(t *testing.T) {
|
|
type test struct {
|
|
host, link, output string
|
|
}
|
|
|
|
data := []test{
|
|
{"http://abc.com/foo", "post/bar", "http://abc.com/foo/post/bar"},
|
|
{"http://abc.com/foo/", "post/bar", "http://abc.com/foo/post/bar"},
|
|
{"http://abc.com", "post/bar", "http://abc.com/post/bar"},
|
|
{"http://abc.com", "bar", "http://abc.com/bar"},
|
|
{"http://abc.com/foo/bar", "post/bar", "http://abc.com/foo/bar/post/bar"},
|
|
{"http://abc.com/foo/bar", "post/bar/", "http://abc.com/foo/bar/post/bar/"},
|
|
}
|
|
|
|
for i, d := range data {
|
|
output := MakePermalink(d.host, d.link).String()
|
|
if d.output != output {
|
|
t.Errorf("Test #%d failed. Expected %q got %q", i, d.output, output)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestURLPrep(t *testing.T) {
|
|
type test struct {
|
|
ugly bool
|
|
input string
|
|
output string
|
|
}
|
|
|
|
data := []test{
|
|
{false, "/section/name.html", "/section/name/"},
|
|
{true, "/section/name/index.html", "/section/name.html"},
|
|
}
|
|
for i, d := range data {
|
|
output := URLPrep(d.ugly, d.input)
|
|
if d.output != output {
|
|
t.Errorf("Test #%d failed. Expected %q got %q", i, d.output, output)
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
func TestAddContextRoot(t *testing.T) {
|
|
tests := []struct {
|
|
baseURL string
|
|
url string
|
|
expected string
|
|
}{
|
|
{"http://example.com/sub/", "/foo", "/sub/foo"},
|
|
{"http://example.com/sub/", "/foo/index.html", "/sub/foo/index.html"},
|
|
{"http://example.com/sub1/sub2", "/foo", "/sub1/sub2/foo"},
|
|
{"http://example.com", "/foo", "/foo"},
|
|
// cannot guess that the context root is already added int the example below
|
|
{"http://example.com/sub/", "/sub/foo", "/sub/sub/foo"},
|
|
{"http://example.com/тря", "/трям/", "/тря/трям/"},
|
|
{"http://example.com", "/", "/"},
|
|
{"http://example.com/bar", "//", "/bar/"},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
output := AddContextRoot(test.baseURL, test.url)
|
|
if output != test.expected {
|
|
t.Errorf("Expected %#v, got %#v\n", test.expected, output)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestPretty(t *testing.T) {
|
|
assert.Equal(t, PrettifyURLPath("/section/name.html"), "/section/name/index.html")
|
|
assert.Equal(t, PrettifyURLPath("/section/sub/name.html"), "/section/sub/name/index.html")
|
|
assert.Equal(t, PrettifyURLPath("/section/name/"), "/section/name/index.html")
|
|
assert.Equal(t, PrettifyURLPath("/section/name/index.html"), "/section/name/index.html")
|
|
assert.Equal(t, PrettifyURLPath("/index.html"), "/index.html")
|
|
assert.Equal(t, PrettifyURLPath("/name.xml"), "/name/index.xml")
|
|
assert.Equal(t, PrettifyURLPath("/"), "/")
|
|
assert.Equal(t, PrettifyURLPath(""), "/")
|
|
assert.Equal(t, PrettifyURL("/section/name.html"), "/section/name")
|
|
assert.Equal(t, PrettifyURL("/section/sub/name.html"), "/section/sub/name")
|
|
assert.Equal(t, PrettifyURL("/section/name/"), "/section/name")
|
|
assert.Equal(t, PrettifyURL("/section/name/index.html"), "/section/name")
|
|
assert.Equal(t, PrettifyURL("/index.html"), "/")
|
|
assert.Equal(t, PrettifyURL("/name.xml"), "/name/index.xml")
|
|
assert.Equal(t, PrettifyURL("/"), "/")
|
|
assert.Equal(t, PrettifyURL(""), "/")
|
|
}
|
|
|
|
func TestUgly(t *testing.T) {
|
|
assert.Equal(t, Uglify("/section/name.html"), "/section/name.html")
|
|
assert.Equal(t, Uglify("/section/sub/name.html"), "/section/sub/name.html")
|
|
assert.Equal(t, Uglify("/section/name/"), "/section/name.html")
|
|
assert.Equal(t, Uglify("/section/name/index.html"), "/section/name.html")
|
|
assert.Equal(t, Uglify("/index.html"), "/index.html")
|
|
assert.Equal(t, Uglify("/name.xml"), "/name.xml")
|
|
assert.Equal(t, Uglify("/"), "/")
|
|
assert.Equal(t, Uglify(""), "/")
|
|
}
|