mirror of
https://github.com/talent-plan/tinykv.git
synced 2025-01-13 13:50:43 +08:00
5e089a2cd1
Signed-off-by: Connor <zbk602423539@gmail.com> Co-authored-by: Nick Cameron <nrc@ncameron.org> Co-authored-by: linning <linningde25@gmail.com> Co-authored-by: YangKeao <keao.yang@yahoo.com> Co-authored-by: andylokandy <andylokandy@hotmail.com> Co-authored-by: Iosmanthus Teng <myosmanthustree@gmail.com>
122 lines
4.0 KiB
Go
122 lines
4.0 KiB
Go
// Copyright 2016 PingCAP, Inc.
|
|
//
|
|
// Licensed 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,
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package server
|
|
|
|
import (
|
|
"github.com/pingcap-incubator/tinykv/proto/pkg/metapb"
|
|
"github.com/pingcap-incubator/tinykv/proto/pkg/schedulerpb"
|
|
"github.com/pingcap-incubator/tinykv/scheduler/pkg/testutil"
|
|
"github.com/pingcap-incubator/tinykv/scheduler/server/core"
|
|
. "github.com/pingcap/check"
|
|
)
|
|
|
|
var _ = Suite(&testClusterWorkerSuite{})
|
|
|
|
type testClusterWorkerSuite struct {
|
|
baseCluster
|
|
}
|
|
|
|
func (s *testClusterWorkerSuite) TestReportSplit(c *C) {
|
|
var cluster RaftCluster
|
|
left := &metapb.Region{Id: 1, StartKey: []byte("a"), EndKey: []byte("b")}
|
|
right := &metapb.Region{Id: 2, StartKey: []byte("b"), EndKey: []byte("c")}
|
|
_, err := cluster.handleReportSplit(&schedulerpb.ReportSplitRequest{Left: left, Right: right})
|
|
c.Assert(err, IsNil)
|
|
_, err = cluster.handleReportSplit(&schedulerpb.ReportSplitRequest{Left: right, Right: left})
|
|
c.Assert(err, NotNil)
|
|
}
|
|
|
|
func (s *testClusterWorkerSuite) TestValidRequestRegion(c *C) {
|
|
var err error
|
|
var cleanup func()
|
|
s.svr, cleanup, err = NewTestServer(c)
|
|
defer cleanup()
|
|
c.Assert(err, IsNil)
|
|
mustWaitLeader(c, []*Server{s.svr})
|
|
s.grpcSchedulerClient = testutil.MustNewGrpcClient(c, s.svr.GetAddr())
|
|
_, err = s.svr.bootstrapCluster(s.newBootstrapRequest(c, s.svr.clusterID, "127.0.0.1:0"))
|
|
c.Assert(err, IsNil)
|
|
|
|
cluster := s.svr.GetRaftCluster()
|
|
c.Assert(cluster, NotNil)
|
|
|
|
r1 := core.NewRegionInfo(&metapb.Region{
|
|
Id: 1,
|
|
StartKey: []byte(""),
|
|
EndKey: []byte("a"),
|
|
Peers: []*metapb.Peer{{
|
|
Id: 1,
|
|
StoreId: 1,
|
|
}},
|
|
RegionEpoch: &metapb.RegionEpoch{ConfVer: 2, Version: 2},
|
|
}, &metapb.Peer{
|
|
Id: 1,
|
|
StoreId: 1,
|
|
})
|
|
err = cluster.HandleRegionHeartbeat(r1)
|
|
c.Assert(err, IsNil)
|
|
r2 := &metapb.Region{Id: 2, StartKey: []byte("a"), EndKey: []byte("b")}
|
|
c.Assert(cluster.validRequestRegion(r2), NotNil)
|
|
r3 := &metapb.Region{Id: 1, StartKey: []byte(""), EndKey: []byte("a"), RegionEpoch: &metapb.RegionEpoch{ConfVer: 1, Version: 2}}
|
|
c.Assert(cluster.validRequestRegion(r3), NotNil)
|
|
r4 := &metapb.Region{Id: 1, StartKey: []byte(""), EndKey: []byte("a"), RegionEpoch: &metapb.RegionEpoch{ConfVer: 2, Version: 1}}
|
|
c.Assert(cluster.validRequestRegion(r4), NotNil)
|
|
r5 := &metapb.Region{Id: 1, StartKey: []byte(""), EndKey: []byte("a"), RegionEpoch: &metapb.RegionEpoch{ConfVer: 2, Version: 2}}
|
|
c.Assert(cluster.validRequestRegion(r5), IsNil)
|
|
cluster.stop()
|
|
}
|
|
|
|
func (s *testClusterWorkerSuite) TestAskSplit(c *C) {
|
|
var err error
|
|
var cleanup func()
|
|
s.svr, cleanup, err = NewTestServer(c)
|
|
defer cleanup()
|
|
c.Assert(err, IsNil)
|
|
mustWaitLeader(c, []*Server{s.svr})
|
|
s.grpcSchedulerClient = testutil.MustNewGrpcClient(c, s.svr.GetAddr())
|
|
bootstrapRequest := s.newBootstrapRequest(c, s.svr.clusterID, "127.0.0.1:0")
|
|
_, err = s.svr.bootstrapCluster(bootstrapRequest)
|
|
c.Assert(err, IsNil)
|
|
|
|
store := bootstrapRequest.Store
|
|
peer := s.newPeer(c, store.GetId(), 0)
|
|
region := s.newRegion(c, 0, []byte{}, []byte{}, []*metapb.Peer{peer}, nil)
|
|
err = s.svr.cluster.processRegionHeartbeat(core.NewRegionInfo(region, nil))
|
|
c.Assert(err, IsNil)
|
|
|
|
cluster := s.svr.GetRaftCluster()
|
|
c.Assert(cluster, NotNil)
|
|
regions := cluster.GetRegions()
|
|
|
|
req := &schedulerpb.AskSplitRequest{
|
|
Header: &schedulerpb.RequestHeader{
|
|
ClusterId: s.svr.ClusterID(),
|
|
},
|
|
Region: regions[0].GetMeta(),
|
|
}
|
|
|
|
_, err = cluster.handleAskSplit(req)
|
|
c.Assert(err, IsNil)
|
|
|
|
req1 := &schedulerpb.AskSplitRequest{
|
|
Header: &schedulerpb.RequestHeader{
|
|
ClusterId: s.svr.ClusterID(),
|
|
},
|
|
Region: regions[0].GetMeta(),
|
|
}
|
|
|
|
_, err = cluster.handleAskSplit(req1)
|
|
c.Assert(err, IsNil)
|
|
}
|