milvus/tests/integration/cluster/process/milvus_process_specialized.go
Zhen Ye ecb24e7232
enhance: use multi-process framework in integration test (#42976)
issue: #41609

- add env `MILVUS_NODE_ID_FOR_TESTING` to set up a node id for milvus
process.
- add env `MILVUS_CONFIG_REFRESH_INTERVAL` to set up the refresh
interval of paramtable.
- Init paramtable when calling `paramtable.Get()`.
- add new multi process framework for integration test.
- change all integration test into multi process.
- merge some test case into one suite to speed up it.
- modify some test, which need to wait for issue #42966, #42685.
- remove the waittssync for delete collection to fix issue: #42989

---------

Signed-off-by: chyezh <chyezh@outlook.com>
2025-06-30 14:22:43 +08:00

83 lines
2.3 KiB
Go

package process
import (
"context"
"github.com/milvus-io/milvus/internal/types"
)
type (
MixcoordProcess = specializedMilvusProcess[types.MixCoordClient]
ProxyProcess = specializedMilvusProcess[types.ProxyClient]
DataNodeProcess = specializedMilvusProcess[types.DataNodeClient]
QueryNodeProcess = specializedMilvusProcess[types.QueryNodeClient]
// StreamingNodeProcess is a special query node process by now.
StreamingNodeProcess = specializedMilvusProcess[types.QueryNodeClient]
)
// NewMixCoordProcess creates a new MixcoordProcess.
func NewMixCoordProcess(opts ...Option) *MixcoordProcess {
opts = append(opts, WithRole("mixcoord"))
mp := NewMilvusProcess(opts...)
return &MixcoordProcess{
MilvusProcess: mp,
}
}
// NewProxyProcess creates a new ProxyProcess.
func NewProxyProcess(opts ...Option) *ProxyProcess {
opts = append(opts, WithRole("proxy"))
mp := NewMilvusProcess(opts...)
return &ProxyProcess{
MilvusProcess: mp,
}
}
// NewQueryNodeProcess creates a new QueryNodeProcess.
func NewQueryNodeProcess(opts ...Option) *QueryNodeProcess {
opts = append(opts, WithRole("querynode"))
mp := NewMilvusProcess(opts...)
return &QueryNodeProcess{
MilvusProcess: mp,
}
}
// NewStreamingNodeProcess creates a new StreamingNodeProcess.
func NewStreamingNodeProcess(opts ...Option) *StreamingNodeProcess {
opts = append(opts, WithRole("streamingnode"))
mp := NewMilvusProcess(opts...)
return &StreamingNodeProcess{
MilvusProcess: mp,
}
}
// NewDataNodeProcess creates a new DataNodeProcess.
func NewDataNodeProcess(opts ...Option) *DataNodeProcess {
opts = append(opts, WithRole("datanode"))
mp := NewMilvusProcess(opts...)
return &DataNodeProcess{
MilvusProcess: mp,
}
}
// specializedMilvusProcess is a specialized Milvus process that returns a client of type T.
type specializedMilvusProcess[T any] struct {
*MilvusProcess
}
// GetClient returns a client of type T.
func (mp *specializedMilvusProcess[T]) MustGetClient(ctx context.Context) T {
client, err := mp.MilvusProcess.GetClient(ctx)
if err != nil {
panic(err)
}
return client.(T)
}
// MustWaitForReady waits for the Milvus process to be ready.
func (mp *specializedMilvusProcess[T]) MustWaitForReady(ctx context.Context) {
if err := mp.MilvusProcess.waitForReady(ctx); err != nil {
panic(err)
}
}