Skip to content

Commit

Permalink
Add e2e test
Browse files Browse the repository at this point in the history
Signed-off-by: Matt Lord <mattalord@gmail.com>
  • Loading branch information
mattlord committed Jan 22, 2025
1 parent fbf4334 commit 59340f2
Showing 1 changed file with 33 additions and 5 deletions.
38 changes: 33 additions & 5 deletions go/test/endtoend/vreplication/vreplication_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -826,7 +826,35 @@ func shardCustomer(t *testing.T, testReverse bool, cells []*Cell, sourceCellOrAl
shardNames = append(shardNames, shardName)
}
testSwitchTrafficPermissionChecks(t, workflowType, sourceKs, shardNames, targetKs, workflow)
switchWrites(t, workflowType, ksWorkflow, false)

// Confirm that switching writes works as expected in the face of
// vreplication lag and cancelling the switch.
t.Run("validate switch writes", func(t *testing.T) {
// First let's test that the pre-checks work as expected.
// Lock the customer table so that we can't replicate the coming
// sentinal row.
productConn, err := productTab.TabletConn("product", true)
require.NoError(t, err)
defer productConn.Close()
customerConn, err := customerTab1.TabletConn("customer", true)
require.NoError(t, err)
execQuery(t, customerConn, "lock tables customer read")
// Insert that sentinal row on the source.
execQuery(t, productConn, "insert into customer(cid, name) values(9999999, 'laggingCustomer')")
// Sleep twice as long as we will set the max replication lag to.
lagDuration := 3 * time.Second
time.Sleep(lagDuration * 2)
_, err = vc.VtctldClient.ExecuteCommandWithOutput(workflowType, "--tablet-types=primary", "--workflow", workflow,
"--target-keyspace", targetKs, "SwitchWrites", "--timeout=30s", "--max-replication-lag-allowed", lagDuration.String())
require.Error(t, err)
t.Logf("expected error: %v", err)
execQuery(t, customerConn, "unlock tables")

// Now confirm that it works as expected.
catchup(t, customerTab1, workflow, workflowType)
catchup(t, customerTab2, workflow, workflowType)
switchWrites(t, workflowType, ksWorkflow, false)
})

checkThatVDiffFails(t, targetKs, workflow)

Expand Down Expand Up @@ -920,14 +948,14 @@ func shardCustomer(t *testing.T, testReverse bool, cells []*Cell, sourceCellOrAl

execVtgateQuery(t, vtgateConn, "customer", "delete from customer where name like 'tempCustomer%'")
waitForRowCountInTablet(t, customerTab1, "customer", "customer", 1)
waitForRowCountInTablet(t, customerTab2, "customer", "customer", 2)
waitForRowCount(t, vtgateConn, "customer", "customer.customer", 3)
waitForRowCountInTablet(t, customerTab2, "customer", "customer", 3)
waitForRowCount(t, vtgateConn, "customer", "customer.customer", 4)

query = "insert into customer (name, cid) values('george', 5)"
execVtgateQuery(t, vtgateConn, "customer", query)
waitForRowCountInTablet(t, customerTab1, "customer", "customer", 1)
waitForRowCountInTablet(t, customerTab2, "customer", "customer", 3)
waitForRowCount(t, vtgateConn, "customer", "customer.customer", 4)
waitForRowCountInTablet(t, customerTab2, "customer", "customer", 4)
waitForRowCount(t, vtgateConn, "customer", "customer.customer", 5)
}
})
}
Expand Down

0 comments on commit 59340f2

Please sign in to comment.