elvish/eval/value_test.go
Qi Xiao 99921ea222 Get rid of types.String.
Elvish strings are now simply Go strings. \o/ This addresses #573.
2018-01-25 22:50:42 +00:00

64 lines
1.7 KiB
Go

package eval
import (
"errors"
"reflect"
"testing"
"github.com/elves/elvish/eval/types"
"github.com/elves/elvish/glob"
)
var reprTests = []struct {
v types.Value
want string
}{
{"233", "233"},
{"a\nb", `"a\nb"`},
{"foo bar", "'foo bar'"},
{"a\x00b", `"a\x00b"`},
{types.Bool(true), "$true"},
{types.Bool(false), "$false"},
{&Exception{nil, nil}, "$ok"},
{&Exception{errors.New("foo bar"), nil}, "?(fail 'foo bar')"},
{&Exception{
PipelineError{[]*Exception{{nil, nil}, {errors.New("lorem"), nil}}}, nil},
"?(multi-error $ok ?(fail lorem))"},
{&Exception{Return, nil}, "?(return)"},
{types.EmptyList, "[]"},
{types.MakeList("bash", types.Bool(false)), "[bash $false]"},
{types.MakeMap(map[types.Value]types.Value{}), "[&]"},
{types.MakeMap(map[types.Value]types.Value{&Exception{nil, nil}: "elvish"}), "[&$ok=elvish]"},
// TODO: test maps of more elements
}
func TestRepr(t *testing.T) {
for _, test := range reprTests {
repr := types.Repr(test.v, types.NoPretty)
if repr != test.want {
t.Errorf("Repr = %s, want %s", repr, test.want)
}
}
}
var stringToSegmentsTests = []struct {
s string
want []glob.Segment
}{
{"", []glob.Segment{}},
{"a", []glob.Segment{glob.Literal{"a"}}},
{"/a", []glob.Segment{glob.Slash{}, glob.Literal{"a"}}},
{"a/", []glob.Segment{glob.Literal{"a"}, glob.Slash{}}},
{"/a/", []glob.Segment{glob.Slash{}, glob.Literal{"a"}, glob.Slash{}}},
{"a//b", []glob.Segment{glob.Literal{"a"}, glob.Slash{}, glob.Literal{"b"}}},
}
func TestStringToSegments(t *testing.T) {
for _, tc := range stringToSegmentsTests {
segs := stringToSegments(tc.s)
if !reflect.DeepEqual(segs, tc.want) {
t.Errorf("stringToSegments(%q) => %v, want %v", tc.s, segs, tc.want)
}
}
}