diff --git a/hugolib/page_frontmatter.go b/hugolib/page_frontmatter.go index c88d482a10f..c5f50f7ef5e 100644 --- a/hugolib/page_frontmatter.go +++ b/hugolib/page_frontmatter.go @@ -108,6 +108,11 @@ func (f frontmatterHandler) handleDates(d frontMatterDescriptor) error { d.dates.Lastmod = d.dates.Date } + // TODO(bep) date decide vs https://github.com/gohugoio/hugo/issues/3977 + if d.dates.PublishDate.IsZero() { + //d.dates.PublishDate = d.dates.Date + } + if d.dates.Date.IsZero() { d.dates.Date = d.dates.Lastmod } diff --git a/hugolib/page_frontmatter_test.go b/hugolib/page_frontmatter_test.go index a0ac7e65c03..46b29da6b7d 100644 --- a/hugolib/page_frontmatter_test.go +++ b/hugolib/page_frontmatter_test.go @@ -93,15 +93,20 @@ func doTestFrontMatterDates(t *testing.T, defaultDateSetting string) { // See http://www.imdb.com/title/tt0133093/ for _, lastModKey := range []string{"lastmod", "modified"} { + testDate = testDate.Add(24 * time.Hour) + t.Log(lastModKey, testDate) for _, lastModDate := range []time.Time{testDate, sentinel} { for _, dateKey := range []string{"date"} { testDate = testDate.Add(24 * time.Hour) + t.Log(dateKey, testDate) for _, dateDate := range []time.Time{testDate, sentinel} { for _, pubDateKey := range []string{"publishdate", "pubdate", "published"} { testDate = testDate.Add(24 * time.Hour) + t.Log(pubDateKey, testDate) for _, pubDateDate := range []time.Time{testDate, sentinel} { for _, expiryDateKey := range []string{"expirydate", "unpublishdate"} { testDate = testDate.Add(24 * time.Hour) + t.Log(expiryDateKey, testDate) for _, expiryDateDate := range []time.Time{testDate, sentinel} { d := frontMatterDescriptor{ frontmatter: make(map[string]interface{}), @@ -115,12 +120,6 @@ func doTestFrontMatterDates(t *testing.T, defaultDateSetting string) { expLastMod, expDate, expPubDate, expExiryDate = zero, zero, zero, zero ) - if lastModDate != sentinel { - d.frontmatter[lastModKey] = lastModDate - expLastMod = lastModDate - expDate = lastModDate - } - if dateDate != sentinel { d.frontmatter[dateKey] = dateDate expDate = dateDate @@ -129,6 +128,18 @@ func doTestFrontMatterDates(t *testing.T, defaultDateSetting string) { if pubDateDate != sentinel { d.frontmatter[pubDateKey] = pubDateDate expPubDate = pubDateDate + if expDate.IsZero() { + expDate = expPubDate + } + } + + if lastModDate != sentinel { + d.frontmatter[lastModKey] = lastModDate + expLastMod = lastModDate + + if expDate.IsZero() { + expDate = expPubDate + } } if expiryDateDate != sentinel { @@ -173,8 +184,6 @@ func assertFrontMatterDate(assert *require.Assertions, d frontMatterDescriptor, if expected != param { assert.Fail("Params check failed", "[%s] Expected:\n%q\nGot:\n%q", dateField, expected, param) } - assert.Equal(expected, param) - } }