elvish/pkg/eval/vals/concat_test.go

51 lines
1.4 KiB
Go

package vals
import (
"errors"
"testing"
. "src.elv.sh/pkg/tt"
)
// An implementation for Concatter that accepts strings, returns a special
// error when rhs is a float64, and returns ErrConcatNotImplemented when rhs is
// of other types.
type concatter struct{}
func (concatter) Concat(rhs interface{}) (interface{}, error) {
switch rhs := rhs.(type) {
case string:
return "concatter " + rhs, nil
case float64:
return nil, errors.New("float64 is bad")
default:
return nil, ErrConcatNotImplemented
}
}
// An implementation of RConcatter that accepts all types.
type rconcatter struct{}
func (rconcatter) RConcat(lhs interface{}) (interface{}, error) {
return "rconcatter", nil
}
func TestConcat(t *testing.T) {
Test(t, Fn("Concat", Concat), Table{
Args("foo", "bar").Rets("foobar", nil),
Args("foo", int64(2)).Rets("foo2", nil),
Args(int64(2), "foo").Rets("2foo", nil),
// LHS implements Concatter and succeeds
Args(concatter{}, "bar").Rets("concatter bar", nil),
// LHS implements Concatter but returns ErrConcatNotImplemented; RHS
// does not implement RConcatter
Args(concatter{}, 12).Rets(nil, cannotConcat{"!!vals.concatter", "!!int"}),
// LHS implements Concatter but returns another error
Args(concatter{}, 12.0).Rets(nil, errors.New("float64 is bad")),
// LHS does not implement Concatter but RHS implements RConcatter
Args(12, rconcatter{}).Rets("rconcatter", nil),
})
}