diff options
author | Matthias Loibl <mail@matthiasloibl.com> | 2016-11-07 21:27:14 +0100 |
---|---|---|
committer | Matthias Loibl <mail@matthiasloibl.com> | 2016-11-07 23:31:39 +0100 |
commit | 030ba2894f3e9f9442b4bbf83fec09bda1ca88c5 (patch) | |
tree | 4e186189b1062603887284d4cae20b6c166b8ebe /modules/base | |
parent | f81711f40d46208917742b871c41fe74a4b214c1 (diff) | |
download | gitea-030ba2894f3e9f9442b4bbf83fec09bda1ca88c5.tar.gz gitea-030ba2894f3e9f9442b4bbf83fec09bda1ca88c5.zip |
Add tests for EllipsisString() and fix bug if param length < 3
Diffstat (limited to 'modules/base')
-rw-r--r-- | modules/base/tool.go | 5 | ||||
-rw-r--r-- | modules/base/tool_test.go | 16 |
2 files changed, 16 insertions, 5 deletions
diff --git a/modules/base/tool.go b/modules/base/tool.go index ff072f857f..9177cfe193 100644 --- a/modules/base/tool.go +++ b/modules/base/tool.go @@ -462,7 +462,10 @@ func Subtract(left interface{}, right interface{}) interface{} { // EllipsisString returns a truncated short string, // it appends '...' in the end of the length of string is too large. func EllipsisString(str string, length int) string { - if len(str) < length { + if length <= 3 { + return "..." + } + if len(str) <= length { return str } return str[:length-3] + "..." diff --git a/modules/base/tool_test.go b/modules/base/tool_test.go index bc46a2a883..b29c8ea717 100644 --- a/modules/base/tool_test.go +++ b/modules/base/tool_test.go @@ -68,14 +68,11 @@ func TestAvatarLink(t *testing.T) { ) } -// TODO: AvatarLink() // TODO: computeTimeDiff() // TODO: TimeSincePro() // TODO: timeSince() // TODO: RawTimeSince() // TODO: TimeSince() -// TODO: logn() -// TODO: humanateBytes() func TestFileSize(t *testing.T) { var size int64 @@ -96,7 +93,18 @@ func TestFileSize(t *testing.T) { } // TODO: Subtract() -// TODO: EllipsisString() + +func TestEllipsisString(t *testing.T) { + assert.Equal(t, "...", EllipsisString("foobar", 0)) + assert.Equal(t, "...", EllipsisString("foobar", 1)) + assert.Equal(t, "...", EllipsisString("foobar", 2)) + assert.Equal(t, "...", EllipsisString("foobar", 3)) + assert.Equal(t, "f...", EllipsisString("foobar", 4)) + assert.Equal(t, "fo...", EllipsisString("foobar", 5)) + assert.Equal(t, "foobar", EllipsisString("foobar", 6)) + assert.Equal(t, "foobar", EllipsisString("foobar", 10)) +} + // TODO: TruncateString() // TODO: StringsToInt64s() // TODO: Int64sToStrings() |