package i2c import ( "bytes" "errors" "testing" "gobot.io/x/gobot" "gobot.io/x/gobot/gobottest" ) var _ gobot.Driver = (*LIDARLiteDriver)(nil) // --------- HELPERS func initTestLIDARLiteDriver() (driver *LIDARLiteDriver) { driver, _ = initTestLIDARLiteDriverWithStubbedAdaptor() return } func initTestLIDARLiteDriverWithStubbedAdaptor() (*LIDARLiteDriver, *i2cTestAdaptor) { adaptor := newI2cTestAdaptor() return NewLIDARLiteDriver(adaptor), adaptor } // --------- TESTS func TestNewLIDARLiteDriver(t *testing.T) { // Does it return a pointer to an instance of LIDARLiteDriver? var bm interface{} = NewLIDARLiteDriver(newI2cTestAdaptor()) _, ok := bm.(*LIDARLiteDriver) if !ok { t.Errorf("NewLIDARLiteDriver() should have returned a *LIDARLiteDriver") } b := NewLIDARLiteDriver(newI2cTestAdaptor()) gobottest.Refute(t, b.Connection(), nil) } // Methods func TestLIDARLiteDriverStart(t *testing.T) { hmc, _ := initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) } func TestLIDARLiteStartConnectError(t *testing.T) { d, adaptor := initTestLIDARLiteDriverWithStubbedAdaptor() adaptor.Testi2cConnectErr(true) gobottest.Assert(t, d.Start(), errors.New("Invalid i2c connection")) } func TestLIDARLiteDriverHalt(t *testing.T) { hmc := initTestLIDARLiteDriver() gobottest.Assert(t, hmc.Halt(), nil) } func TestLIDARLiteDriverDistance(t *testing.T) { // when everything is happy hmc, adaptor := initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) first := true adaptor.i2cReadImpl = func(b []byte) (int, error) { if first { first = false copy(b, []byte{99}) return 1, nil } copy(b, []byte{1}) return 1, nil } distance, err := hmc.Distance() gobottest.Assert(t, err, nil) gobottest.Assert(t, distance, int(25345)) // when insufficient bytes have been read hmc, adaptor = initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) adaptor.i2cReadImpl = func([]byte) (int, error) { return 0, nil } distance, err = hmc.Distance() gobottest.Assert(t, distance, int(0)) gobottest.Assert(t, err, ErrNotEnoughBytes) // when read error hmc, adaptor = initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) adaptor.i2cReadImpl = func([]byte) (int, error) { return 0, errors.New("read error") } distance, err = hmc.Distance() gobottest.Assert(t, distance, int(0)) gobottest.Assert(t, err, errors.New("read error")) } func TestLIDARLiteDriverDistanceError1(t *testing.T) { hmc, adaptor := initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) adaptor.i2cWriteImpl = func([]byte) (int, error) { return 0, errors.New("write error") } distance, err := hmc.Distance() gobottest.Assert(t, distance, int(0)) gobottest.Assert(t, err, errors.New("write error")) } func TestLIDARLiteDriverDistanceError2(t *testing.T) { hmc, adaptor := initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) adaptor.i2cWriteImpl = func(b []byte) (int, error) { if b[0] == 0x0f { return 0, errors.New("write error") } return len(b), nil } distance, err := hmc.Distance() gobottest.Assert(t, distance, int(0)) gobottest.Assert(t, err, errors.New("write error")) } func TestLIDARLiteDriverDistanceError3(t *testing.T) { hmc, adaptor := initTestLIDARLiteDriverWithStubbedAdaptor() gobottest.Assert(t, hmc.Start(), nil) adaptor.i2cWriteImpl = func(b []byte) (int, error) { if b[0] == 0x10 { return 0, errors.New("write error") } return len(b), nil } adaptor.i2cReadImpl = func(b []byte) (int, error) { buf := new(bytes.Buffer) buf.Write([]byte{0x03}) copy(b, buf.Bytes()) return buf.Len(), nil } distance, err := hmc.Distance() gobottest.Assert(t, distance, int(0)) gobottest.Assert(t, err, errors.New("write error")) } func TestLIDARLiteDriverSetName(t *testing.T) { l := initTestLIDARLiteDriver() l.SetName("TESTME") gobottest.Assert(t, l.Name(), "TESTME") } func TestLIDARLiteDriverOptions(t *testing.T) { l := NewLIDARLiteDriver(newI2cTestAdaptor(), WithBus(2)) gobottest.Assert(t, l.GetBusOrDefault(1), 2) }