Event replay and cleanup
This commit is contained in:
parent
2560410820
commit
97bf66c191
8 changed files with 447 additions and 39 deletions
|
|
@ -2,11 +2,12 @@ package state
|
|||
|
||||
import (
|
||||
"fmt"
|
||||
"os"
|
||||
"testing"
|
||||
"time"
|
||||
|
||||
"gitlab.com/whom/bingobot/pkg/docbuf"
|
||||
"gitlab.com/whom/bingobot/internal/logging"
|
||||
"gitlab.com/whom/bingobot/pkg/docbuf"
|
||||
)
|
||||
|
||||
/* WARNING:
|
||||
|
|
@ -54,15 +55,11 @@ func TestEventMarshalUnmarshal(t *testing.T) {
|
|||
t.Fatalf("error marshalling challenge: %e, %s", err, cstr)
|
||||
}
|
||||
|
||||
t.Logf("cstr: %s\n", cstr)
|
||||
|
||||
vstr, err := EventToString(vev);
|
||||
if err != nil {
|
||||
t.Fatalf("error marshalling vote: %e, %s", err, vstr)
|
||||
}
|
||||
|
||||
t.Logf("vstr: %s\n", vstr)
|
||||
|
||||
if ev, err := EventFromString(cstr); err != nil ||
|
||||
ev.Data()[UserEventUserKey] != cev.Data()[UserEventUserKey] ||
|
||||
ev.Data()[UserEventCreatedKey] != cev.Data()[UserEventCreatedKey] {
|
||||
|
|
@ -270,3 +267,81 @@ func TestVoteEventValidations(t *testing.T) {
|
|||
t.Errorf("Unexpected or no error: %e", err)
|
||||
}
|
||||
}
|
||||
|
||||
func TestEventReplay(t *testing.T) {
|
||||
tmpTestFile, err := os.CreateTemp("", "TestEventReplayBackingStore")
|
||||
if err != nil {
|
||||
t.Fatalf("failed setting up tempfile: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := tmpTestFile.Close(); err != nil {
|
||||
t.Fatalf("failed to close initial handle to tempfile: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := Init(2, tmpTestFile.Name()); err != nil {
|
||||
t.Fatalf("failed initializing state machine: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := PublishEvent(TestEvent{
|
||||
ID: 1,
|
||||
Dispose: true,
|
||||
}); err != nil {
|
||||
t.Fatalf("failed to publish event 1: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := PublishEvent(TestEvent{
|
||||
ID: 2,
|
||||
Dispose: false,
|
||||
}); err != nil {
|
||||
t.Fatalf("failed to publish event 2: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := PublishEvent(TestEvent{
|
||||
ID: 3,
|
||||
Dispose: true,
|
||||
}); err != nil {
|
||||
t.Fatalf("failed to publish event 3: %s", err.Error())
|
||||
}
|
||||
|
||||
if err := PublishEvent(TestEvent{
|
||||
ID: 4,
|
||||
Dispose: false,
|
||||
}); err != nil {
|
||||
t.Fatalf("failed to publish event 4: %s", err.Error())
|
||||
}
|
||||
|
||||
sub, err := Test.Subscribe()
|
||||
if err := Start(); err != nil {
|
||||
t.Fatalf("failed to start state machine: %s", err.Error())
|
||||
}
|
||||
|
||||
select {
|
||||
case ev1 := <- sub:
|
||||
if ev1.Type() != Test {
|
||||
t.Fatalf("wrong kind of event somehow: %+v", ev1)
|
||||
}
|
||||
if ev1.(TestEvent).ID != 2 {
|
||||
t.Fatalf("misordered event: %+v", ev1)
|
||||
}
|
||||
default:
|
||||
t.Fatal("no events available from replay")
|
||||
}
|
||||
|
||||
select {
|
||||
case ev2 := <- sub:
|
||||
if ev2.Type() != Test {
|
||||
t.Fatalf("wrong kind of event somehow: %+v", ev2)
|
||||
}
|
||||
if ev2.(TestEvent).ID != 4 {
|
||||
t.Fatalf("misordered event: %+v", ev2)
|
||||
}
|
||||
default:
|
||||
t.Fatal("only one event made it out")
|
||||
}
|
||||
|
||||
select {
|
||||
case <- sub:
|
||||
t.Fatalf("superfluous events left in subscription")
|
||||
default:
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue