1
0
mirror of https://github.com/hybridgroup/gobot.git synced 2025-04-29 13:49:14 +08:00
hybridgroup.gobot/drivers/gpio/analog_sensor_driver_test.go

102 lines
2.1 KiB
Go
Raw Normal View History

2014-04-27 19:34:16 -07:00
package gpio
import (
2014-12-16 13:42:48 -08:00
"errors"
2014-06-12 20:08:06 -07:00
"testing"
2014-12-16 13:42:48 -08:00
"time"
2014-09-27 11:45:52 -07:00
"github.com/hybridgroup/gobot"
"github.com/hybridgroup/gobot/gobottest"
)
var _ gobot.Driver = (*AnalogSensorDriver)(nil)
2014-12-16 13:42:48 -08:00
func TestAnalogSensorDriver(t *testing.T) {
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
gobottest.Refute(t, d.Connection(), nil)
2014-12-16 13:42:48 -08:00
d = NewAnalogSensorDriver(newGpioTestAdaptor(), "1", 30*time.Second)
gobottest.Assert(t, d.interval, 30*time.Second)
2014-12-16 13:42:48 -08:00
testAdaptorAnalogRead = func() (val int, err error) {
val = 100
return
}
ret := d.Command("Read")(nil).(map[string]interface{})
gobottest.Assert(t, ret["val"].(int), 100)
gobottest.Assert(t, ret["err"], nil)
2014-06-12 20:08:06 -07:00
}
2014-06-13 16:01:39 -07:00
func TestAnalogSensorDriverStart(t *testing.T) {
2014-12-16 13:42:48 -08:00
sem := make(chan bool, 1)
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
2014-12-16 13:42:48 -08:00
2015-07-15 13:00:01 -07:00
testAdaptorAnalogRead = func() (val int, err error) {
val = 0
return
}
gobottest.Assert(t, len(d.Start()), 0)
2014-12-16 13:42:48 -08:00
2015-07-15 13:00:01 -07:00
// data was received
d.Once(d.Event(Data), func(data interface{}) {
gobottest.Assert(t, data.(int), 100)
2014-12-16 13:42:48 -08:00
sem <- true
})
testAdaptorAnalogRead = func() (val int, err error) {
val = 100
return
}
select {
case <-sem:
2015-07-15 13:00:01 -07:00
case <-time.After(10 * time.Second):
2014-12-16 13:42:48 -08:00
t.Errorf("AnalogSensor Event \"Data\" was not published")
}
2015-07-15 13:00:01 -07:00
// read error
d.Once(d.Event(Error), func(data interface{}) {
gobottest.Assert(t, data.(error).Error(), "read error")
2014-12-16 13:42:48 -08:00
sem <- true
})
testAdaptorAnalogRead = func() (val int, err error) {
err = errors.New("read error")
return
}
select {
case <-sem:
2015-07-15 13:00:01 -07:00
case <-time.After(10 * time.Second):
2014-12-16 13:42:48 -08:00
t.Errorf("AnalogSensor Event \"Error\" was not published")
}
2015-07-15 13:00:01 -07:00
// send a halt message
d.Once(d.Event(Data), func(data interface{}) {
sem <- true
})
testAdaptorAnalogRead = func() (val int, err error) {
val = 200
return
}
d.halt <- true
select {
case <-sem:
t.Errorf("AnalogSensor Event should not published")
2015-07-15 13:00:01 -07:00
case <-time.After(100 * time.Millisecond):
}
2014-06-12 20:08:06 -07:00
}
2014-06-13 12:39:02 -07:00
2014-06-13 16:01:39 -07:00
func TestAnalogSensorDriverHalt(t *testing.T) {
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
go func() {
<-d.halt
}()
gobottest.Assert(t, len(d.Halt()), 0)
2014-06-12 20:08:06 -07:00
}