hybridgroup.gobot/drivers/gpio/analog_sensor_driver_test.go

110 lines
2.3 KiB
Go
Raw Permalink Normal View History

2014-04-28 10:34:16 +08:00
package gpio
import (
2014-12-17 05:42:48 +08:00
"errors"
2014-06-13 11:08:06 +08:00
"testing"
2014-12-17 05:42:48 +08:00
"time"
2014-09-28 02:45:52 +08:00
"gobot.io/x/gobot"
"gobot.io/x/gobot/gobottest"
)
var _ gobot.Driver = (*AnalogSensorDriver)(nil)
2014-12-17 05:42:48 +08:00
func TestAnalogSensorDriver(t *testing.T) {
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
gobottest.Refute(t, d.Connection(), nil)
// default interval
gobottest.Assert(t, d.interval, 10*time.Millisecond)
2014-12-17 05:42:48 +08:00
d = NewAnalogSensorDriver(newGpioTestAdaptor(), "42", 30*time.Second)
gobottest.Assert(t, d.Pin(), "42")
gobottest.Assert(t, d.interval, 30*time.Second)
2014-12-17 05: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-13 11:08:06 +08:00
}
2014-06-14 07:01:39 +08:00
func TestAnalogSensorDriverStart(t *testing.T) {
2014-12-17 05:42:48 +08:00
sem := make(chan bool, 1)
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
2014-12-17 05:42:48 +08:00
gobottest.Assert(t, d.Start(), nil)
2014-12-17 05:42:48 +08:00
// expect data to be received
d.Once(d.Event(Data), func(data interface{}) {
gobottest.Assert(t, data.(int), 100)
2014-12-17 05:42:48 +08:00
sem <- true
})
// send data
2014-12-17 05:42:48 +08:00
testAdaptorAnalogRead = func() (val int, err error) {
val = 100
return
}
select {
case <-sem:
2015-07-16 04:00:01 +08:00
case <-time.After(10 * time.Second):
2014-12-17 05:42:48 +08:00
t.Errorf("AnalogSensor Event \"Data\" was not published")
}
// expect error to be received
d.Once(d.Event(Error), func(data interface{}) {
gobottest.Assert(t, data.(error).Error(), "read error")
2014-12-17 05:42:48 +08:00
sem <- true
})
// send error
2014-12-17 05:42:48 +08:00
testAdaptorAnalogRead = func() (val int, err error) {
err = errors.New("read error")
return
}
select {
case <-sem:
2015-07-16 04:00:01 +08:00
case <-time.After(10 * time.Second):
2014-12-17 05:42:48 +08:00
t.Errorf("AnalogSensor Event \"Error\" was not published")
}
2015-07-16 04:00:01 +08: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-16 04:00:01 +08:00
case <-time.After(100 * time.Millisecond):
}
2014-06-13 11:08:06 +08:00
}
2014-06-14 03:39:02 +08:00
2014-06-14 07:01:39 +08:00
func TestAnalogSensorDriverHalt(t *testing.T) {
d := NewAnalogSensorDriver(newGpioTestAdaptor(), "1")
done := make(chan struct{})
go func() {
<-d.halt
close(done)
}()
gobottest.Assert(t, d.Halt(), nil)
select {
case <-done:
case <-time.After(time.Millisecond):
t.Errorf("AnalogSensor was not halted")
}
2014-06-13 11:08:06 +08:00
}