mirror of https://github.com/milvus-io/milvus.git
65 lines
3.0 KiB
Go
65 lines
3.0 KiB
Go
package dependency
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/milvus-io/milvus/pkg/util/paramtable"
|
|
)
|
|
|
|
func TestValidateMQType(t *testing.T) {
|
|
assert.Error(t, validateMQType(true, mqTypeDefault))
|
|
assert.Error(t, validateMQType(false, mqTypeDefault))
|
|
assert.Error(t, validateMQType(false, mqTypeNatsmq))
|
|
assert.Error(t, validateMQType(false, mqTypeRocksmq))
|
|
}
|
|
|
|
func TestSelectMQType(t *testing.T) {
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeDefault, mqEnable{true, true, true, true}), mqTypeRocksmq)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeDefault, mqEnable{false, true, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeDefault, mqEnable{false, false, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeDefault, mqEnable{false, false, false, true}), mqTypeKafka)
|
|
assert.Panics(t, func() { mustSelectMQType(true, mqTypeDefault, mqEnable{false, false, false, false}) })
|
|
assert.Equal(t, mustSelectMQType(false, mqTypeDefault, mqEnable{true, true, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(false, mqTypeDefault, mqEnable{false, true, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(false, mqTypeDefault, mqEnable{false, false, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(false, mqTypeDefault, mqEnable{false, false, false, true}), mqTypeKafka)
|
|
assert.Panics(t, func() { mustSelectMQType(false, mqTypeDefault, mqEnable{false, false, false, false}) })
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeRocksmq, mqEnable{true, true, true, true}), mqTypeRocksmq)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeNatsmq, mqEnable{true, true, true, true}), mqTypeNatsmq)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypePulsar, mqEnable{true, true, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(true, mqTypeKafka, mqEnable{true, true, true, true}), mqTypeKafka)
|
|
assert.Panics(t, func() { mustSelectMQType(false, mqTypeRocksmq, mqEnable{true, true, true, true}) })
|
|
assert.Panics(t, func() { mustSelectMQType(false, mqTypeNatsmq, mqEnable{true, true, true, true}) })
|
|
assert.Equal(t, mustSelectMQType(false, mqTypePulsar, mqEnable{true, true, true, true}), mqTypePulsar)
|
|
assert.Equal(t, mustSelectMQType(false, mqTypeKafka, mqEnable{true, true, true, true}), mqTypeKafka)
|
|
}
|
|
|
|
func TestHealthCheck(t *testing.T) {
|
|
paramtable.Init()
|
|
paramtable.Get().Save(paramtable.Get().PulsarCfg.WebAddress.Key, "")
|
|
paramtable.Get().Reset(paramtable.Get().PulsarCfg.WebAddress.Key)
|
|
paramtable.Get().Save(paramtable.Get().KafkaCfg.Address.Key, "")
|
|
paramtable.Get().Reset(paramtable.Get().KafkaCfg.Address.Key)
|
|
|
|
testCases := []struct {
|
|
mqType string
|
|
health bool
|
|
}{
|
|
{mqTypeNatsmq, true},
|
|
{mqTypeRocksmq, true},
|
|
{mqTypePulsar, false},
|
|
{mqTypeKafka, false},
|
|
{"invalidType", false},
|
|
}
|
|
|
|
for _, tc := range testCases {
|
|
t.Run(tc.mqType, func(t *testing.T) {
|
|
status := HealthCheck(tc.mqType)
|
|
assert.Equal(t, tc.mqType, status.MqType)
|
|
assert.Equal(t, tc.health, status.Health)
|
|
})
|
|
}
|
|
}
|