Commit 64d89ae7 authored by Juan Batiz-Benet's avatar Juan Batiz-Benet

blockstore: fixed data race

parent c637d733
...@@ -118,9 +118,11 @@ func TestAllKeysRespectsContext(t *testing.T) { ...@@ -118,9 +118,11 @@ func TestAllKeysRespectsContext(t *testing.T) {
// Once without context, to make sure it all works // Once without context, to make sure it all works
{ {
var results dsq.Results var results dsq.Results
var resultsmu = make(chan struct{})
resultChan := make(chan dsq.Result) resultChan := make(chan dsq.Result)
d.SetFunc(func(q dsq.Query) (dsq.Results, error) { d.SetFunc(func(q dsq.Query) (dsq.Results, error) {
results = dsq.ResultsWithChan(q, resultChan) results = dsq.ResultsWithChan(q, resultChan)
resultsmu <- struct{}{}
return results, nil return results, nil
}) })
...@@ -128,6 +130,7 @@ func TestAllKeysRespectsContext(t *testing.T) { ...@@ -128,6 +130,7 @@ func TestAllKeysRespectsContext(t *testing.T) {
// make sure it's waiting. // make sure it's waiting.
<-started <-started
<-resultsmu
select { select {
case <-done: case <-done:
t.Fatal("sync is wrong") t.Fatal("sync is wrong")
...@@ -156,9 +159,11 @@ func TestAllKeysRespectsContext(t *testing.T) { ...@@ -156,9 +159,11 @@ func TestAllKeysRespectsContext(t *testing.T) {
// Once with // Once with
{ {
var results dsq.Results var results dsq.Results
var resultsmu = make(chan struct{})
resultChan := make(chan dsq.Result) resultChan := make(chan dsq.Result)
d.SetFunc(func(q dsq.Query) (dsq.Results, error) { d.SetFunc(func(q dsq.Query) (dsq.Results, error) {
results = dsq.ResultsWithChan(q, resultChan) results = dsq.ResultsWithChan(q, resultChan)
resultsmu <- struct{}{}
return results, nil return results, nil
}) })
...@@ -167,6 +172,7 @@ func TestAllKeysRespectsContext(t *testing.T) { ...@@ -167,6 +172,7 @@ func TestAllKeysRespectsContext(t *testing.T) {
// make sure it's waiting. // make sure it's waiting.
<-started <-started
<-resultsmu
select { select {
case <-done: case <-done:
t.Fatal("sync is wrong") t.Fatal("sync is wrong")
......
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