Make chomp return the type it receives
authorVictor Kropp <victor.kropp@gmail.com>
Fri, 13 Oct 2017 20:57:52 +0000 (22:57 +0200)
committerBjørn Erik Pedersen <bjorn.erik.pedersen@gmail.com>
Sat, 16 Dec 2017 22:59:36 +0000 (23:59 +0100)
fixes #2187

tpl/strings/strings.go
tpl/strings/strings_test.go

index f8acbfe2b22924b0d7fdac2e558c3a304db64139..6d423391fe67f5638842e5bd31a63396239c20a0 100644 (file)
@@ -78,13 +78,20 @@ func (ns *Namespace) CountWords(s interface{}) (int, error) {
 }
 
 // Chomp returns a copy of s with all trailing newline characters removed.
-func (ns *Namespace) Chomp(s interface{}) (template.HTML, error) {
+func (ns *Namespace) Chomp(s interface{}) (interface{}, error) {
        ss, err := cast.ToStringE(s)
        if err != nil {
                return "", err
        }
 
-       return template.HTML(_strings.TrimRight(ss, "\r\n")), nil
+       res := _strings.TrimRight(ss, "\r\n")
+       switch s.(type) {
+       case template.HTML:
+               return template.HTML(res), nil
+       default:
+               return res, nil
+       }
+
 }
 
 // Contains reports whether substr is in s.
index 3ab73392c0fea582ecf697194acdb60037a2c65d..91e71fd012e550b9640c0da559f61aa7e2b96ebc 100644 (file)
@@ -19,6 +19,7 @@ import (
        "testing"
 
        "github.com/gohugoio/hugo/deps"
+       "github.com/spf13/cast"
        "github.com/spf13/viper"
        "github.com/stretchr/testify/assert"
        "github.com/stretchr/testify/require"
@@ -35,12 +36,12 @@ func TestChomp(t *testing.T) {
                s      interface{}
                expect interface{}
        }{
-               {"\n a\n", template.HTML("\n a")},
-               {"\n a\n\n", template.HTML("\n a")},
-               {"\n a\r\n", template.HTML("\n a")},
-               {"\n a\n\r\n", template.HTML("\n a")},
-               {"\n a\r\r", template.HTML("\n a")},
-               {"\n a\r", template.HTML("\n a")},
+               {"\n a\n", "\n a"},
+               {"\n a\n\n", "\n a"},
+               {"\n a\r\n", "\n a"},
+               {"\n a\n\r\n", "\n a"},
+               {"\n a\r\r", "\n a"},
+               {"\n a\r", "\n a"},
                // errors
                {tstNoStringer{}, false},
        } {
@@ -55,6 +56,11 @@ func TestChomp(t *testing.T) {
 
                require.NoError(t, err, errMsg)
                assert.Equal(t, test.expect, result, errMsg)
+
+               // repeat the check with template.HTML input
+               result, err = ns.Chomp(template.HTML(cast.ToString(test.s)))
+               require.NoError(t, err, errMsg)
+               assert.Equal(t, template.HTML(cast.ToString(test.expect)), result, errMsg)
        }
 }