From 0dd06bdac008aa81ec2e8f29ad8110dac0227011 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bj=C3=B8rn=20Erik=20Pedersen?= Date: Tue, 14 Aug 2018 18:11:36 +0200 Subject: [PATCH] hugolib: Fix Related when called from shortcode Fixes #5071 --- hugolib/shortcode_test.go | 11 +++++++++++ hugolib/site_sections.go | 15 ++++++++------- 2 files changed, 19 insertions(+), 7 deletions(-) diff --git a/hugolib/shortcode_test.go b/hugolib/shortcode_test.go index f4935c6e..d57dca82 100644 --- a/hugolib/shortcode_test.go +++ b/hugolib/shortcode_test.go @@ -150,6 +150,17 @@ func TestPositionalParamIndexOutOfBounds(t *testing.T) { CheckShortCodeMatch(t, "{{< video 47238zzb >}}", "Playing Video Missing", wt) } +// #5071 +func TestShortcodeRelated(t *testing.T) { + t.Parallel() + wt := func(tem tpl.TemplateHandler) error { + tem.AddTemplate("_internal/shortcodes/a.html", `{{ len (.Site.RegularPages.Related .Page) }}`) + return nil + } + + CheckShortCodeMatch(t, "{{< a >}}", "0", wt) +} + // some repro issues for panics in Go Fuzz testing func TestNamedParamSC(t *testing.T) { diff --git a/hugolib/site_sections.go b/hugolib/site_sections.go index 2a92a342..15b96e1a 100644 --- a/hugolib/site_sections.go +++ b/hugolib/site_sections.go @@ -145,15 +145,16 @@ func (p *Page) Eq(other interface{}) bool { } func unwrapPage(in interface{}) (*Page, error) { - if po, ok := in.(*PageOutput); ok { - in = po.Page - } - - pp, ok := in.(*Page) - if !ok { + switch v := in.(type) { + case *Page: + return v, nil + case *PageOutput: + return v.Page, nil + case *PageWithoutContent: + return v.Page, nil + default: return nil, fmt.Errorf("%T not supported", in) } - return pp, nil } // Sections returns this section's subsections, if any. -- 2.30.2