Skip to content

Commit

Permalink
Add test for partial stop/start to existing e2e test
Browse files Browse the repository at this point in the history
Signed-off-by: Rohit Nayak <rohit@planetscale.com>
  • Loading branch information
rohit-nayak-ps committed Jan 22, 2025
1 parent bf63050 commit 3b83410
Showing 1 changed file with 23 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import (
"testing"

"github.com/stretchr/testify/require"
"github.com/tidwall/gjson"
"golang.org/x/exp/maps"
"google.golang.org/protobuf/encoding/protojson"

Expand Down Expand Up @@ -501,6 +502,28 @@ func splitShard(t *testing.T, keyspace, workflowName, sourceShards, targetShards
waitForWorkflowState(t, vc, ksWorkflow, binlogdatapb.VReplicationWorkflowState_Stopped.String())
rs.Start()
waitForWorkflowState(t, vc, fmt.Sprintf("%s.%s", keyspace, workflowName), binlogdatapb.VReplicationWorkflowState_Running.String())

t.Run("Test --shards in workflow start/stop", func(t *testing.T) {
// This subtest expects workflow to be running at the start and restarts it at the end.
type tCase struct {
shards string
action string
expected int
}
testCases := []tCase{
{"-40", "stop", 1},
{"40-80", "stop", 1},
{"-40,40-80", "start", 2},
}
for _, tc := range testCases {
output, err := vc.VtctldClient.ExecuteCommandWithOutput("workflow", "--keyspace", keyspace, tc.action, "--workflow", workflowName, "--shards", tc.shards)
require.NoError(t, err, "failed to %s workflow: %v", tc.action, err)
cnt := gjson.Get(output, "details.#").Int()
require.EqualValuesf(t, tc.expected, cnt, "expected %d shards, got %d for action %s, shards %s", tc.expected, cnt, tc.action, tc.shards)
}
})
waitForWorkflowState(t, vc, fmt.Sprintf("%s.%s", keyspace, workflowName), binlogdatapb.VReplicationWorkflowState_Running.String())

for _, targetTab := range targetTabs {
catchup(t, targetTab, workflowName, "Reshard")
}
Expand Down

0 comments on commit 3b83410

Please sign in to comment.