Added TestEventExt and TestEvent, added return of queued signals to WaitForResponse
parent
2081771135
commit
a061d6850c
@ -1,13 +1,77 @@
|
||||
package graphvent
|
||||
|
||||
import (
|
||||
"testing"
|
||||
"reflect"
|
||||
"testing"
|
||||
"time"
|
||||
)
|
||||
|
||||
func TestEvent(t *testing.T) {
|
||||
ctx := logTestContext(t, []string{"event", "listener"})
|
||||
err := ctx.RegisterExtension(reflect.TypeOf(&TestEventExt{}), NewExtType("TEST_EVENT"), nil)
|
||||
fatalErr(t, err)
|
||||
|
||||
|
||||
event_listener := NewListenerExt(100)
|
||||
_, err := NewNode(ctx, nil, BaseNodeType, 100, nil, NewEventExt(nil, "Test Event"), event_listener)
|
||||
event, err := NewNode(ctx, nil, BaseNodeType, 100, nil, NewEventExt(nil, "Test Event"), &TestEventExt{}, event_listener)
|
||||
fatalErr(t, err)
|
||||
|
||||
response, signals := testSend(t, ctx, NewEventControlSignal("start"), event, event)
|
||||
switch resp := response.(type) {
|
||||
case *SuccessSignal:
|
||||
case *ErrorSignal:
|
||||
t.Fatalf("Error response %+v", resp.Error)
|
||||
default:
|
||||
t.Fatalf("Unexpected response %+v", resp)
|
||||
}
|
||||
|
||||
var state_signal *EventStateSignal = nil
|
||||
for _, signal := range(signals) {
|
||||
event_state, is_event_state := signal.(*EventStateSignal)
|
||||
if is_event_state == true && event_state.Source == event.ID && event_state.State == "running" {
|
||||
state_signal = event_state
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
if state_signal == nil {
|
||||
state_signal, err = WaitForSignal(event_listener.Chan, 10*time.Millisecond, func(sig *EventStateSignal) bool {
|
||||
return sig.Source == event.ID && sig.State == "running"
|
||||
})
|
||||
fatalErr(t, err)
|
||||
}
|
||||
|
||||
response, signals = testSend(t, ctx, NewEventControlSignal("finish"), event, event)
|
||||
switch resp := response.(type) {
|
||||
case *SuccessSignal:
|
||||
case *ErrorSignal:
|
||||
t.Fatalf("Error response %+v", resp.Error)
|
||||
default:
|
||||
t.Fatalf("Unexpected response %+v", resp)
|
||||
}
|
||||
|
||||
state_signal = nil
|
||||
for _, signal := range(signals) {
|
||||
event_state, is_event_state := signal.(*EventStateSignal)
|
||||
if is_event_state == true && event_state.Source == event.ID && event_state.State == "done" {
|
||||
state_signal = event_state
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
if state_signal == nil {
|
||||
state_signal, err = WaitForSignal(event_listener.Chan, 10*time.Millisecond, func(sig *EventStateSignal) bool {
|
||||
return sig.Source == event.ID && sig.State == "done"
|
||||
})
|
||||
fatalErr(t, err)
|
||||
}
|
||||
|
||||
response, signals = testSend(t, ctx, NewEventControlSignal("start"), event, event)
|
||||
switch resp := response.(type) {
|
||||
case *SuccessSignal:
|
||||
t.Fatalf("Success response starting finished TestEventExt")
|
||||
case *ErrorSignal:
|
||||
default:
|
||||
t.Fatalf("Unexpected response %+v", resp)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue