graphvent/gql_test.go

65 lines
1.7 KiB
Go

2023-06-25 20:20:59 -06:00
package graphvent
import (
"testing"
2023-06-25 22:19:05 -06:00
"time"
"fmt"
"encoding/json"
2023-06-25 20:20:59 -06:00
)
func TestGQLThread(t * testing.T) {
2023-07-02 12:14:04 -06:00
ctx := logTestContext(t, []string{"thread"})
gql_thread, err := NewGQLThread(ctx, ":8080", []Lockable{})
2023-06-25 20:20:59 -06:00
fatalErr(t, err)
2023-07-02 12:14:04 -06:00
test_thread_1, err := NewSimpleThread(ctx, "Test thread 1", []Lockable{}, BaseThreadActions, BaseThreadHandlers)
2023-06-25 20:20:59 -06:00
fatalErr(t, err)
2023-07-02 12:14:04 -06:00
test_thread_2, err := NewSimpleThread(ctx, "Test thread 2", []Lockable{}, BaseThreadActions, BaseThreadHandlers)
fatalErr(t, err)
i1 := NewGQLThreadInfo(true, "start", "restore")
err = LinkThreads(ctx, gql_thread, test_thread_1, &i1)
fatalErr(t, err)
i2 := NewGQLThreadInfo(false, "start", "restore")
err = LinkThreads(ctx, gql_thread, test_thread_2, &i2)
2023-06-25 20:20:59 -06:00
fatalErr(t, err)
2023-06-25 22:19:05 -06:00
go func(thread Thread){
time.Sleep(10*time.Millisecond)
SendUpdate(ctx, thread, CancelSignal(nil))
}(gql_thread)
err = RunThread(ctx, gql_thread, "start")
2023-06-25 20:20:59 -06:00
fatalErr(t, err)
}
func TestGQLDBLoad(t * testing.T) {
ctx := logTestContext(t, []string{})
2023-07-02 12:14:04 -06:00
l1, err := NewSimpleLockable(ctx, "Test Lockable 1", []Lockable{})
fatalErr(t, err)
t1, err := NewGQLThread(ctx, ":8080", []Lockable{l1})
fatalErr(t, err)
SendUpdate(ctx, t1, CancelSignal(nil))
err = RunThread(ctx, t1, "start")
fatalErr(t, err)
err = UseStates(ctx, []GraphNode{t1}, func(states NodeStateMap) error {
ser, err := json.MarshalIndent(states[t1.ID()], "", " ")
fmt.Printf("\n%s\n\n", ser)
return err
})
t1_loaded, err := LoadNode(ctx, t1.ID())
fatalErr(t, err)
err = UseStates(ctx, []GraphNode{t1_loaded}, func(states NodeStateMap) error {
ser, err := json.MarshalIndent(states[t1_loaded.ID()], "", " ")
fmt.Printf("\n%s\n\n", ser)
return err
})
}