2026-04-07 06:58:39 +09:00
|
|
|
package main
|
|
|
|
|
|
|
|
|
|
import (
|
2026-04-07 07:43:16 +09:00
|
|
|
"log/slog"
|
2026-04-07 06:58:39 +09:00
|
|
|
"os"
|
|
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/theater/picomap/lib/client"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
|
if len(os.Args) < 2 {
|
2026-04-07 07:43:16 +09:00
|
|
|
slog.Error("usage: test <name>")
|
2026-04-07 06:58:39 +09:00
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if err := run(os.Args[1]); err != nil {
|
2026-04-07 07:43:16 +09:00
|
|
|
slog.Error("fatal", "err", err)
|
2026-04-07 06:58:39 +09:00
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func run(name string) error {
|
|
|
|
|
devs, err := client.ListSerial()
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var testDev string
|
|
|
|
|
for _, dev := range devs {
|
2026-04-07 07:43:16 +09:00
|
|
|
log := slog.With("dev", dev)
|
|
|
|
|
log.Info("connecting for info")
|
2026-04-07 06:58:39 +09:00
|
|
|
c, err := client.NewSerial(dev, 2*time.Second)
|
|
|
|
|
if err != nil {
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Warn("connect error", "err", err)
|
2026-04-07 06:58:39 +09:00
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
info, err := c.Info()
|
|
|
|
|
c.Close()
|
|
|
|
|
if err != nil {
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Warn("info error", "err", err)
|
2026-04-07 06:58:39 +09:00
|
|
|
continue
|
|
|
|
|
}
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Info("got info", "firmware", info.FirmwareName)
|
2026-04-07 06:58:39 +09:00
|
|
|
if info.FirmwareName == "picomap_test" {
|
|
|
|
|
testDev = dev
|
|
|
|
|
break
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if testDev == "" {
|
2026-04-07 07:43:16 +09:00
|
|
|
slog.Error("no picomap_test device found")
|
|
|
|
|
os.Exit(1)
|
2026-04-07 06:58:39 +09:00
|
|
|
}
|
|
|
|
|
|
2026-04-07 07:43:16 +09:00
|
|
|
log := slog.With("dev", testDev)
|
|
|
|
|
log.Info("running test", "name", name)
|
2026-04-07 06:58:39 +09:00
|
|
|
|
|
|
|
|
c, err := client.NewSerial(testDev, 10*time.Second)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
defer c.Close()
|
|
|
|
|
|
|
|
|
|
result, err := c.Test(name)
|
|
|
|
|
if err != nil {
|
2026-04-07 07:43:16 +09:00
|
|
|
slog.Error("remote error", "dev", testDev, "err", err)
|
|
|
|
|
os.Exit(1)
|
2026-04-07 06:58:39 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
for _, msg := range result.Messages {
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Info("remote", "msg", msg)
|
2026-04-07 06:58:39 +09:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if result.Pass {
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Info("PASS")
|
2026-04-07 06:58:39 +09:00
|
|
|
} else {
|
2026-04-07 07:43:16 +09:00
|
|
|
log.Error("FAIL")
|
2026-04-07 06:58:39 +09:00
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
|
|
|
|
return nil
|
|
|
|
|
}
|