package main
import (
"reflect"
"testing"
)
func TestTruncateStop(t *testing.T) {
tests := []struct {
name string
pieces []string
stop string
expected []string
expectedTrunc bool
}{
{
name: "Single word",
pieces: []string{"hello", "world"},
stop: "world",
expected: []string{"hello"},
expectedTrunc: false,
},
name: "Partial",
pieces: []string{"hello", "wor"},
stop: "or",
expected: []string{"hello", "w"},
expectedTrunc: true,
name: "Suffix",
pieces: []string{"Hello", " there", "!"},
stop: "!",
expected: []string{"Hello", " there"},
name: "Suffix partial",
pieces: []string{"Hello", " the", "re!"},
stop: "there!",
expected: []string{"Hello", " "},
name: "Middle",
pieces: []string{"hello", " wor"},
stop: "llo w",
expected: []string{"he"},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
result, resultTrunc := truncateStop(tt.pieces, tt.stop)
if !reflect.DeepEqual(result, tt.expected) || resultTrunc != tt.expectedTrunc {
t.Errorf("truncateStop(%v, %s): have %v (%v); want %v (%v)", tt.pieces, tt.stop, result, resultTrunc, tt.expected, tt.expectedTrunc)
})
func TestIncompleteUnicode(t *testing.T) {
input string
expected bool
name: "Basic",
input: "hi",
expected: false,
name: "Two byte",
input: "hi" + string([]byte{0xc2, 0xa3}),
name: "Two byte - missing last",
input: "hi" + string([]byte{0xc2}),
expected: true,
name: "Three byte",
input: "hi" + string([]byte{0xe0, 0xA0, 0x80}),
name: "Three byte - missing last",
input: "hi" + string([]byte{0xe0, 0xA0}),
name: "Three byte - missing last 2",
input: "hi" + string([]byte{0xe0}),
name: "Four byte",
input: "hi" + string([]byte{0xf0, 0x92, 0x8a, 0xb7}),
name: "Four byte - missing last",
input: "hi" + string([]byte{0xf0, 0x92, 0x8a}),
name: "Four byte - missing last 2",
input: "hi" + string([]byte{0xf0, 0x92}),
name: "Four byte - missing last 3",
input: "hi" + string([]byte{0xf0}),
result := incompleteUnicode(tt.input)
if result != tt.expected {
t.Errorf("incompleteUnicode(%s): have %v; want %v", tt.input, result, tt.expected)