graphvent/node_test.go

56 lines
1.3 KiB
Go

package graphvent
import (
"testing"
"time"
"crypto/rand"
2023-08-06 12:47:47 -06:00
"crypto/ed25519"
)
func TestNodeDB(t *testing.T) {
2024-03-28 20:28:07 -06:00
ctx := logTestContext(t, []string{"test", "node", "db"})
node_listener := NewListenerExt(10)
2024-03-31 19:58:27 -06:00
node, err := ctx.NewNode(nil, "Node", NewLockableExt(nil), node_listener)
fatalErr(t, err)
2024-03-31 19:58:27 -06:00
err = ctx.Stop()
2023-08-31 22:31:29 -06:00
fatalErr(t, err)
2024-03-31 19:58:27 -06:00
_, err = ctx.GetNode(node.ID)
fatalErr(t, err)
}
func TestNodeRead(t *testing.T) {
ctx := logTestContext(t, []string{"test"})
2023-08-06 12:47:47 -06:00
n1_pub, n1_key, err := ed25519.GenerateKey(rand.Reader)
fatalErr(t, err)
2023-08-06 12:47:47 -06:00
n2_pub, n2_key, err := ed25519.GenerateKey(rand.Reader)
fatalErr(t, err)
2023-08-06 12:47:47 -06:00
n1_id := KeyID(n1_pub)
n2_id := KeyID(n2_pub)
ctx.Log.Logf("test", "N1: %s", n1_id)
ctx.Log.Logf("test", "N2: %s", n2_id)
n2_listener := NewListenerExt(10)
2024-03-31 19:58:27 -06:00
n2, err := ctx.NewNode(n2_key, "Node", n2_listener)
2023-08-31 22:31:29 -06:00
fatalErr(t, err)
2024-03-31 19:58:27 -06:00
n1, err := ctx.NewNode(n1_key, "Node", NewListenerExt(10))
2023-08-31 22:31:29 -06:00
fatalErr(t, err)
2024-03-28 20:28:07 -06:00
read_sig := NewReadSignal([]string{"buffer"})
msgs := []Message{{n1.ID, read_sig}}
2024-03-04 17:30:42 -07:00
err = ctx.Send(n2, msgs)
fatalErr(t, err)
res, err := WaitForSignal(n2_listener.Chan, 10*time.Millisecond, func(sig *ReadResultSignal) bool {
return true
})
fatalErr(t, err)
ctx.Log.Logf("test", "READ_RESULT: %+v", res)
}