Skip to content

Commit

Permalink
Merge pull request #21392 from benesch/speed-up-part-tests
Browse files Browse the repository at this point in the history
sqlccl: speed up partitioning tests
  • Loading branch information
benesch authored Jan 16, 2018
2 parents fb1a667 + 5c3d4ce commit 7ce795a
Showing 1 changed file with 24 additions and 28 deletions.
52 changes: 24 additions & 28 deletions pkg/ccl/sqlccl/partition_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1061,18 +1061,14 @@ func verifyScansOnNode(db *gosql.DB, query string, node string) error {
return nil
}

func TestInitialPartitioning(t *testing.T) {
defer leaktest.AfterTest(t)()
rng, _ := randutil.NewPseudoRand()

func setupPartitioningTestCluster(ctx context.Context, t testing.TB) (*sqlutils.SQLRunner, func()) {
cfg := config.DefaultZoneConfig()
cfg.NumReplicas = 1
defer config.TestingSetDefaultZoneConfig(cfg)()
resetZoneConfig := config.TestingSetDefaultZoneConfig(cfg)

ctx := context.Background()
tsArgs := func(attr string) base.TestServerArgs {
return base.TestServerArgs{
ScanInterval: time.Second,
ScanInterval: 100 * time.Millisecond,
StoreSpecs: []base.StoreSpec{
{InMemory: true, Attributes: roachpb.Attributes{Attrs: []string{attr}}},
},
Expand All @@ -1084,12 +1080,30 @@ func TestInitialPartitioning(t *testing.T) {
2: tsArgs("n3"),
}}
tc := testcluster.StartTestCluster(t, 3, tcArgs)
defer tc.Stopper().Stop(context.Background())

sqlDB := sqlutils.MakeSQLRunner(tc.Conns[0])
sqlDB.Exec(t, `CREATE DATABASE data`)
sqlDB.Exec(t, `USE data`)

// Disabling store throttling vastly speeds up rebalancing.
sqlDB.Exec(t, `SET CLUSTER SETTING server.declined_reservation_timeout = '0s'`)
sqlDB.Exec(t, `SET CLUSTER SETTING server.failed_reservation_timeout = '0s'`)

return sqlDB, func() {
tc.Stopper().Stop(context.Background())
resetZoneConfig()
}
}

func TestInitialPartitioning(t *testing.T) {
defer leaktest.AfterTest(t)()
rng, _ := randutil.NewPseudoRand()
testCases := allPartitioningTests(rng)

ctx := context.Background()
sqlDB, cleanup := setupPartitioningTestCluster(ctx, t)
defer cleanup()

for _, test := range testCases {
if len(test.scans) == 0 {
continue
Expand Down Expand Up @@ -1189,27 +1203,9 @@ func TestRepartitioning(t *testing.T) {
t.Fatalf("%+v", err)
}

cfg := config.DefaultZoneConfig()
cfg.NumReplicas = 1
defer config.TestingSetDefaultZoneConfig(cfg)()

ctx := context.Background()
tsArgs := func(attr string) base.TestServerArgs {
return base.TestServerArgs{
ScanInterval: time.Second,
StoreSpecs: []base.StoreSpec{
{InMemory: true, Attributes: roachpb.Attributes{Attrs: []string{attr}}},
},
}
}
tcArgs := base.TestClusterArgs{ServerArgsPerNode: map[int]base.TestServerArgs{
0: tsArgs("n1"),
1: tsArgs("n2"),
2: tsArgs("n3"),
}}
tc := testcluster.StartTestCluster(t, 3, tcArgs)
defer tc.Stopper().Stop(context.Background())
sqlDB := sqlutils.MakeSQLRunner(tc.Conns[0])
sqlDB, cleanup := setupPartitioningTestCluster(ctx, t)
defer cleanup()

for _, test := range testCases {
t.Run(fmt.Sprintf("%s/%s", test.old.name, test.new.name), func(t *testing.T) {
Expand Down

0 comments on commit 7ce795a

Please sign in to comment.