2016-09-01 18:17:43 +08:00
|
|
|
package gpio
|
|
|
|
|
|
|
|
import (
|
2016-11-06 11:14:30 +08:00
|
|
|
"errors"
|
|
|
|
"reflect"
|
|
|
|
"sync/atomic"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2016-12-08 20:24:03 +08:00
|
|
|
"gobot.io/x/gobot"
|
|
|
|
"gobot.io/x/gobot/gobottest"
|
2016-09-01 18:17:43 +08:00
|
|
|
)
|
|
|
|
|
2016-11-06 11:14:30 +08:00
|
|
|
type DriverAndPinner interface {
|
|
|
|
gobot.Driver
|
|
|
|
gobot.Pinner
|
|
|
|
}
|
|
|
|
|
|
|
|
type DriverAndEventer interface {
|
|
|
|
gobot.Driver
|
|
|
|
gobot.Eventer
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDriverDefaults(t *testing.T) {
|
|
|
|
testAdaptor := newGpioTestAdaptor()
|
|
|
|
pin := "456"
|
|
|
|
|
|
|
|
drivers := []DriverAndPinner{
|
|
|
|
NewGroveTouchDriver(testAdaptor, pin),
|
|
|
|
NewGroveButtonDriver(testAdaptor, pin),
|
|
|
|
NewGroveBuzzerDriver(testAdaptor, pin),
|
|
|
|
NewGroveLedDriver(testAdaptor, pin),
|
|
|
|
NewGroveRelayDriver(testAdaptor, pin),
|
|
|
|
NewGroveMagneticSwitchDriver(testAdaptor, pin),
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, driver := range drivers {
|
2016-11-07 02:36:11 +08:00
|
|
|
gobottest.Assert(t, driver.Connection(), testAdaptor)
|
|
|
|
gobottest.Assert(t, driver.Pin(), pin)
|
2016-11-06 11:14:30 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDigitalDriverHalt(t *testing.T) {
|
|
|
|
testAdaptor := newGpioTestAdaptor()
|
|
|
|
pin := "456"
|
|
|
|
|
|
|
|
drivers := []DriverAndEventer{
|
|
|
|
NewGroveTouchDriver(testAdaptor, pin),
|
|
|
|
NewGroveButtonDriver(testAdaptor, pin),
|
|
|
|
NewGroveMagneticSwitchDriver(testAdaptor, pin),
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, driver := range drivers {
|
2016-11-07 02:36:11 +08:00
|
|
|
|
|
|
|
var callCount int32
|
2017-04-02 23:15:45 +08:00
|
|
|
testAdaptor.testAdaptorDigitalRead = func() (int, error) {
|
2016-11-07 02:36:11 +08:00
|
|
|
atomic.AddInt32(&callCount, 1)
|
|
|
|
return 42, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Start the driver and allow for multiple digital reads
|
|
|
|
driver.Start()
|
|
|
|
time.Sleep(20 * time.Millisecond)
|
|
|
|
|
|
|
|
driver.Halt()
|
|
|
|
lastCallCount := atomic.LoadInt32(&callCount)
|
|
|
|
// If driver was not halted, digital reads would still continue
|
|
|
|
time.Sleep(20 * time.Millisecond)
|
|
|
|
if atomic.LoadInt32(&callCount) != lastCallCount {
|
|
|
|
t.Errorf("DigitalRead was called after driver was halted")
|
|
|
|
}
|
2016-11-06 11:14:30 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestDriverPublishesError(t *testing.T) {
|
|
|
|
testAdaptor := newGpioTestAdaptor()
|
|
|
|
pin := "456"
|
|
|
|
|
|
|
|
drivers := []DriverAndEventer{
|
|
|
|
NewGroveTouchDriver(testAdaptor, pin),
|
|
|
|
NewGroveButtonDriver(testAdaptor, pin),
|
|
|
|
NewGroveMagneticSwitchDriver(testAdaptor, pin),
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, driver := range drivers {
|
2016-11-07 02:36:11 +08:00
|
|
|
sem := make(chan struct{}, 1)
|
|
|
|
// send error
|
|
|
|
returnErr := func() (val int, err error) {
|
|
|
|
err = errors.New("read error")
|
|
|
|
return
|
|
|
|
}
|
2017-04-02 23:15:45 +08:00
|
|
|
testAdaptor.testAdaptorDigitalRead = returnErr
|
2016-11-07 02:36:11 +08:00
|
|
|
|
2016-11-08 04:22:05 +08:00
|
|
|
gobottest.Assert(t, driver.Start(), nil)
|
2016-11-07 02:36:11 +08:00
|
|
|
|
|
|
|
// expect error
|
|
|
|
driver.Once(driver.Event(Error), func(data interface{}) {
|
|
|
|
gobottest.Assert(t, data.(error).Error(), "read error")
|
|
|
|
close(sem)
|
2016-11-06 11:14:30 +08:00
|
|
|
})
|
|
|
|
|
2016-11-07 02:36:11 +08:00
|
|
|
select {
|
|
|
|
case <-sem:
|
|
|
|
case <-time.After(time.Second):
|
|
|
|
t.Errorf("%s Event \"Error\" was not published", getType(driver))
|
|
|
|
}
|
|
|
|
|
2016-11-06 11:14:30 +08:00
|
|
|
// Cleanup
|
|
|
|
driver.Halt()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func getType(driver interface{}) string {
|
|
|
|
d := reflect.TypeOf(driver)
|
|
|
|
|
|
|
|
if d.Kind() == reflect.Ptr {
|
|
|
|
return d.Elem().Name()
|
|
|
|
}
|
|
|
|
|
|
|
|
return d.Name()
|
|
|
|
}
|