Skip to content

Commit

Permalink
CI: wait-for rather than 'assume' in Online DDL flow (#16210)
Browse files Browse the repository at this point in the history
Signed-off-by: Shlomi Noach <2607934+shlomi-noach@users.noreply.github.com>
  • Loading branch information
shlomi-noach authored Jun 17, 2024
1 parent 6f85089 commit 135a6a8
Showing 1 changed file with 19 additions and 6 deletions.
25 changes: 19 additions & 6 deletions go/test/endtoend/onlineddl/flow/onlineddl_flow_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -304,13 +304,26 @@ func TestSchemaChange(t *testing.T) {
}
waitForThrottleCheckStatus(t, throttlerapp.OnlineDDLName, primaryTablet, http.StatusOK)
})
t.Run("additional wait", func(t *testing.T) {
// Waiting just so that we generate more DMLs, and give migration/vreplication
t.Run("apply more DML", func(t *testing.T) {
// Looking to run a substantial amount of DML, giving vreplication
// more "opportunities" to throttle or to make progress.
select {
case <-time.After(3 * time.Second):
case <-ctx.Done():
require.Fail(t, "context cancelled")
ctx, cancel := context.WithTimeout(context.Background(), time.Minute)
defer cancel()
ticker := time.NewTicker(time.Second)
defer ticker.Stop()

startDML := totalAppliedDML.Load()
for {
appliedDML := totalAppliedDML.Load()
if appliedDML-startDML >= int64(maxTableRows) {
// We have generated enough DMLs
return
}
select {
case <-ticker.C:
case <-ctx.Done():
require.Fail(t, "timeout waiting for applied DML")
}
}
})
t.Run("validate applied DML", func(t *testing.T) {
Expand Down

0 comments on commit 135a6a8

Please sign in to comment.