168 lines
4.1 KiB
Go
168 lines
4.1 KiB
Go
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)
|
|
}
|