quota_param_test.go 3.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
// Licensed to the LF AI & Data foundation under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package paramtable

import (
20
	"math"
21 22 23 24 25 26 27 28 29 30
	"testing"

	"github.com/stretchr/testify/assert"
)

func TestQuotaParam(t *testing.T) {
	qc := quotaConfig{}
	qc.init(&baseParams)

	t.Run("test quota", func(t *testing.T) {
31 32
		assert.True(t, qc.QuotaAndLimitsEnabled.GetAsBool())
		assert.Equal(t, float64(3), qc.QuotaCenterCollectInterval.GetAsFloat())
33 34 35
	})

	t.Run("test ddl", func(t *testing.T) {
36 37 38
		assert.Equal(t, false, qc.DDLLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.DDLCollectionRate.GetAsFloat())
		assert.Equal(t, defaultMax, qc.DDLPartitionRate.GetAsFloat())
39 40 41
	})

	t.Run("test functional params", func(t *testing.T) {
42 43 44 45 46 47
		assert.Equal(t, false, qc.IndexLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.MaxIndexRate.GetAsFloat())
		assert.Equal(t, false, qc.FlushLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.MaxFlushRate.GetAsFloat())
		assert.Equal(t, false, qc.CompactionLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.MaxCompactionRate.GetAsFloat())
48 49 50
	})

	t.Run("test dml", func(t *testing.T) {
51 52 53 54 55 56 57
		assert.Equal(t, false, qc.DMLLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.DMLMaxInsertRate.GetAsFloat())
		assert.Equal(t, defaultMin, qc.DMLMinInsertRate.GetAsFloat())
		assert.Equal(t, defaultMax, qc.DMLMaxDeleteRate.GetAsFloat())
		assert.Equal(t, defaultMin, qc.DMLMinDeleteRate.GetAsFloat())
		assert.Equal(t, defaultMax, qc.DMLMaxBulkLoadRate.GetAsFloat())
		assert.Equal(t, defaultMin, qc.DMLMinBulkLoadRate.GetAsFloat())
58 59 60
	})

	t.Run("test dql", func(t *testing.T) {
61 62 63 64 65
		assert.Equal(t, false, qc.DQLLimitEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.DQLMaxSearchRate.GetAsFloat())
		assert.Equal(t, defaultMin, qc.DQLMinSearchRate.GetAsFloat())
		assert.Equal(t, defaultMax, qc.DQLMaxQueryRate.GetAsFloat())
		assert.Equal(t, defaultMin, qc.DQLMinQueryRate.GetAsFloat())
66 67 68
	})

	t.Run("test limits", func(t *testing.T) {
69
		assert.Equal(t, 65535, qc.MaxCollectionNum.GetAsInt())
70 71
	})

B
bigsheeper 已提交
72
	t.Run("test limit writing", func(t *testing.T) {
73 74 75 76 77 78 79 80 81
		assert.False(t, qc.ForceDenyWriting.GetAsBool())
		assert.Equal(t, false, qc.TtProtectionEnabled.GetAsBool())
		assert.Equal(t, math.MaxInt64, qc.MaxTimeTickDelay.GetAsInt())
		assert.Equal(t, defaultLowWaterLevel, qc.DataNodeMemoryLowWaterLevel.GetAsFloat())
		assert.Equal(t, defaultHighWaterLevel, qc.DataNodeMemoryHighWaterLevel.GetAsFloat())
		assert.Equal(t, defaultLowWaterLevel, qc.QueryNodeMemoryLowWaterLevel.GetAsFloat())
		assert.Equal(t, defaultHighWaterLevel, qc.QueryNodeMemoryHighWaterLevel.GetAsFloat())
		assert.Equal(t, true, qc.DiskProtectionEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.DiskQuota.GetAsFloat())
82 83
	})

B
bigsheeper 已提交
84
	t.Run("test limit reading", func(t *testing.T) {
85 86 87 88 89 90 91
		assert.False(t, qc.ForceDenyReading.GetAsBool())
		assert.Equal(t, false, qc.QueueProtectionEnabled.GetAsBool())
		assert.Equal(t, int64(math.MaxInt64), qc.NQInQueueThreshold.GetAsInt64())
		assert.Equal(t, defaultMax, qc.QueueLatencyThreshold.GetAsFloat())
		assert.Equal(t, false, qc.ResultProtectionEnabled.GetAsBool())
		assert.Equal(t, defaultMax, qc.MaxReadResultRate.GetAsFloat())
		assert.Equal(t, 0.9, qc.CoolOffSpeed.GetAsFloat())
92 93
	})
}