Commit 8ed04cfe authored by Juan Batiz-Benet's avatar Juan Batiz-Benet Committed by Brian Tiger Chow

fixed test

parent 315e121e
...@@ -76,15 +76,18 @@ func TestSyncQueue(t *testing.T) { ...@@ -76,15 +76,18 @@ func TestSyncQueue(t *testing.T) {
pq := NewXORDistancePQ(u.Key("11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a31")) pq := NewXORDistancePQ(u.Key("11140beec7b5ea3f0fdbc95d0dd47f3c5bc275da8a31"))
cq := NewChanQueue(ctx, pq) cq := NewChanQueue(ctx, pq)
countIn := 0
countOut := 0
produce := func() { max := 100000
consumerN := 10
countsIn := make([]int, consumerN*2)
countsOut := make([]int, consumerN)
produce := func(p int) {
tick := time.Tick(time.Millisecond) tick := time.Tick(time.Millisecond)
for { for i := 0; i < max; i++ {
select { select {
case tim := <-tick: case tim := <-tick:
countIn++ countsIn[p]++
cq.EnqChan <- newPeerTime(tim) cq.EnqChan <- newPeerTime(tim)
case <-ctx.Done(): case <-ctx.Done():
return return
...@@ -92,29 +95,37 @@ func TestSyncQueue(t *testing.T) { ...@@ -92,29 +95,37 @@ func TestSyncQueue(t *testing.T) {
} }
} }
consume := func() { consume := func(c int) {
for { for {
select { select {
case <-cq.DeqChan: case <-cq.DeqChan:
countOut++ countsOut[c]++
case <-ctx.Done(): case <-ctx.Done():
return return
} }
} }
} }
for i := 0; i < 10; i++ { // make n * 2 producers and n consumers
go produce() for i := 0; i < consumerN; i++ {
go produce() go produce(i)
go consume() go produce(consumerN + i)
go consume(i)
} }
select { select {
case <-ctx.Done(): case <-ctx.Done():
} }
if countIn != countOut { sum := func(ns []int) int {
t.Errorf("didnt get them all out: %d/%d", countOut, countIn) total := 0
for _, n := range ns {
total += n
}
return total
} }
if sum(countsIn) != sum(countsOut) {
t.Errorf("didnt get all of them out: %d/%d", countsOut, countsIn)
}
} }
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