Tighten page kind logic, introduce tests
authorVas Sudanagunta <vas@commonkarma.org>
Sun, 21 Jan 2018 19:40:58 +0000 (14:40 -0500)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Mon, 22 Jan 2018 12:55:08 +0000 (13:55 +0100)
hugolib/page.go
hugolib/page_test.go

index 64bef07ae54b4e7151c78898249e8e3b351e83d2..2502faa0898d0b2f463afc2ef3361d783267f2c2 100644 (file)
@@ -759,7 +759,7 @@ func (s *Site) newPage(filename string) *Page {
 func (s *Site) newPageFromFile(fi *fileInfo) *Page {
        return &Page{
                pageInit:    &pageInit{},
-               Kind:        kindFromFilename(fi.Path()),
+               Kind:        kindFromFileInfo(fi),
                contentType: "",
                Source:      Source{File: fi},
                Keywords:    []string{}, Sitemap: Sitemap{Priority: -1},
@@ -2010,24 +2010,16 @@ func sectionsFromDir(dirname string) []string {
        return strings.Split(dirname, helpers.FilePathSeparator)
 }
 
-const (
-       regularPageFileNameDoesNotStartWith = "_index"
-
-       // There can be "my_regular_index_page.md but not /_index_file.md
-       regularPageFileNameDoesNotContain = helpers.FilePathSeparator + regularPageFileNameDoesNotStartWith
-)
-
-func kindFromFilename(filename string) string {
-       if !strings.HasPrefix(filename, regularPageFileNameDoesNotStartWith) && !strings.Contains(filename, regularPageFileNameDoesNotContain) {
-               return KindPage
-       }
-
-       if strings.HasPrefix(filename, "_index") {
-               return KindHome
+func kindFromFileInfo(fi *fileInfo) string {
+       if fi.TranslationBaseName() == "_index" {
+               if fi.Dir() == "" {
+                       return KindHome
+               }
+               // Could be index for section, taxonomy, taxonomy term
+               // We don't know enough yet to determine which
+               return kindUnknown
        }
-
-       // We don't know enough yet to determine the type.
-       return kindUnknown
+       return KindPage
 }
 
 func (p *Page) setValuesForKind(s *Site) {
index c947382e4b47f249df26fce3bd8c928e318626a5..2413ac4a2bbbcaae9262537f83e412364bac0553 100644 (file)
@@ -1010,6 +1010,60 @@ func TestCreatePage(t *testing.T) {
        }
 }
 
+func TestPageKind(t *testing.T) {
+       t.Parallel()
+       const sep = helpers.FilePathSeparator
+       var tests = []struct {
+               file string
+               kind string
+       }{
+               {"_index.md", KindHome},
+               {"about.md", KindPage},
+               {"sectionA" + sep + "_index.md", KindSection},
+               {"sectionA" + sep + "about.md", KindPage},
+               {"categories" + sep + "_index.md", KindTaxonomyTerm},
+               {"categories" + sep + "categoryA" + sep + "_index.md", KindTaxonomy},
+               {"tags" + sep + "_index.md", KindTaxonomyTerm},
+               {"tags" + sep + "tagA" + sep + "_index.md", KindTaxonomy},
+
+               // nn is configured as a language
+               {"_index.nn.md", KindHome},
+               {"about.nn.md", KindPage},
+               {"sectionA" + sep + "_index.nn.md", KindSection},
+               {"sectionA" + sep + "about.nn.md", KindPage},
+
+               // should NOT be categorized as KindHome
+               {"_indexNOT.md", KindPage},
+
+               // To be consistent with FileInfo.TranslationBaseName(),
+               // language codes not explicitly configured for the site
+               // are not treated as such. "fr" is not configured as
+               // a language in the test site, so ALL of the
+               // following should be KindPage
+               {"_index.fr.md", KindPage}, //not KindHome
+               {"about.fr.md", KindPage},
+               {"sectionA" + sep + "_index.fr.md", KindPage}, // KindSection
+               {"sectionA" + sep + "about.fr.md", KindPage},
+       }
+
+       for _, test := range tests {
+               s := newTestSite(t, "languages.nn.languageName", "Nynorsk")
+               taxonomies := make(map[string]string)
+               taxonomies["tag"] = "tags"
+               taxonomies["category"] = "categories"
+               s.Taxonomies = make(TaxonomyList)
+               for _, plural := range taxonomies {
+                       s.Taxonomies[plural] = make(Taxonomy)
+               }
+
+               p, _ := s.NewPage(test.file)
+               p.setValuesForKind(s)
+               if p.Kind != test.kind {
+                       t.Errorf("for %s expected p.Kind == %s, got %s", test.file, test.kind, p.Kind)
+               }
+       }
+}
+
 func TestDegenerateInvalidFrontMatterShortDelim(t *testing.T) {
        t.Parallel()
        var tests = []struct {