update: move structs with test data into tests
This commit is contained in:
parent
dc03addc2c
commit
778301ed3c
72
slug_test.go
72
slug_test.go
@ -11,10 +11,11 @@ import (
|
|||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
|
|
||||||
var SlugMakeTests = []struct {
|
func TestSlugMake(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{"DOBROSLAWZYBORT", "dobroslawzybort"},
|
{"DOBROSLAWZYBORT", "dobroslawzybort"},
|
||||||
{"Dobroslaw Zybort", "dobroslaw-zybort"},
|
{"Dobroslaw Zybort", "dobroslaw-zybort"},
|
||||||
{" Dobroslaw Zybort ?", "dobroslaw-zybort"},
|
{" Dobroslaw Zybort ?", "dobroslaw-zybort"},
|
||||||
@ -46,10 +47,9 @@ var SlugMakeTests = []struct {
|
|||||||
{"\"C'est déjà l’été.\"", "cest-deja-lete"},
|
{"\"C'est déjà l’été.\"", "cest-deja-lete"},
|
||||||
{"jaja---lol-méméméoo--a", "jaja-lol-mememeoo-a"},
|
{"jaja---lol-méméméoo--a", "jaja-lol-mememeoo-a"},
|
||||||
{"影師", "ying-shi"},
|
{"影師", "ying-shi"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMake(t *testing.T) {
|
for index, st := range testCases {
|
||||||
for index, st := range SlugMakeTests {
|
|
||||||
got := Make(st.in)
|
got := Make(st.in)
|
||||||
if got != st.want {
|
if got != st.want {
|
||||||
t.Errorf(
|
t.Errorf(
|
||||||
@ -59,20 +59,20 @@ func TestSlugMake(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var SlugMakeLangTests = []struct {
|
func TestSlugMakeLang(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
lang string
|
lang string
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{"en", "This & that", "this-and-that"},
|
{"en", "This & that", "this-and-that"},
|
||||||
{"de", "This & that", "this-und-that"},
|
{"de", "This & that", "this-und-that"},
|
||||||
{"pl", "This & that", "this-i-that"},
|
{"pl", "This & that", "this-i-that"},
|
||||||
{"es", "This & that", "this-y-that"},
|
{"es", "This & that", "this-y-that"},
|
||||||
{"test", "This & that", "this-and-that"}, // unknown lang, fallback to "en"
|
{"test", "This & that", "this-and-that"}, // unknown lang, fallback to "en"
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMakeLang(t *testing.T) {
|
for index, smlt := range testCases {
|
||||||
for index, smlt := range SlugMakeLangTests {
|
|
||||||
got := MakeLang(smlt.in, smlt.lang)
|
got := MakeLang(smlt.in, smlt.lang)
|
||||||
if got != smlt.want {
|
if got != smlt.want {
|
||||||
t.Errorf(
|
t.Errorf(
|
||||||
@ -82,19 +82,19 @@ func TestSlugMakeLang(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var SlugMakeUserSubstituteTests = []struct {
|
func TestSlugMakeUserSubstituteLang(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
cSub map[string]string
|
cSub map[string]string
|
||||||
lang string
|
lang string
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{map[string]string{"'": " "}, "en", "That's great", "that-s-great"},
|
{map[string]string{"'": " "}, "en", "That's great", "that-s-great"},
|
||||||
{map[string]string{"&": "or"}, "en", "This & that", "this-or-that"}, // by default "&" => "and"
|
{map[string]string{"&": "or"}, "en", "This & that", "this-or-that"}, // by default "&" => "and"
|
||||||
{map[string]string{"&": "or"}, "de", "This & that", "this-or-that"}, // by default "&" => "und"
|
{map[string]string{"&": "or"}, "de", "This & that", "this-or-that"}, // by default "&" => "und"
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMakeUserSubstituteLang(t *testing.T) {
|
for index, smust := range testCases {
|
||||||
for index, smust := range SlugMakeUserSubstituteTests {
|
|
||||||
CustomSub = smust.cSub
|
CustomSub = smust.cSub
|
||||||
got := MakeLang(smust.in, smust.lang)
|
got := MakeLang(smust.in, smust.lang)
|
||||||
if got != smust.want {
|
if got != smust.want {
|
||||||
@ -107,19 +107,19 @@ func TestSlugMakeUserSubstituteLang(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Always substitute runes first
|
func TestSlugMakeSubstituteOrderLang(t *testing.T) {
|
||||||
var SlugMakeSubstituteOrderTests = []struct {
|
// Always substitute runes first
|
||||||
|
var testCases = []struct {
|
||||||
rSub map[rune]string
|
rSub map[rune]string
|
||||||
sSub map[string]string
|
sSub map[string]string
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{map[rune]string{'o': "left"}, map[string]string{"o": "right"}, "o o", "left-left"},
|
{map[rune]string{'o': "left"}, map[string]string{"o": "right"}, "o o", "left-left"},
|
||||||
{map[rune]string{'&': "down"}, map[string]string{"&": "up"}, "&", "down"},
|
{map[rune]string{'&': "down"}, map[string]string{"&": "up"}, "&", "down"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMakeSubstituteOrderLang(t *testing.T) {
|
for index, smsot := range testCases {
|
||||||
for index, smsot := range SlugMakeSubstituteOrderTests {
|
|
||||||
CustomRuneSub = smsot.rSub
|
CustomRuneSub = smsot.rSub
|
||||||
CustomSub = smsot.sSub
|
CustomSub = smsot.sSub
|
||||||
got := Make(smsot.in)
|
got := Make(smsot.in)
|
||||||
@ -133,17 +133,17 @@ func TestSlugMakeSubstituteOrderLang(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var SlugSubstituteTests = []struct {
|
func TestSubstituteLang(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
cSub map[string]string
|
cSub map[string]string
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{map[string]string{"o": "no"}, "o o o", "no no no"},
|
{map[string]string{"o": "no"}, "o o o", "no no no"},
|
||||||
{map[string]string{"'": " "}, "That's great", "That s great"},
|
{map[string]string{"'": " "}, "That's great", "That s great"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSubstituteLang(t *testing.T) {
|
for index, sst := range testCases {
|
||||||
for index, sst := range SlugSubstituteTests {
|
|
||||||
got := Substitute(sst.in, sst.cSub)
|
got := Substitute(sst.in, sst.cSub)
|
||||||
if got != sst.want {
|
if got != sst.want {
|
||||||
t.Errorf(
|
t.Errorf(
|
||||||
@ -153,17 +153,17 @@ func TestSubstituteLang(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var SlugSubstituteRuneTests = []struct {
|
func TestSubstituteRuneLang(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
cSub map[rune]string
|
cSub map[rune]string
|
||||||
in string
|
in string
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{map[rune]string{'o': "no"}, "o o o", "no no no"},
|
{map[rune]string{'o': "no"}, "o o o", "no no no"},
|
||||||
{map[rune]string{'\'': " "}, "That's great", "That s great"},
|
{map[rune]string{'\'': " "}, "That's great", "That s great"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSubstituteRuneLang(t *testing.T) {
|
for index, ssrt := range testCases {
|
||||||
for index, ssrt := range SlugSubstituteRuneTests {
|
|
||||||
got := SubstituteRune(ssrt.in, ssrt.cSub)
|
got := SubstituteRune(ssrt.in, ssrt.cSub)
|
||||||
if got != ssrt.want {
|
if got != ssrt.want {
|
||||||
t.Errorf(
|
t.Errorf(
|
||||||
@ -173,21 +173,21 @@ func TestSubstituteRuneLang(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var SlugMakeSmartTruncateTests = []struct {
|
func TestSlugMakeSmartTruncate(t *testing.T) {
|
||||||
|
var testCases = []struct {
|
||||||
in string
|
in string
|
||||||
maxLength int
|
maxLength int
|
||||||
want string
|
want string
|
||||||
}{
|
}{
|
||||||
{"DOBROSLAWZYBORT", 100, "dobroslawzybort"},
|
{"DOBROSLAWZYBORT", 100, "dobroslawzybort"},
|
||||||
{"Dobroslaw Zybort", 100, "dobroslaw-zybort"},
|
{"Dobroslaw Zybort", 100, "dobroslaw-zybort"},
|
||||||
{"Dobroslaw Zybort", 12, "dobroslaw"},
|
{"Dobroslaw Zybort", 12, "dobroslaw"},
|
||||||
{" Dobroslaw Zybort ?", 12, "dobroslaw"},
|
{" Dobroslaw Zybort ?", 12, "dobroslaw"},
|
||||||
{"Ala ma 6 kotów.", 10, "ala-ma-6"},
|
{"Ala ma 6 kotów.", 10, "ala-ma-6"},
|
||||||
{"Dobrosław Żybort", 5, "dobro"},
|
{"Dobrosław Żybort", 5, "dobro"},
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMakeSmartTruncate(t *testing.T) {
|
for index, smstt := range testCases {
|
||||||
for index, smstt := range SlugMakeSmartTruncateTests {
|
|
||||||
MaxLength = smstt.maxLength
|
MaxLength = smstt.maxLength
|
||||||
got := Make(smstt.in)
|
got := Make(smstt.in)
|
||||||
if got != smstt.want {
|
if got != smstt.want {
|
||||||
|
Loading…
Reference in New Issue
Block a user