mirror of https://github.com/periph/devices
travis: run on 1.5.4
- Move go1.8+ test code using t.Run() into separate file conditionally compiled on go1.8+. It's not a big deal to partially lose test coverage on <1.8 as long as the main code runs fine. - Run coverage before race checker to help get results faster. - Fix typo. - No need to run travis on recent versions, they are handed by gohci workers and they are faster. :)pull/1/head
parent
6f8bd69f03
commit
f7d0d4e3d5
@ -0,0 +1,154 @@
|
|||||||
|
// Copyright 2017 The Periph Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed under the Apache License, Version 2.0
|
||||||
|
// that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
// +build go1.8
|
||||||
|
|
||||||
|
package cap1188
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"periph.io/x/periph/conn/i2c"
|
||||||
|
"periph.io/x/periph/conn/i2c/i2ctest"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestDev_InputStatus(t *testing.T) {
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
bus i2c.Bus
|
||||||
|
want [8]TouchStatus
|
||||||
|
}{
|
||||||
|
{name: "all off",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
// status
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x0}},
|
||||||
|
// deltas
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
// thresholds
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus},
|
||||||
|
},
|
||||||
|
{name: "all pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0xff}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{PressedStatus, PressedStatus, PressedStatus, PressedStatus, PressedStatus, PressedStatus, PressedStatus, PressedStatus},
|
||||||
|
},
|
||||||
|
{name: "first pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x80}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{PressedStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus},
|
||||||
|
},
|
||||||
|
{name: "second pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x40}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{OffStatus, PressedStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus},
|
||||||
|
},
|
||||||
|
{name: "third pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x20}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{OffStatus, OffStatus, PressedStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus},
|
||||||
|
},
|
||||||
|
{name: "eighth pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x1}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, PressedStatus},
|
||||||
|
},
|
||||||
|
{name: "3 pressed",
|
||||||
|
bus: &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x91}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
},
|
||||||
|
want: [8]TouchStatus{PressedStatus, OffStatus, OffStatus, PressedStatus, OffStatus, OffStatus, OffStatus, PressedStatus},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
d, err := NewI2C(tt.bus, &DefaultOpts)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
var got [8]TouchStatus
|
||||||
|
if err := d.InputStatus(got[:]); err != nil {
|
||||||
|
t.Fatalf("Dev.InputStatus() error = %v", err)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(got, tt.want) {
|
||||||
|
t.Errorf("Dev.InputStatus() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// test hold
|
||||||
|
t.Run("held touch sensors", func(t *testing.T) {
|
||||||
|
bus := &i2ctest.Playback{
|
||||||
|
Ops: append(setupPlaybackIO(), []i2ctest.IO{
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x80}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
// repeat call to get status (still pressed)
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x80}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
// finall call
|
||||||
|
{Addr: 40, W: []byte{0x3}, R: []byte{0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x10}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
//{Addr: 40, W: []byte{0x30}, R: []byte{0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0}},
|
||||||
|
}...),
|
||||||
|
}
|
||||||
|
// Set the recorded response to have the retrigger option on.
|
||||||
|
bus.Ops[10] = i2ctest.IO{Addr: 40, W: []byte{0x28, 0xff}, R: nil}
|
||||||
|
opts := DefaultOpts
|
||||||
|
// Following option needs to be true so we can get the held status.
|
||||||
|
opts.RetriggerOnHold = true
|
||||||
|
d, err := NewI2C(bus, &opts)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
// first check
|
||||||
|
var got [8]TouchStatus
|
||||||
|
if err := d.InputStatus(got[:]); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(got, [8]TouchStatus{PressedStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus}) {
|
||||||
|
t.Fatalf("expected to have the first sensor touched but instead got %v", got)
|
||||||
|
}
|
||||||
|
// 2nd check
|
||||||
|
if err = d.InputStatus(got[:]); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if !reflect.DeepEqual(got, [8]TouchStatus{HeldStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus, OffStatus}) {
|
||||||
|
t.Fatalf("expected to have the first sensor touched but instead got %v", got)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
@ -0,0 +1,39 @@
|
|||||||
|
// Copyright 2017 The Periph Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed under the Apache License, Version 2.0
|
||||||
|
// that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
// +build go1.8
|
||||||
|
|
||||||
|
package nrzled
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strconv"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestNRZ(t *testing.T) {
|
||||||
|
data := []struct {
|
||||||
|
in byte
|
||||||
|
expected uint32
|
||||||
|
}{
|
||||||
|
{0x00, 0x924924},
|
||||||
|
{0x01, 0x924926},
|
||||||
|
{0x02, 0x924934},
|
||||||
|
{0x04, 0x9249A4},
|
||||||
|
{0x08, 0x924D24},
|
||||||
|
{0x10, 0x926924},
|
||||||
|
{0x20, 0x934924},
|
||||||
|
{0x40, 0x9A4924},
|
||||||
|
{0x80, 0xD24924},
|
||||||
|
{0xFD, 0xDB6DA6},
|
||||||
|
{0xFE, 0xDB6DB4},
|
||||||
|
{0xFF, 0xDB6DB6},
|
||||||
|
}
|
||||||
|
for i, line := range data {
|
||||||
|
t.Run(strconv.Itoa(i), func(t *testing.T) {
|
||||||
|
if actual := NRZ(line.in); line.expected != actual {
|
||||||
|
t.Fatalf("NRZ(%X): 0x%X != 0x%X", line.in, line.expected, actual)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue