blob: ecd3b80771a5fc1ded2f7ca6187e9aa48e355c75 [file] [log] [blame]
package main
import "testing"
func BenchmarkWorker(b *testing.B) {
producerSequence := NewSequence()
workerSequence := NewSequence()
barrier := NewBarrier(producerSequence)
worker := NewWorker(barrier, &testHandler{}, producerSequence, workerSequence)
iterations := int64(b.N)
b.ReportAllocs()
b.ResetTimer()
producerSequence.Store(1)
for i := int64(0); i < iterations; i++ {
workerSequence[SequencePayloadIndex] = 0
worker.Process()
}
}
type testHandler struct{}
func (this testHandler) Consume(sequence, remaining int64) {}