add tests for active config and reset
This commit is contained in:
@@ -19,10 +19,19 @@ import (
|
|||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestOpenEndpoint(t *testing.T) {
|
func TestClaimAndRelease(t *testing.T) {
|
||||||
_, done := newFakeLibusb()
|
_, done := newFakeLibusb()
|
||||||
defer done()
|
defer done()
|
||||||
|
|
||||||
|
const (
|
||||||
|
devIdx = 1
|
||||||
|
cfgNum = 1
|
||||||
|
if1Num = 1
|
||||||
|
alt1Num = 1
|
||||||
|
ep1Num = 6
|
||||||
|
alt2Num = 0
|
||||||
|
if2Num = 0
|
||||||
|
)
|
||||||
c := NewContext()
|
c := NewContext()
|
||||||
defer c.Close()
|
defer c.Close()
|
||||||
dev, err := c.OpenDeviceWithVidPid(0x8888, 0x0002)
|
dev, err := c.OpenDeviceWithVidPid(0x8888, 0x0002)
|
||||||
@@ -33,22 +42,28 @@ func TestOpenEndpoint(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("OpenDeviceWithVidPid(0x8888, 0x0002): %v", err)
|
t.Fatalf("OpenDeviceWithVidPid(0x8888, 0x0002): %v", err)
|
||||||
}
|
}
|
||||||
cfg, err := dev.Config(1)
|
cfg, err := dev.Config(cfgNum)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("%s.Config(1): %v", dev, err)
|
t.Fatalf("%s.Config(1): %v", dev, err)
|
||||||
}
|
}
|
||||||
defer cfg.Close()
|
defer cfg.Close()
|
||||||
intf, err := cfg.Interface(1, 1)
|
if got, err := dev.ActiveConfig(); err != nil {
|
||||||
|
t.Errorf("%s.ActiveConfig(): got error %v, want nil", dev, err)
|
||||||
|
} else if got != cfgNum {
|
||||||
|
t.Errorf("%s.ActiveConfig(): got %d, want %d", dev, got, cfgNum)
|
||||||
|
}
|
||||||
|
|
||||||
|
intf, err := cfg.Interface(if1Num, alt1Num)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("%s.Interface(1, 1): %v", cfg, err)
|
t.Fatalf("%s.Interface(%d, %d): %v", cfg, if1Num, alt1Num, err)
|
||||||
}
|
}
|
||||||
defer intf.Close()
|
defer intf.Close()
|
||||||
got, err := intf.InEndpoint(6)
|
got, err := intf.InEndpoint(ep1Num)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("%s.InEndpoint(6): got error %v, want nil", intf, err)
|
t.Fatalf("%s.InEndpoint(%d): got error %v, want nil", intf, ep1Num, err)
|
||||||
}
|
}
|
||||||
if want := fakeDevices[1].Configs[1].Interfaces[1].AltSettings[1].Endpoints[1]; !reflect.DeepEqual(got.Info, want) {
|
if want := fakeDevices[devIdx].Configs[cfgNum].Interfaces[if1Num].AltSettings[alt1Num].Endpoints[ep1Num]; !reflect.DeepEqual(got.Info, want) {
|
||||||
t.Errorf("%s.InEndpoint(6): got %+v, want %+v", intf, got, want)
|
t.Errorf("%s.InEndpoint(%d): got %+v, want %+v", intf, ep1Num, got, want)
|
||||||
}
|
}
|
||||||
|
|
||||||
if _, err := cfg.Interface(1, 0); err == nil {
|
if _, err := cfg.Interface(1, 0); err == nil {
|
||||||
@@ -81,10 +96,18 @@ func TestOpenEndpoint(t *testing.T) {
|
|||||||
t.Fatalf("%s.Close(): got nil, want non nil, because the Config was not released.", dev)
|
t.Fatalf("%s.Close(): got nil, want non nil, because the Config was not released.", dev)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := dev.Reset(); err == nil {
|
||||||
|
t.Fatalf("%s.Reset(): got nil, want non nil, because Device is still has an active Config.", dev)
|
||||||
|
}
|
||||||
|
|
||||||
if err := cfg.Close(); err != nil {
|
if err := cfg.Close(); err != nil {
|
||||||
t.Fatalf("%s.Close(): got error %v, want nil", cfg, err)
|
t.Fatalf("%s.Close(): got error %v, want nil", cfg, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := dev.Reset(); err != nil {
|
||||||
|
t.Fatalf("%s.Reset(): got error %v, want nil", dev, err)
|
||||||
|
}
|
||||||
|
|
||||||
if err := dev.Close(); err != nil {
|
if err := dev.Close(); err != nil {
|
||||||
t.Fatalf("%s.Close(): got error %v, want nil", dev, err)
|
t.Fatalf("%s.Close(): got error %v, want nil", dev, err)
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user