2016-02-07 07:55:42 +08:00
|
|
|
package eval
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2016-02-08 03:39:03 +08:00
|
|
|
"reflect"
|
2016-02-07 07:55:42 +08:00
|
|
|
"testing"
|
2016-02-08 03:39:03 +08:00
|
|
|
|
|
|
|
"github.com/elves/elvish/glob"
|
2016-02-07 07:55:42 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var reprTests = []struct {
|
|
|
|
v Value
|
|
|
|
want string
|
|
|
|
}{
|
|
|
|
{String("233"), "233"},
|
|
|
|
{String("a\nb"), "'a\nb'"},
|
|
|
|
{String("foo bar"), "'foo bar'"},
|
|
|
|
{String("a\x00b"), `"a\x00b"`},
|
|
|
|
{Bool(true), "$true"},
|
|
|
|
{Bool(false), "$false"},
|
|
|
|
{Error{nil}, "$ok"},
|
|
|
|
{Error{errors.New("foo bar")}, "?(error 'foo bar')"},
|
|
|
|
{Error{multiError{[]Error{{nil}, {errors.New("lorem")}}}},
|
|
|
|
"?(multi-error $ok ?(error lorem))"},
|
|
|
|
{Error{Return}, "?(return)"},
|
|
|
|
{List{&[]Value{}}, "[]"},
|
|
|
|
{List{&[]Value{String("bash"), Bool(false)}}, "[bash $false]"},
|
|
|
|
{Map{&map[Value]Value{}}, "[&]"},
|
|
|
|
{Map{&map[Value]Value{Error{nil}: String("elvish")}}, "[&$ok elvish]"},
|
|
|
|
// TODO: test maps of more elements
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestRepr(t *testing.T) {
|
|
|
|
for _, test := range reprTests {
|
|
|
|
repr := test.v.Repr()
|
|
|
|
if repr != test.want {
|
|
|
|
t.Errorf("Repr = %s, want %s", repr, test.want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-02-08 03:39:03 +08:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|