Skip to content

Commit

Permalink
test: make TestOperatorTestSuite more stable (#7268)
Browse files Browse the repository at this point in the history
close #7171

Signed-off-by: lhy1024 <[email protected]>
  • Loading branch information
lhy1024 authored Oct 26, 2023
1 parent 42782d4 commit 092ec86
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 15 deletions.
6 changes: 0 additions & 6 deletions pkg/mcs/scheduling/server/server.go
Original file line number Diff line number Diff line change
Expand Up @@ -504,12 +504,6 @@ func (s *Server) stopWatcher() {
s.metaWatcher.Close()
}

// GetPersistConfig returns the persist config.
// It's used to test.
func (s *Server) GetPersistConfig() *config.PersistConfig {
return s.persistConfig
}

// CreateServer creates the Server
func CreateServer(ctx context.Context, cfg *config.Config) *Server {
svr := &Server{
Expand Down
2 changes: 1 addition & 1 deletion tests/integrations/mcs/scheduling/server_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -509,6 +509,6 @@ func checkOperatorFail(re *require.Assertions, oc *operator.Controller, op *oper

func waitSyncFinish(re *require.Assertions, tc *tests.TestSchedulingCluster, typ storelimit.Type, expectedLimit float64) {
testutil.Eventually(re, func() bool {
return tc.GetPrimaryServer().GetPersistConfig().GetStoreLimitByType(2, typ) == expectedLimit
return tc.GetPrimaryServer().GetCluster().GetSharedConfig().GetStoreLimitByType(2, typ) == expectedLimit
})
}
8 changes: 8 additions & 0 deletions tests/pdctl/operator/operator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import (
"github.com/pingcap/kvproto/pkg/metapb"
"github.com/stretchr/testify/suite"
"github.com/tikv/pd/pkg/core"
"github.com/tikv/pd/pkg/utils/testutil"
"github.com/tikv/pd/server/config"
"github.com/tikv/pd/tests"
"github.com/tikv/pd/tests/pdctl"
Expand Down Expand Up @@ -221,6 +222,13 @@ func (suite *operatorTestSuite) checkOperator(cluster *tests.TestCluster) {

_, err = pdctl.ExecuteCommand(cmd, "config", "set", "enable-placement-rules", "true")
re.NoError(err)
if sche := cluster.GetSchedulingPrimaryServer(); sche != nil {
// wait for the scheduler server to update the config
testutil.Eventually(re, func() bool {
return sche.GetCluster().GetCheckerConfig().IsPlacementRulesEnabled()
})
}

output, err = pdctl.ExecuteCommand(cmd, "operator", "add", "transfer-region", "1", "2", "3")
re.NoError(err)
re.Contains(string(output), "not supported")
Expand Down
4 changes: 1 addition & 3 deletions tests/pdctl/scheduler/scheduler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -472,10 +472,8 @@ func (suite *schedulerTestSuite) checkSchedulerDiagnostic(cluster *tests.TestClu
result := make(map[string]interface{})
testutil.Eventually(re, func() bool {
mightExec(re, cmd, []string{"-u", pdAddr, "scheduler", "describe", schedulerName}, &result)
return len(result) != 0
return len(result) != 0 && expectedStatus == result["status"] && expectedSummary == result["summary"]
}, testutil.WithTickInterval(50*time.Millisecond))
re.Equal(expectedStatus, result["status"])
re.Equal(expectedSummary, result["summary"])
}

stores := []*metapb.Store{
Expand Down
42 changes: 37 additions & 5 deletions tests/server/api/operator_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
package api

import (
"encoding/json"
"errors"
"fmt"
"net/http"
Expand Down Expand Up @@ -73,6 +74,7 @@ func (suite *operatorTestSuite) TestOperator() {

func (suite *operatorTestSuite) checkAddRemovePeer(cluster *tests.TestCluster) {
re := suite.Require()
suite.pauseRuleChecker(cluster)
stores := []*metapb.Store{
{
Id: 1,
Expand Down Expand Up @@ -106,6 +108,8 @@ func (suite *operatorTestSuite) checkAddRemovePeer(cluster *tests.TestCluster) {
ConfVer: 1,
Version: 1,
},
StartKey: []byte("a"),
EndKey: []byte("b"),
}
regionInfo := core.NewRegionInfo(region, peer1)
tests.MustPutRegionInfo(re, cluster, regionInfo)
Expand Down Expand Up @@ -176,6 +180,7 @@ func (suite *operatorTestSuite) checkAddRemovePeer(cluster *tests.TestCluster) {

func (suite *operatorTestSuite) checkMergeRegionOperator(cluster *tests.TestCluster) {
re := suite.Require()
suite.pauseRuleChecker(cluster)
r1 := core.NewTestRegionInfo(10, 1, []byte(""), []byte("b"), core.SetWrittenBytes(1000), core.SetReadBytes(1000), core.SetRegionConfVer(1), core.SetRegionVersion(1))
tests.MustPutRegionInfo(re, cluster, r1)
r2 := core.NewTestRegionInfo(20, 1, []byte("b"), []byte("c"), core.SetWrittenBytes(2000), core.SetReadBytes(0), core.SetRegionConfVer(2), core.SetRegionVersion(3))
Expand All @@ -201,6 +206,7 @@ func (suite *operatorTestSuite) checkMergeRegionOperator(cluster *tests.TestClus

func (suite *operatorTestSuite) checkTransferRegionWithPlacementRule(cluster *tests.TestCluster) {
re := suite.Require()
suite.pauseRuleChecker(cluster)
stores := []*metapb.Store{
{
Id: 1,
Expand Down Expand Up @@ -239,6 +245,8 @@ func (suite *operatorTestSuite) checkTransferRegionWithPlacementRule(cluster *te
ConfVer: 1,
Version: 1,
},
StartKey: []byte("a"),
EndKey: []byte("b"),
}
tests.MustPutRegionInfo(re, cluster, core.NewRegionInfo(region, peer1))

Expand Down Expand Up @@ -408,13 +416,24 @@ func (suite *operatorTestSuite) checkTransferRegionWithPlacementRule(cluster *te
},
}
svr := cluster.GetLeaderServer()
url := fmt.Sprintf("%s/pd/api/v1/config", svr.GetAddr())
for _, testCase := range testCases {
suite.T().Log(testCase.name)
// TODO: remove this after we can sync this config to all servers.
if sche := cluster.GetSchedulingPrimaryServer(); sche != nil {
sche.GetCluster().GetSchedulerConfig().SetPlacementRuleEnabled(testCase.placementRuleEnable)
data := make(map[string]interface{})
if testCase.placementRuleEnable {
data["enable-placement-rules"] = "true"
} else {
svr.GetRaftCluster().GetOpts().SetPlacementRuleEnabled(testCase.placementRuleEnable)
data["enable-placement-rules"] = "false"
}
reqData, e := json.Marshal(data)
re.NoError(e)
err := tu.CheckPostJSON(testDialClient, url, reqData, tu.StatusOK(re))
re.NoError(err)
if sche := cluster.GetSchedulingPrimaryServer(); sche != nil {
// wait for the scheduler server to update the config
tu.Eventually(re, func() bool {
return sche.GetCluster().GetCheckerConfig().IsPlacementRulesEnabled() == testCase.placementRuleEnable
})
}
manager := svr.GetRaftCluster().GetRuleManager()
if sche := cluster.GetSchedulingPrimaryServer(); sche != nil {
Expand All @@ -436,7 +455,6 @@ func (suite *operatorTestSuite) checkTransferRegionWithPlacementRule(cluster *te
err = manager.DeleteRule("pd", "default")
suite.NoError(err)
}
var err error
if testCase.expectedError == nil {
err = tu.CheckPostJSON(testDialClient, fmt.Sprintf("%s/operators", urlPrefix), testCase.input, tu.StatusOK(re))
} else {
Expand All @@ -457,3 +475,17 @@ func (suite *operatorTestSuite) checkTransferRegionWithPlacementRule(cluster *te
suite.NoError(err)
}
}

// pauseRuleChecker will pause rule checker to avoid unexpected operator.
func (suite *operatorTestSuite) pauseRuleChecker(cluster *tests.TestCluster) {
re := suite.Require()
checkerName := "rule"
addr := cluster.GetLeaderServer().GetAddr()
resp := make(map[string]interface{})
url := fmt.Sprintf("%s/pd/api/v1/checker/%s", addr, checkerName)
err := tu.CheckPostJSON(testDialClient, url, []byte(`{"delay":1000}`), tu.StatusOK(re))
re.NoError(err)
err = tu.ReadGetJSON(re, testDialClient, url, &resp)
re.NoError(err)
re.True(resp["paused"].(bool))
}

0 comments on commit 092ec86

Please sign in to comment.