Skip to content

Commit

Permalink
backupccl: deflake TestScheduleChainingLifecycle
Browse files Browse the repository at this point in the history
This patch will skip the test if the machine clock is close to midnight, and
increases the frequency of incremental backups to run every 2 minutes.

Previously, the backup schedule in this test used the following crontab
recurrence: '*/5 * * * *'. In english, this means "run a full backup now, and
then run a full backup every day at midnight, and an incremental every 5
minutes. This test also relies on an incremental backup running after the first
full backup. But, what happens if the first full backup gets scheduled to run
within 5 minutes of midnight? A second full backup may get scheduled before the
expected incremental backup, breaking the invariant the test expects.

Fixes cockroachdb#88575 cockroachdb#95186

Release note: None
  • Loading branch information
msbutler committed Jan 20, 2023
1 parent b861696 commit a7f1750
Showing 1 changed file with 15 additions and 1 deletion.
16 changes: 15 additions & 1 deletion pkg/ccl/backupccl/schedule_pts_chaining_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import (
"github.com/cockroachdb/cockroach/pkg/sql/isql"
"github.com/cockroachdb/cockroach/pkg/sql/sem/tree"
"github.com/cockroachdb/cockroach/pkg/testutils"
"github.com/cockroachdb/cockroach/pkg/testutils/skip"
"github.com/cockroachdb/cockroach/pkg/util/hlc"
"github.com/cockroachdb/cockroach/pkg/util/leaktest"
"github.com/cockroachdb/cockroach/pkg/util/log"
Expand All @@ -43,7 +44,7 @@ func (th *testHelper) createSchedules(
}
backupQuery := fmt.Sprintf("%s%s", backupStmt, backupOpts)
schedules, err := th.createBackupSchedule(t,
fmt.Sprintf("CREATE SCHEDULE FOR %s RECURRING '*/5 * * * *'", backupQuery))
fmt.Sprintf("CREATE SCHEDULE FOR %s RECURRING '*/2 * * * *'", backupQuery))
require.NoError(t, err)

// We expect full & incremental schedule to be created.
Expand Down Expand Up @@ -94,6 +95,19 @@ func TestScheduleChainingLifecycle(t *testing.T) {
th, cleanup := newTestHelper(t)
defer cleanup()

roundedCurrentTime := th.cfg.DB.KV().Clock().PhysicalTime().Round(time.Minute * 5)
if roundedCurrentTime.Hour() == 0 && roundedCurrentTime.Minute() == 0 {
// The backup schedule in this test uses the following crontab recurrence:
// '*/2 * * * *'. In english, this means "run a full backup now, and then
// run a full backup every day at midnight, and an incremental every 2
// minutes. This test relies on an incremental backup running after the
// first full backup. But, what happens if the first full backup gets
// scheduled to run within 5 minutes of midnight? A second full backup may
// get scheduled before the expected incremental backup, breaking the
// invariant the test expects. For this reason, skip the test if it's
// running close to midnight #spooky.
skip.WithIssue(t, 91640, "test flakes when the machine clock is too close to midnight")
}
th.sqlDB.Exec(t, `
CREATE DATABASE db;
USE db;
Expand Down

0 comments on commit a7f1750

Please sign in to comment.