mirror of
https://github.com/miniflux/v2.git
synced 2025-06-27 16:36:00 +00:00
Add more unit tests for template functions
This commit is contained in:
parent
d79bab2997
commit
f244df6293
5 changed files with 129 additions and 122 deletions
|
@ -8,41 +8,87 @@ import (
|
|||
"testing"
|
||||
)
|
||||
|
||||
func TestTruncate(t *testing.T) {
|
||||
fm := funcMap{}
|
||||
if f, ok := fm.Map()["truncate"]; ok {
|
||||
if truncate := f.(func(str string, max int) string); ok {
|
||||
shortEnglishText := "Short text"
|
||||
shortUnicodeText := "Короткий текст"
|
||||
func TestDict(t *testing.T) {
|
||||
d, err := dict("k1", "v1", "k2", "v2")
|
||||
if err != nil {
|
||||
t.Fatalf(`The dict should be valid: %v`, err)
|
||||
}
|
||||
|
||||
// edge case
|
||||
if truncate(shortEnglishText, len(shortEnglishText)) != shortEnglishText {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
// real case
|
||||
if truncate(shortEnglishText, 25) != shortEnglishText {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
if truncate(shortUnicodeText, len(shortUnicodeText)) != shortUnicodeText {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
if truncate(shortUnicodeText, 25) != shortUnicodeText {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
|
||||
longEnglishText := "This is really pretty long English text"
|
||||
longRussianText := "Это реально очень длинный русский текст"
|
||||
|
||||
if truncate(longEnglishText, 25) != "This is really pretty lon…" {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
if truncate(longRussianText, 25) != "Это реально очень длинный…" {
|
||||
t.Fatal("Invalid truncation")
|
||||
}
|
||||
} else {
|
||||
t.Fatal("Type assetion for this func is failed, check func, maybe it was changed")
|
||||
if value, found := d["k1"]; found {
|
||||
if value != "v1" {
|
||||
t.Fatalf(`Unexpected value for k1: got %q`, value)
|
||||
}
|
||||
}
|
||||
|
||||
if value, found := d["k2"]; found {
|
||||
if value != "v2" {
|
||||
t.Fatalf(`Unexpected value for k2: got %q`, value)
|
||||
}
|
||||
} else {
|
||||
t.Fatal("There is no such function in this map, check key, maybe it was changed")
|
||||
}
|
||||
}
|
||||
|
||||
func TestDictWithInvalidNumberOfArguments(t *testing.T) {
|
||||
_, err := dict("k1")
|
||||
if err == nil {
|
||||
t.Fatal(`An error should be returned if the number of arguments are not even`)
|
||||
}
|
||||
}
|
||||
|
||||
func TestDictWithInvalidMap(t *testing.T) {
|
||||
_, err := dict(1, 2)
|
||||
if err == nil {
|
||||
t.Fatal(`An error should be returned if the dict keys are not string`)
|
||||
}
|
||||
}
|
||||
|
||||
func TestHasKey(t *testing.T) {
|
||||
input := map[string]string{"k": "v"}
|
||||
|
||||
if !hasKey(input, "k") {
|
||||
t.Fatal(`This key exists in the map and should returns true`)
|
||||
}
|
||||
|
||||
if hasKey(input, "missing") {
|
||||
t.Fatal(`This key doesn't exists in the given map and should returns false`)
|
||||
}
|
||||
}
|
||||
|
||||
func TestTruncateWithShortTexts(t *testing.T) {
|
||||
scenarios := []string{"Short text", "Короткий текст"}
|
||||
|
||||
for _, input := range scenarios {
|
||||
result := truncate(input, 25)
|
||||
if result != input {
|
||||
t.Fatalf(`Unexpected output, got %q instead of %q`, result, input)
|
||||
}
|
||||
|
||||
result = truncate(input, len(input))
|
||||
if result != input {
|
||||
t.Fatalf(`Unexpected output, got %q instead of %q`, result, input)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestTruncateWithLongTexts(t *testing.T) {
|
||||
scenarios := map[string]string{
|
||||
"This is a really pretty long English text": "This is a really pretty l…",
|
||||
"Это реально очень длинный русский текст": "Это реально очень длинный…",
|
||||
}
|
||||
|
||||
for input, expected := range scenarios {
|
||||
result := truncate(input, 25)
|
||||
if result != expected {
|
||||
t.Fatalf(`Unexpected output, got %q instead of %q`, result, expected)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestIsEmail(t *testing.T) {
|
||||
if !isEmail("user@domain.tld") {
|
||||
t.Fatal(`This email is valid and should returns true`)
|
||||
}
|
||||
|
||||
if isEmail("invalid") {
|
||||
t.Fatal(`This email is not valid and should returns false`)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue