Browse Source

test for multi dc replication

pull/1475/head
Chris Lu 4 years ago
parent
commit
12a8f5294d
  1. 2
      weed/shell/command_volume_balance.go
  2. 18
      weed/shell/command_volume_balance_test.go

2
weed/shell/command_volume_balance.go

@ -299,7 +299,7 @@ func isGoodMove(placement *super_block.ReplicaPlacement, existingReplicas []*Vol
return false return false
} }
if len(racks) > placement.DiffRackCount+1 {
if len(racks) > placement.DiffRackCount+placement.DiffDataCenterCount+1 {
return false return false
} }

18
weed/shell/command_volume_balance_test.go

@ -19,6 +19,24 @@ type testMoveCase struct {
func TestIsGoodMove(t *testing.T) { func TestIsGoodMove(t *testing.T) {
var tests = []testMoveCase{ var tests = []testMoveCase{
{
name: "test 100 move to spread into proper data centers",
replication: "100",
replicas: []*VolumeReplica{
{
location: &location{"dc1", "r1", &master_pb.DataNodeInfo{Id: "dn1"}},
},
{
location: &location{"dc1", "r2", &master_pb.DataNodeInfo{Id: "dn2"}},
},
},
sourceLocation: location{"dc1", "r2", &master_pb.DataNodeInfo{Id: "dn2"}},
targetLocation: location{"dc2", "r2", &master_pb.DataNodeInfo{Id: "dn3"}},
expected: true,
},
{ {
name: "test move to the same node", name: "test move to the same node",
replication: "001", replication: "001",

Loading…
Cancel
Save