From a7f1750c40d51dc152e89153898f2947d942ae7e Mon Sep 17 00:00:00 2001 From: Michael Butler Date: Fri, 20 Jan 2023 13:51:19 -0500 Subject: [PATCH] backupccl: deflake TestScheduleChainingLifecycle 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 #88575 #95186 Release note: None --- pkg/ccl/backupccl/schedule_pts_chaining_test.go | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/pkg/ccl/backupccl/schedule_pts_chaining_test.go b/pkg/ccl/backupccl/schedule_pts_chaining_test.go index 62b7c58c2116..0568ba85fd64 100644 --- a/pkg/ccl/backupccl/schedule_pts_chaining_test.go +++ b/pkg/ccl/backupccl/schedule_pts_chaining_test.go @@ -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" @@ -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. @@ -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;