Commit 7405215b authored by Kirill Smelkov's avatar Kirill Smelkov

.

parent 0255bff1
...@@ -61,6 +61,7 @@ func setupTracing(t *tracetest.T) *tracing.ProbeGroup { ...@@ -61,6 +61,7 @@ func setupTracing(t *tracetest.T) *tracing.ProbeGroup {
t.RxEvent(eventHello(who)) t.RxEvent(eventHello(who))
}) })
tracing.Unlock() tracing.Unlock()
// NOTE pg.Done must be invoked by caller when setup tracing is no longer needed.
return pg return pg
} }
...@@ -86,18 +87,24 @@ func routeEvent(event interface{}) (stream string) { ...@@ -86,18 +87,24 @@ func routeEvent(event interface{}) (stream string) {
return strings.ToLower(who[:i]) return strings.ToLower(who[:i])
} }
// setupTraceEvents sets up tracing and routing.
// it is used in the prologue of tests.
func setupTraceEvents(t *tracetest.T) {
// setup tracing to deliver trace events to t.
pg := setupTracing(t)
t.Cleanup(pg.Done)
// tell t to which stream an event should go.
t.SetEventRouter(routeEvent)
}
// TestExample demonstrates how to use tracetest to verify concurrent system with 2 threads. // TestExample demonstrates how to use tracetest to verify concurrent system with 2 threads.
func TestExample(t *testing.T) { func TestExample(t *testing.T) {
tracetest.Verify(t, tracetestExample) tracetest.Verify(t, tracetestExample)
} }
func tracetestExample(t *tracetest.T) { func tracetestExample(t *tracetest.T) {
// setup tracing to deliver trace events to t. // setup tracing to deliver trace events to t and route them appropriately.
pg := setupTracing(t) setupTraceEvents(t)
defer pg.Done()
// tell tracetest to which stream an event should go.
t.SetEventRouter(routeEvent)
// run the workload // run the workload
var wg sync.WaitGroup var wg sync.WaitGroup
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment