@@ -7,6 +7,7 @@ import (
|
||||
"path/filepath"
|
||||
"strings"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"ymhut-box/server/unified-management/internal/config"
|
||||
"ymhut-box/server/unified-management/internal/db"
|
||||
@@ -57,6 +58,67 @@ func TestCheckOneTreatsRedirectToOKAsRedirected(t *testing.T) {
|
||||
}
|
||||
}
|
||||
|
||||
func TestQueueCheckAllUsesBackgroundContext(t *testing.T) {
|
||||
server := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
|
||||
_, _ = w.Write([]byte("ok"))
|
||||
}))
|
||||
defer server.Close()
|
||||
cfg, store := testStore(t)
|
||||
service := NewService(cfg, store)
|
||||
if _, err := store.UpsertSource(db.Source{
|
||||
CategoryID: "test",
|
||||
CategoryName: "Test",
|
||||
SourceID: "slow-ok",
|
||||
Name: "Slow OK",
|
||||
Method: "GET",
|
||||
APIURL: server.URL,
|
||||
TimeoutMS: 1000,
|
||||
CheckIntervalSec: 300,
|
||||
Enabled: true,
|
||||
ClientVisible: true,
|
||||
}); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
job := service.QueueCheckAll()
|
||||
deadline := time.Now().Add(2 * time.Second)
|
||||
for time.Now().Before(deadline) {
|
||||
current, ok := service.CheckJob(job.ID)
|
||||
if ok && current.Status == "completed" {
|
||||
if current.Stats["ok"] != 1 {
|
||||
t.Fatalf("stats = %#v, want one ok", current.Stats)
|
||||
}
|
||||
return
|
||||
}
|
||||
time.Sleep(20 * time.Millisecond)
|
||||
}
|
||||
t.Fatalf("job did not complete: %#v", job)
|
||||
}
|
||||
|
||||
func TestSubscribeEventsBroadcastsToAllSubscribers(t *testing.T) {
|
||||
cfg, store := testStore(t)
|
||||
service := NewService(cfg, store)
|
||||
eventsA, unsubscribeA := service.SubscribeEvents()
|
||||
defer unsubscribeA()
|
||||
eventsB, unsubscribeB := service.SubscribeEvents()
|
||||
defer unsubscribeB()
|
||||
|
||||
service.emit("source_check.completed", map[string]any{"jobId": "demo"})
|
||||
|
||||
assertEvent := func(name string, events <-chan Event) {
|
||||
t.Helper()
|
||||
select {
|
||||
case event := <-events:
|
||||
if event.Type != "source_check.completed" || event.Data["jobId"] != "demo" {
|
||||
t.Fatalf("%s received unexpected event: %#v", name, event)
|
||||
}
|
||||
case <-time.After(time.Second):
|
||||
t.Fatalf("%s did not receive broadcast event", name)
|
||||
}
|
||||
}
|
||||
assertEvent("subscriber A", eventsA)
|
||||
assertEvent("subscriber B", eventsB)
|
||||
}
|
||||
|
||||
func testStore(t *testing.T) (*config.Config, *db.Store) {
|
||||
t.Helper()
|
||||
dir := t.TempDir()
|
||||
|
||||
Reference in New Issue
Block a user