mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 17:18:35 +08:00
Related to #44620 Related to unstable ut "internal/querycoordv2 TestServer/TestNodeUp" Introduce SessionWatcher interface to fix race condition and goroutine leak that caused unstable unit test TestServer/TestNodeUp. Changes: - Add SessionWatcher interface with EventChannel() and Stop() methods - Refactor WatchServices() to return SessionWatcher instead of raw channel - Fix cleanup order in QueryCoordV2: stop watcher before session - Update DataCoord, ConnectionManager to use SessionWatcher - Add MockSessionWatcher for testing Fixes race condition between session context cancellation and internal loop exit. Eliminates goroutine leak by providing explicit lifecycle management. --------- Signed-off-by: Congqi Xia <congqi.xia@zilliz.com>
112 lines
3.0 KiB
Go
112 lines
3.0 KiB
Go
// Code generated by mockery v2.53.3. DO NOT EDIT.
|
|
|
|
package sessionutil
|
|
|
|
import mock "github.com/stretchr/testify/mock"
|
|
|
|
// MockSessionWatcher is an autogenerated mock type for the SessionWatcher type
|
|
type MockSessionWatcher struct {
|
|
mock.Mock
|
|
}
|
|
|
|
type MockSessionWatcher_Expecter struct {
|
|
mock *mock.Mock
|
|
}
|
|
|
|
func (_m *MockSessionWatcher) EXPECT() *MockSessionWatcher_Expecter {
|
|
return &MockSessionWatcher_Expecter{mock: &_m.Mock}
|
|
}
|
|
|
|
// EventChannel provides a mock function with no fields
|
|
func (_m *MockSessionWatcher) EventChannel() <-chan *SessionEvent {
|
|
ret := _m.Called()
|
|
|
|
if len(ret) == 0 {
|
|
panic("no return value specified for EventChannel")
|
|
}
|
|
|
|
var r0 <-chan *SessionEvent
|
|
if rf, ok := ret.Get(0).(func() <-chan *SessionEvent); ok {
|
|
r0 = rf()
|
|
} else {
|
|
if ret.Get(0) != nil {
|
|
r0 = ret.Get(0).(<-chan *SessionEvent)
|
|
}
|
|
}
|
|
|
|
return r0
|
|
}
|
|
|
|
// MockSessionWatcher_EventChannel_Call is a *mock.Call that shadows Run/Return methods with type explicit version for method 'EventChannel'
|
|
type MockSessionWatcher_EventChannel_Call struct {
|
|
*mock.Call
|
|
}
|
|
|
|
// EventChannel is a helper method to define mock.On call
|
|
func (_e *MockSessionWatcher_Expecter) EventChannel() *MockSessionWatcher_EventChannel_Call {
|
|
return &MockSessionWatcher_EventChannel_Call{Call: _e.mock.On("EventChannel")}
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_EventChannel_Call) Run(run func()) *MockSessionWatcher_EventChannel_Call {
|
|
_c.Call.Run(func(args mock.Arguments) {
|
|
run()
|
|
})
|
|
return _c
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_EventChannel_Call) Return(_a0 <-chan *SessionEvent) *MockSessionWatcher_EventChannel_Call {
|
|
_c.Call.Return(_a0)
|
|
return _c
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_EventChannel_Call) RunAndReturn(run func() <-chan *SessionEvent) *MockSessionWatcher_EventChannel_Call {
|
|
_c.Call.Return(run)
|
|
return _c
|
|
}
|
|
|
|
// Stop provides a mock function with no fields
|
|
func (_m *MockSessionWatcher) Stop() {
|
|
_m.Called()
|
|
}
|
|
|
|
// MockSessionWatcher_Stop_Call is a *mock.Call that shadows Run/Return methods with type explicit version for method 'Stop'
|
|
type MockSessionWatcher_Stop_Call struct {
|
|
*mock.Call
|
|
}
|
|
|
|
// Stop is a helper method to define mock.On call
|
|
func (_e *MockSessionWatcher_Expecter) Stop() *MockSessionWatcher_Stop_Call {
|
|
return &MockSessionWatcher_Stop_Call{Call: _e.mock.On("Stop")}
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_Stop_Call) Run(run func()) *MockSessionWatcher_Stop_Call {
|
|
_c.Call.Run(func(args mock.Arguments) {
|
|
run()
|
|
})
|
|
return _c
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_Stop_Call) Return() *MockSessionWatcher_Stop_Call {
|
|
_c.Call.Return()
|
|
return _c
|
|
}
|
|
|
|
func (_c *MockSessionWatcher_Stop_Call) RunAndReturn(run func()) *MockSessionWatcher_Stop_Call {
|
|
_c.Run(run)
|
|
return _c
|
|
}
|
|
|
|
// NewMockSessionWatcher creates a new instance of MockSessionWatcher. It also registers a testing interface on the mock and a cleanup function to assert the mocks expectations.
|
|
// The first argument is typically a *testing.T value.
|
|
func NewMockSessionWatcher(t interface {
|
|
mock.TestingT
|
|
Cleanup(func())
|
|
}) *MockSessionWatcher {
|
|
mock := &MockSessionWatcher{}
|
|
mock.Mock.Test(t)
|
|
|
|
t.Cleanup(func() { mock.AssertExpectations(t) })
|
|
|
|
return mock
|
|
}
|