mirror of
				https://github.com/gohugoio/hugo.git
				synced 2024-05-11 05:54:58 +00:00 
			
		
		
		
	Section names are also used as the title of the list pages, but naming section folders as `Fish and Chips` and similar didn't work very well. This commit fixes that. This commit also changes the title casing of the section titles. Some may argue that this is a breaking change, but the old behaviour was also pretty broken, even for languages that use title capitalizations, as it didn't follow any particular style guide, `fish and chips` became `Fish And Chips` etc. Now it just turns the first letter into upper case, so `Fish and Chips` will be left as `Fish and Chips`. People wanting the good old behaviour can use the `title` template func. Fixes #1176
		
			
				
	
	
		
			94 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package hugolib
 | |
| 
 | |
| import (
 | |
| 	"html/template"
 | |
| 	"path/filepath"
 | |
| 	"testing"
 | |
| 
 | |
| 	"github.com/spf13/hugo/source"
 | |
| 	"github.com/spf13/viper"
 | |
| )
 | |
| 
 | |
| func TestPermalink(t *testing.T) {
 | |
| 	viper.Reset()
 | |
| 	defer viper.Reset()
 | |
| 
 | |
| 	tests := []struct {
 | |
| 		file         string
 | |
| 		base         template.URL
 | |
| 		slug         string
 | |
| 		url          string
 | |
| 		uglyURLs     bool
 | |
| 		canonifyURLs bool
 | |
| 		expectedAbs  string
 | |
| 		expectedRel  string
 | |
| 	}{
 | |
| 		{"x/y/z/boofar.md", "", "", "", false, false, "/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "", "", "", false, false, "/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		// Issue #1174
 | |
| 		{"x/y/z/boofar.md", "http://gopher.com/", "", "", false, true, "http://gopher.com/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "http://gopher.com/", "", "", true, true, "http://gopher.com/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "", "boofar", "", false, false, "/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/", "", "", false, false, "http://barnew/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/", "boofar", "", false, false, "http://barnew/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "", "", "", true, false, "/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "", "", "", true, false, "/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "", "boofar", "", true, false, "/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/", "", "", true, false, "http://barnew/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/", "boofar", "", true, false, "http://barnew/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/boo/", "boofar", "", true, false, "http://barnew/boo/x/y/z/boofar.html", "/boo/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/boo/", "boofar", "", false, true, "http://barnew/boo/x/y/z/boofar/", "/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/boo/", "boofar", "", false, false, "http://barnew/boo/x/y/z/boofar/", "/boo/x/y/z/boofar/"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/boo/", "boofar", "", true, true, "http://barnew/boo/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 		{"x/y/z/boofar.md", "http://barnew/boo", "boofar", "", true, true, "http://barnew/boo/x/y/z/boofar.html", "/x/y/z/boofar.html"},
 | |
| 
 | |
| 		// test URL overrides
 | |
| 		{"x/y/z/boofar.md", "", "", "/z/y/q/", false, false, "/z/y/q/", "/z/y/q/"},
 | |
| 	}
 | |
| 
 | |
| 	viper.Set("DefaultExtension", "html")
 | |
| 
 | |
| 	for i, test := range tests {
 | |
| 		viper.Set("uglyurls", test.uglyURLs)
 | |
| 		viper.Set("canonifyurls", test.canonifyURLs)
 | |
| 		p := &Page{
 | |
| 			Node: Node{
 | |
| 				URLPath: URLPath{
 | |
| 					Section: "z",
 | |
| 					URL:     test.url,
 | |
| 				},
 | |
| 				Site: &SiteInfo{
 | |
| 					BaseURL: test.base,
 | |
| 				},
 | |
| 			},
 | |
| 			Source: Source{File: *source.NewFile(filepath.FromSlash(test.file))},
 | |
| 		}
 | |
| 
 | |
| 		if test.slug != "" {
 | |
| 			p.update(map[string]interface{}{
 | |
| 				"slug": test.slug,
 | |
| 			})
 | |
| 		}
 | |
| 
 | |
| 		u, err := p.Permalink()
 | |
| 		if err != nil {
 | |
| 			t.Errorf("Test %d: Unable to process permalink: %s", i, err)
 | |
| 		}
 | |
| 
 | |
| 		expected := test.expectedAbs
 | |
| 		if u != expected {
 | |
| 			t.Errorf("Test %d: Expected abs url: %s, got: %s", i, expected, u)
 | |
| 		}
 | |
| 
 | |
| 		u, err = p.RelPermalink()
 | |
| 		if err != nil {
 | |
| 			t.Errorf("Test %d: Unable to process permalink: %s", i, err)
 | |
| 		}
 | |
| 
 | |
| 		expected = test.expectedRel
 | |
| 		if u != expected {
 | |
| 			t.Errorf("Test %d: Expected rel url: %s, got: %s", i, expected, u)
 | |
| 		}
 | |
| 	}
 | |
| }
 |