go-emlid/reach/discovery/resolver_test.go

70 lines
1.2 KiB
Go
Raw Normal View History

2024-07-30 14:28:39 +02:00
package discovery
import (
"context"
"regexp"
"testing"
"time"
"forge.cadoles.com/cadoles/go-emlid/reach"
2024-08-06 09:32:02 +02:00
"github.com/davecgh/go-spew/spew"
"github.com/pkg/errors"
2024-07-30 14:28:39 +02:00
)
2024-08-06 09:32:02 +02:00
func TestResolver(t *testing.T) {
2024-07-30 14:28:39 +02:00
reach.AssertIntegrationTests(t)
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
2024-08-06 09:32:02 +02:00
resolver := NewResolver()
found, err := resolver.Scan(ctx, 500*time.Millisecond)
2024-07-30 14:28:39 +02:00
if err != nil {
2024-08-06 09:32:02 +02:00
t.Fatalf("%+v", errors.WithStack(err))
}
services := make([]Service, 0)
OUTER:
for {
select {
case s := <-found:
t.Logf("%s", spew.Sdump(s))
services = append(services, s)
case <-ctx.Done():
break OUTER
}
2024-07-30 14:28:39 +02:00
}
if g, e := len(services), 1; g < e {
t.Fatalf("len(services): got '%d', expected > %d", g, e)
}
t.Logf("Found %d services", len(services))
patterns := []string{"reach", "Reach", "^RS.*"}
for i, s := range services {
t.Logf("Service #%d: %s - %s:%d", i, s.Name, s.AddrV4.String(), s.Port)
matched := false
for _, p := range patterns {
re, err := regexp.Compile(p)
if err != nil {
t.Fatal(err)
}
if re.Match([]byte(s.Name)) {
matched = true
break
}
}
if !matched {
t.Errorf("services[%d].Name ('%s') to match on of '%v'", i, s.Name, patterns)
}
}
}