milvus/pkg/util/syncutil/async_task_notifier_test.go
chyezh 1bc3c0b925
enhance: implement balancer at streaming coord (#34435)
issue: #33285

- add balancer implementation
- add channel count fair balance policy
- add channel assignment discover grpc service

Signed-off-by: chyezh <chyezh@outlook.com>
2024-07-11 09:58:48 +08:00

58 lines
972 B
Go

package syncutil
import (
"errors"
"testing"
"github.com/stretchr/testify/assert"
)
func TestAsyncTaskNotifier(t *testing.T) {
n := NewAsyncTaskNotifier[error]()
assert.NotNil(t, n.Context())
select {
case <-n.FinishChan():
t.Errorf("should not done")
return
case <-n.Context().Done():
t.Error("should not cancel")
return
default:
}
finishErr := errors.New("test")
ch := make(chan struct{})
go func() {
defer close(ch)
done := false
cancel := false
cancelCh := n.Context().Done()
doneCh := n.FinishChan()
for i := 0; ; i += 1 {
select {
case <-doneCh:
done = true
doneCh = nil
case <-cancelCh:
cancel = true
cancelCh = nil
n.Finish(finishErr)
}
if cancel && done {
return
}
if i == 0 {
assert.True(t, cancel && !done)
} else if i == 1 {
assert.True(t, cancel && done)
}
}
}()
n.Cancel()
n.BlockUntilFinish()
assert.ErrorIs(t, n.BlockAndGetResult(), finishErr)
<-ch
}