package hexonet import ( "strings" "testing" ) var txtData = []struct { decoded []string encoded string }{ {[]string{`simple`}, `"simple"`}, {[]string{`changed`}, `"changed"`}, {[]string{`with spaces`}, `"with spaces"`}, {[]string{`with whitespace`}, `"with whitespace"`}, {[]string{"one", "two"}, `"one" "two"`}, {[]string{"eh", "bee", "cee"}, `"eh" "bee" "cee"`}, {[]string{"o\"ne", "tw\"o"}, `"o\"ne" "tw\"o"`}, {[]string{"dimple"}, `"dimple"`}, {[]string{"fun", "two"}, `"fun" "two"`}, {[]string{"eh", "bzz", "cee"}, `"eh" "bzz" "cee"`}, } func TestEncodeTxt(t *testing.T) { // Test encoded the lists of strings into a string: for i, test := range txtData { enc := encodeTxt(test.decoded) if enc != test.encoded { t.Errorf("%v: txt\n data: []string{%v}\nexpected: %q\n got: %q", i, "`"+strings.Join(test.decoded, "`, `")+"`", test.encoded, enc) } } } func TestDecodeTxt(t *testing.T) { // Test decoded a string into the list of strings: for i, test := range txtData { data := test.encoded got := decodeTxt(data) wanted := test.decoded if len(got) != len(wanted) { t.Errorf("%v: txt\n decode: %v\nexpected: %q\n got: %q\n", i, data, strings.Join(wanted, "`, `"), strings.Join(got, "`, `")) } else { for j := range got { if got[j] != wanted[j] { t.Errorf("%v: txt\n decode: %v\nexpected: %q\n got: %q\n", i, data, strings.Join(wanted, "`, `"), strings.Join(got, "`, `")) } } } } }