Fix unstable TestSingleflight unit test (#26363)

Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
This commit is contained in:
congqixia 2023-08-16 10:07:33 +08:00 committed by GitHub
parent a12e45f693
commit 4742049ecf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -68,26 +68,21 @@ func (s *SingleflightSuite) TestDoChan() {
}
func (s *SingleflightSuite) TestForget() {
counter, hasShared := atomic.Int32{}, atomic.Bool{}
sf := Singleflight[any]{}
ch := make(chan struct{})
submitted := make(chan struct{})
var wg sync.WaitGroup
wg.Add(10)
for i := 0; i < 10; i++ {
go func(i int) {
wg.Add(1)
go func() {
sf.Do("test_forget", func() (any, error) {
defer wg.Done()
_, _, shared := sf.Do("test_forget", func() (any, error) {
<-ch
counter.Add(1)
return struct{}{}, nil
})
if shared {
hasShared.Store(true)
}
}(i)
}
close(submitted)
<-ch
return struct{}{}, nil
})
}()
<-submitted
flag := false
sf.Forget("test_forget")
sf.Do("test_forget", func() (any, error) {
@ -98,7 +93,7 @@ func (s *SingleflightSuite) TestForget() {
close(ch)
wg.Wait()
s.True(flag)
s.True(flag, "new job shall be executed after forget")
}
func TestSingleFlight(t *testing.T) {