Skip to content
/ hugo Public
forked from gohugoio/hugo

Commit

Permalink
Fix validation of Page Kind in cascade target map
Browse files Browse the repository at this point in the history
  • Loading branch information
jmooring committed Jan 30, 2022
1 parent ef7d14a commit f8d0446
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 5 deletions.
16 changes: 12 additions & 4 deletions resources/page/page_matcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,10 @@ import (
"path/filepath"
"strings"

"github.com/pkg/errors"

"github.com/gohugoio/hugo/common/maps"
"github.com/gohugoio/hugo/hugofs/glob"
"github.com/mitchellh/mapstructure"
"github.com/pkg/errors"
)

// A PageMatcher can be used to match a Page with Glob patterns.
Expand Down Expand Up @@ -114,8 +113,17 @@ func DecodePageMatcher(m interface{}, v *PageMatcher) error {

v.Kind = strings.ToLower(v.Kind)
if v.Kind != "" {
if _, found := kindMap[v.Kind]; !found {
return errors.Errorf("%q is not a valid Page Kind", v.Kind)
g, _ := glob.GetGlob(v.Kind)
// TODO figure out what to with e_err above, if anything
found := false
for _, k := range kindMap {
if g.Match(k) {
found = true
break
}
}
if !found {
return errors.Errorf("%q did not match a valid Page Kind", v.Kind)
}
}

Expand Down
7 changes: 6 additions & 1 deletion resources/page/page_matcher_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,12 @@ func TestPageMatcher(t *testing.T) {

c.Run("Decode", func(c *qt.C) {
var v PageMatcher
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "foo"}, &v), qt.Not((qt.IsNil)))
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "foo"}, &v), qt.Not(qt.IsNil))
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{foo,bar}"}, &v), qt.Not(qt.IsNil))
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "taxonomy"}, &v), qt.IsNil)
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{taxonomy,foo}"}, &v), qt.IsNil)
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "{taxonomy,term}"}, &v), qt.IsNil)
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "*"}, &v), qt.IsNil)
c.Assert(DecodePageMatcher(map[string]interface{}{"kind": "home", "path": filepath.FromSlash("/a/b/**")}, &v), qt.IsNil)
c.Assert(v, qt.Equals, PageMatcher{Kind: "home", Path: "/a/b/**"})
})
Expand Down

0 comments on commit f8d0446

Please # to comment.