diff options
author | Lunny Xiao <xiaolunwen@gmail.com> | 2020-01-31 00:09:39 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-01-30 11:09:39 -0500 |
commit | eac5142ac78de9ceef38b07eeb0b9ce6bc34ba58 (patch) | |
tree | 5e69fd19761a7a302ca32688287e31d07413f061 /modules/queue | |
parent | d7f4f87aafe04baf4638a5c66ea4a7989b2e38d4 (diff) | |
download | gitea-eac5142ac78de9ceef38b07eeb0b9ce6bc34ba58.tar.gz gitea-eac5142ac78de9ceef38b07eeb0b9ce6bc34ba58.zip |
Fix leveldb test race (#10054)
Co-authored-by: Lauris BH <lauris@nix.lv>
Co-authored-by: techknowlogick <techknowlogick@gitea.io>
Diffstat (limited to 'modules/queue')
-rw-r--r-- | modules/queue/queue_disk_test.go | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/modules/queue/queue_disk_test.go b/modules/queue/queue_disk_test.go index 8600b8d868..038d7d8223 100644 --- a/modules/queue/queue_disk_test.go +++ b/modules/queue/queue_disk_test.go @@ -8,6 +8,7 @@ import ( "context" "io/ioutil" "os" + "sync" "testing" "time" @@ -24,6 +25,7 @@ func TestLevelQueue(t *testing.T) { } } + var lock sync.Mutex queueShutdown := []func(){} queueTerminate := []func(){} @@ -46,9 +48,13 @@ func TestLevelQueue(t *testing.T) { assert.NoError(t, err) go queue.Run(func(_ context.Context, shutdown func()) { + lock.Lock() queueShutdown = append(queueShutdown, shutdown) + lock.Unlock() }, func(_ context.Context, terminate func()) { + lock.Lock() queueTerminate = append(queueTerminate, terminate) + lock.Unlock() }) test1 := testData{"A", 1} @@ -72,9 +78,12 @@ func TestLevelQueue(t *testing.T) { err = queue.Push(test1) assert.Error(t, err) + lock.Lock() for _, callback := range queueShutdown { callback() } + lock.Unlock() + time.Sleep(200 * time.Millisecond) err = queue.Push(&test1) assert.NoError(t, err) @@ -85,9 +94,11 @@ func TestLevelQueue(t *testing.T) { assert.Fail(t, "Handler processing should have stopped") default: } + lock.Lock() for _, callback := range queueTerminate { callback() } + lock.Unlock() // Reopen queue queue, err = NewWrappedQueue(handle, @@ -109,9 +120,13 @@ func TestLevelQueue(t *testing.T) { assert.NoError(t, err) go queue.Run(func(_ context.Context, shutdown func()) { + lock.Lock() queueShutdown = append(queueShutdown, shutdown) + lock.Unlock() }, func(_ context.Context, terminate func()) { + lock.Lock() queueTerminate = append(queueTerminate, terminate) + lock.Unlock() }) result3 := <-handleChan @@ -121,10 +136,13 @@ func TestLevelQueue(t *testing.T) { result4 := <-handleChan assert.Equal(t, test2.TestString, result4.TestString) assert.Equal(t, test2.TestInt, result4.TestInt) + + lock.Lock() for _, callback := range queueShutdown { callback() } for _, callback := range queueTerminate { callback() } + lock.Unlock() } |