go-rpio/rpio_test.go
Drahoslav 4ae1cfd964 Minor change in edge event detection api
Also other minor changes and gofmt
2018-06-06 13:34:52 +02:00

96 lines
1.5 KiB
Go

package rpio
import (
"os"
"testing"
"time"
)
func TestMain(m *testing.M) {
println("Note: bcm pins 2 and 3 has to be directly connected")
if err := Open(); err != nil {
panic(err)
}
defer Close()
os.Exit(m.Run())
}
func TestRisingEdgeEvent(t *testing.T) {
src := Pin(3)
src.Mode(Output)
src.Low()
pin := Pin(2)
pin.Mode(Input)
pin.PullDown()
pin.Detect(RiseEdge)
timeout := time.After(time.Second)
loop:
for {
src.High()
time.Sleep(time.Second / 5)
if pin.EdgeDetected() {
t.Log("edge rised")
} else {
t.Errorf("Rise event should be detected")
}
select {
case <-timeout:
break loop
default:
}
src.Low()
}
if pin.EdgeDetected() {
t.Error("Rise should not be detected, no change since last call")
}
pin.Detect(NoEdge)
src.High()
if pin.EdgeDetected() {
t.Error("Rise should not be detected, events disabled")
}
}
func TestFallingEdgeEvent(t *testing.T) {
src := Pin(3)
src.Mode(Output)
src.High()
pin := Pin(2)
pin.Mode(Input)
pin.PullDown()
pin.Detect(FallEdge)
timeout := time.After(time.Second)
loop:
for {
src.Low()
time.Sleep(time.Second / 5)
if pin.EdgeDetected() {
t.Log("edge fallen")
} else {
t.Errorf("Fall event should be detected")
}
select {
case <-timeout:
break loop
default:
}
src.High()
}
if pin.EdgeDetected() {
t.Error("Fall should not be detected, no change since last call")
}
pin.Detect(NoEdge)
src.Low()
if pin.EdgeDetected() {
t.Error("Fall should not be detected, events disabled")
}
}