From b86338071d71a0cf9ecab32fd566c47840488613 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 21 Mar 2022 09:45:32 +0000 Subject: [PATCH 1/3] backupccl: add deprecation notice for `BACKUP TO` Informs: #78153 Release note (sql change): The `BACKUP TO` syntax to take backups is deprecated, and will be removed in a future release. Users are recommended to create a backup collection using the `BACKUP INTO` syntax in our docs. --- pkg/ccl/backupccl/backup_planning.go | 11 ++++++++++ .../backup-restore/backup-permissions | 22 +++++++++---------- .../testdata/backup-restore/column-families | 2 +- .../backup-restore/descriptor-broadening | 8 +++---- .../testdata/backup-restore/feature-flags | 4 ++-- .../testdata/backup-restore/max-row-size | 2 +- .../testdata/backup-restore/multiregion | 10 ++++----- .../testdata/backup-restore/restore-grants | 2 +- .../backup-restore/restore-permissions | 2 +- .../testdata/backup-restore/row_level_ttl | 4 ++-- .../testdata/backup-restore/temp-tables | 8 +++---- .../backup-restore/user-defined-types | 4 ++-- .../testdata/backup-restore/virtual-columns | 2 +- 13 files changed, 46 insertions(+), 35 deletions(-) diff --git a/pkg/ccl/backupccl/backup_planning.go b/pkg/ccl/backupccl/backup_planning.go index b6277556a213..49f1d21dac8c 100644 --- a/pkg/ccl/backupccl/backup_planning.go +++ b/pkg/ccl/backupccl/backup_planning.go @@ -45,6 +45,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/sql/catalog/tabledesc" "github.com/cockroachdb/cockroach/pkg/sql/pgwire/pgcode" "github.com/cockroachdb/cockroach/pkg/sql/pgwire/pgerror" + "github.com/cockroachdb/cockroach/pkg/sql/pgwire/pgnotice" "github.com/cockroachdb/cockroach/pkg/sql/privilege" "github.com/cockroachdb/cockroach/pkg/sql/sem/tree" "github.com/cockroachdb/cockroach/pkg/util/hlc" @@ -591,6 +592,16 @@ func backupPlanHook( return nil, nil, nil, false, err } + // Deprecation notice for `BACKUP TO` syntax. Remove this once the syntax is + // deleted in 22.2. + if !backupStmt.Nested { + p.BufferClientNotice(ctx, + pgnotice.Newf("The `BACKUP TO` syntax will be removed in a future release, please"+ + " switch over to using `BACKUP INTO` to create a backup collection: %s. "+ + "Backups created using the `BACKUP TO` syntax may not be restoreable in the next major version release.", + "https://www.cockroachlabs.com/docs/stable/backup.html#considerations")) + } + var err error subdirFn := func() (string, error) { return "", nil } if backupStmt.Subdir != nil { diff --git a/pkg/ccl/backupccl/testdata/backup-restore/backup-permissions b/pkg/ccl/backupccl/testdata/backup-restore/backup-permissions index cedacf4c5fc2..e6e2c68b60fc 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/backup-permissions +++ b/pkg/ccl/backupccl/testdata/backup-restore/backup-permissions @@ -15,7 +15,7 @@ SET enable_implicit_transaction_for_batch_statements = true # BACKUP is not allowed in a batch-statement. exec-sql -BACKUP TO 'nodelocal://0/test-root/'; +BACKUP INTO 'nodelocal://0/test-root/'; SELECT 1; ---- pq: BACKUP cannot be used inside a multi-statement transaction without DETACHED option @@ -26,7 +26,7 @@ SET enable_implicit_transaction_for_batch_statements = false # Cluster backup should succeed as a root user. exec-sql -BACKUP TO 'nodelocal://0/test-root/' +BACKUP INTO 'nodelocal://0/test-root/' ---- # Backups should succeed as a non-root user with admin role. @@ -36,15 +36,15 @@ GRANT ADMIN TO testuser; ---- exec-sql user=testuser -BACKUP TO 'nodelocal://0/test-nonroot-cluster'; +BACKUP INTO 'nodelocal://0/test-nonroot-cluster'; ---- exec-sql user=testuser -BACKUP DATABASE d TO 'nodelocal://0/test-nonroot-db'; +BACKUP DATABASE d INTO 'nodelocal://0/test-nonroot-db'; ---- exec-sql user=testuser -BACKUP TABLE d.t TO 'nodelocal://0/test-nonroot-table'; +BACKUP TABLE d.t INTO 'nodelocal://0/test-nonroot-table'; ---- # Start a new cluster with the same IO dir. @@ -83,7 +83,7 @@ GRANT CONNECT ON DATABASE d2 TO testuser; # Table backup as a non-admin user should have SELECT privileges. exec-sql user=testuser -BACKUP TABLE d2.t TO 'nodelocal://0/d2-table' +BACKUP TABLE d2.t INTO 'nodelocal://0/d2-table' ---- pq: user testuser does not have SELECT privilege on relation t @@ -98,7 +98,7 @@ CREATE SCHEMA sc2; # Schema backup as a non-admin user should have USAGE privileges. exec-sql user=testuser -BACKUP DATABASE d2 TO 'nodelocal://0/d2-schema'; +BACKUP DATABASE d2 INTO 'nodelocal://0/d2-schema'; ---- pq: user testuser does not have USAGE privilege on schema sc2 @@ -116,7 +116,7 @@ REVOKE USAGE ON TYPE d2.greeting FROM public; # Type backup as a non-admin user should have USAGE privileges. exec-sql user=testuser -BACKUP DATABASE d2 TO 'nodelocal://0/d2-schema'; +BACKUP DATABASE d2 INTO 'nodelocal://0/d2-schema'; ---- pq: user testuser does not have USAGE privilege on type greeting @@ -126,11 +126,11 @@ GRANT USAGE ON TYPE d2.greeting TO testuser; # testuser should now have all the required privileges. exec-sql server=s2 user=testuser -BACKUP DATABASE d2 TO 'nodelocal://0/d2'; +BACKUP DATABASE d2 INTO 'nodelocal://0/d2'; ---- exec-sql server=s2 user=testuser -BACKUP TABLE d2.t TO 'nodelocal://0/d2-table'; +BACKUP TABLE d2.t INTO 'nodelocal://0/d2-table'; ---- exec-sql server=s2 user=testuser @@ -155,7 +155,7 @@ SHOW BACKUP 'http://COCKROACH_TEST_HTTP_SERVER/' pq: only users with the admin role are allowed to SHOW BACKUP from the specified http URI exec-sql user=testuser -BACKUP DATABASE d TO 'nodelocal://0/test3' +BACKUP DATABASE d INTO 'nodelocal://0/test3' ---- pq: only users with the admin role are allowed to BACKUP to the specified nodelocal URI diff --git a/pkg/ccl/backupccl/testdata/backup-restore/column-families b/pkg/ccl/backupccl/testdata/backup-restore/column-families index 8f873736de3d..cdd90a316ba8 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/column-families +++ b/pkg/ccl/backupccl/testdata/backup-restore/column-families @@ -29,7 +29,7 @@ SET CLUSTER SETTING bulkio.backup.merge_file_buffer_size = '1MiB'; ---- exec-sql -BACKUP cfs TO 'nodelocal://1/foo'; +BACKUP cfs INTO 'nodelocal://1/foo'; ---- exec-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/descriptor-broadening b/pkg/ccl/backupccl/testdata/backup-restore/descriptor-broadening index 848deb9392e3..11553de952e0 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/descriptor-broadening +++ b/pkg/ccl/backupccl/testdata/backup-restore/descriptor-broadening @@ -11,19 +11,19 @@ CREATE TABLE db1.t (a INT); ---- exec-sql -BACKUP DATABASE db1 TO 'nodelocal://1/backup'; +BACKUP DATABASE db1 INTO 'nodelocal://1/backup'; ---- exec-sql -BACKUP DATABASE db1,db2 TO 'nodelocal://1/backup'; +BACKUP DATABASE db1,db2 INTO LATEST IN 'nodelocal://1/backup'; ---- pq: previous backup does not contain the complete database "db2" exec-sql -BACKUP db1.t TO 'nodelocal://1/backup_2'; +BACKUP db1.t INTO 'nodelocal://1/backup_2'; ---- exec-sql -BACKUP DATABASE db1 TO 'nodelocal://1/backup_2'; +BACKUP DATABASE db1 INTO LATEST IN 'nodelocal://1/backup_2'; ---- pq: previous backup does not contain the complete database "db1" diff --git a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags index b014b12aef5e..8d2233aadf2d 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags +++ b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags @@ -13,7 +13,7 @@ SET CLUSTER SETTING feature.backup.enabled = FALSE; ---- exec-sql -BACKUP TO 'nodelocal://0/test-root/'; +BACKUP INTO 'nodelocal://0/test-root/'; ---- pq: feature BACKUP was disabled by the database administrator @@ -23,7 +23,7 @@ SET CLUSTER SETTING feature.backup.enabled = TRUE; ---- exec-sql -BACKUP TO 'nodelocal://0/test-root/'; +BACKUP INTO 'nodelocal://0/test-root/'; ---- exec-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/max-row-size b/pkg/ccl/backupccl/testdata/backup-restore/max-row-size index 8fc41a66c586..f8be2751b363 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/max-row-size +++ b/pkg/ccl/backupccl/testdata/backup-restore/max-row-size @@ -23,7 +23,7 @@ INSERT INTO maxrow VALUES (2, repeat('x', 20000)) pq: row larger than max row size: table 109 family 0 primary key /Table/109/1/2/0 size 20013 exec-sql -BACKUP maxrow TO 'nodelocal://1/maxrow'; +BACKUP maxrow INTO 'nodelocal://1/maxrow'; ---- exec-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/multiregion b/pkg/ccl/backupccl/testdata/backup-restore/multiregion index eee1bc5e5ae4..6a63f5ea44e9 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/multiregion +++ b/pkg/ccl/backupccl/testdata/backup-restore/multiregion @@ -15,11 +15,11 @@ us-east-1 us-west-1 exec-sql -BACKUP DATABASE d TO 'nodelocal://1/database_backup/'; +BACKUP DATABASE d INTO 'nodelocal://1/database_backup/'; ---- exec-sql -BACKUP TO 'nodelocal://1/full_cluster_backup/'; +BACKUP INTO 'nodelocal://1/full_cluster_backup/'; ---- # A new cluster with the same locality settings. @@ -77,11 +77,11 @@ INSERT INTO no_region_db_2.t VALUES (1), (2), (3); ---- exec-sql -BACKUP DATABASE no_region_db TO 'nodelocal://1/no_region_database_backup/'; +BACKUP DATABASE no_region_db INTO 'nodelocal://1/no_region_database_backup/'; ---- exec-sql -BACKUP TO 'nodelocal://1/no_region_cluster_backup/'; +BACKUP INTO 'nodelocal://1/no_region_cluster_backup/'; ---- exec-sql @@ -136,7 +136,7 @@ INSERT INTO eu_central_db.t VALUES (1), (2), (3); NOTICE: setting eu-central-1 as the PRIMARY REGION as no PRIMARY REGION was specified exec-sql -BACKUP DATABASE eu_central_db TO 'nodelocal://1/eu_central_database_backup/'; +BACKUP DATABASE eu_central_db INTO 'nodelocal://1/eu_central_database_backup/'; ---- # New cluster for a cluster backup. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/restore-grants b/pkg/ccl/backupccl/testdata/backup-restore/restore-grants index 59617a755a0b..f2040fdca178 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/restore-grants +++ b/pkg/ccl/backupccl/testdata/backup-restore/restore-grants @@ -130,7 +130,7 @@ testdb sc othertable admin ALL true exec-sql -BACKUP TO 'nodelocal://0/test/' +BACKUP INTO 'nodelocal://0/test/' ---- # Ensure that testuser is indeed the owner of the type, but dropping it. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions b/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions index e7bfa75f7cf8..bedc9bfdd147 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions +++ b/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions @@ -9,7 +9,7 @@ INSERT INTO d.t VALUES (1), (2), (3); ---- exec-sql -BACKUP TO 'nodelocal://0/test/' +BACKUP INTO 'nodelocal://0/test/' ---- # Restores should succeed as a non-root user with admin role. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl b/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl index f7da8e077d4b..cb73c6e9d4c3 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl +++ b/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl @@ -8,11 +8,11 @@ CREATE TABLE t (id INT PRIMARY KEY) WITH (ttl_expire_after = '10 minutes') ---- exec-sql -BACKUP DATABASE d TO 'nodelocal://1/database_backup/' +BACKUP DATABASE d INTO 'nodelocal://1/database_backup/' ---- exec-sql -BACKUP TO 'nodelocal://1/full_cluster_backup/' +BACKUP INTO 'nodelocal://1/full_cluster_backup/' ---- new-server name=s2 share-io-dir=s1 allow-implicit-access diff --git a/pkg/ccl/backupccl/testdata/backup-restore/temp-tables b/pkg/ccl/backupccl/testdata/backup-restore/temp-tables index 675c59589f01..658dc03ed00d 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/temp-tables +++ b/pkg/ccl/backupccl/testdata/backup-restore/temp-tables @@ -33,16 +33,16 @@ pg_temp public exec-sql -BACKUP TABLE temp_table TO 'nodelocal://0/temp_table_backup' +BACKUP TABLE temp_table INTO 'nodelocal://0/temp_table_backup' ---- pq: failed to resolve targets specified in the BACKUP stmt: table "temp_table" does not exist, or invalid RESTORE timestamp: supplied backups do not cover requested time exec-sql -BACKUP DATABASE d1 TO 'nodelocal://0/d1_backup/' +BACKUP DATABASE d1 INTO 'nodelocal://0/d1_backup/' ---- exec-sql -BACKUP d1.* TO 'nodelocal://0/d1_star_backup/' +BACKUP d1.* INTO 'nodelocal://0/d1_star_backup/' ---- exec-sql @@ -50,7 +50,7 @@ COMMENT ON TABLE temp_table IS 'should not show up in restore'; ---- exec-sql -BACKUP TO 'nodelocal://0/full_cluster_backup/'; +BACKUP INTO 'nodelocal://0/full_cluster_backup/'; ---- exec-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types b/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types index 4e6d0f1e9b26..557f085f8644 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types +++ b/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types @@ -20,7 +20,7 @@ INSERT INTO d2.t2 VALUES (ARRAY['bye']), (ARRAY['cya']); ---- exec-sql -BACKUP TO 'nodelocal://0/test/' +BACKUP INTO 'nodelocal://0/test/' ---- # Start a new cluster with the same IO dir. @@ -129,7 +129,7 @@ CREATE TABLE d.expr ( # Backup the database now. exec-sql -BACKUP DATABASE d TO 'nodelocal://0/test/' +BACKUP DATABASE d INTO LATEST IN 'nodelocal://0/test/' ---- exec-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns b/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns index 3a64f4f37016..1072437d8ef9 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns +++ b/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns @@ -18,7 +18,7 @@ INSERT INTO tab VALUES (1,1,1), (2,2,2), (3,3,3) ---- exec-sql -BACKUP TO 'nodelocal://0/test/' +BACKUP INTO 'nodelocal://0/test/' ---- # Start a new cluster with the same IO dir. From 947cb882e2aef6e230d8e9b41576b774d3a8e7e3 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 21 Mar 2022 11:18:33 +0000 Subject: [PATCH 2/3] backupccl: add deprecation notice to `RESTORE FROM` without subdir Informs: #78153 Release note (sql change): The `RESTORE FROM` syntax without an explicit subdirectory pointing to a backup in a collection is deprecated, and will be removed in a future release. Users are recommended to use `RESTORE FROM IN ` to restore a particular backup in a collection. --- pkg/ccl/backupccl/restore_planning.go | 7 +++++++ .../testdata/backup-restore/column-families | 2 +- .../testdata/backup-restore/feature-flags | 4 ++-- .../testdata/backup-restore/max-row-size | 2 +- .../testdata/backup-restore/multiregion | 16 ++++++++-------- .../testdata/backup-restore/restore-grants | 10 +++++----- .../testdata/backup-restore/restore-permissions | 14 +++++++------- .../testdata/backup-restore/row_level_ttl | 6 +++--- .../testdata/backup-restore/temp-tables | 6 +++--- .../testdata/backup-restore/user-defined-types | 6 +++--- .../testdata/backup-restore/virtual-columns | 2 +- 11 files changed, 41 insertions(+), 34 deletions(-) diff --git a/pkg/ccl/backupccl/restore_planning.go b/pkg/ccl/backupccl/restore_planning.go index f091d2f90434..f085cc2d9b20 100644 --- a/pkg/ccl/backupccl/restore_planning.go +++ b/pkg/ccl/backupccl/restore_planning.go @@ -1075,6 +1075,13 @@ func restorePlanHook( if err != nil { return nil, nil, nil, false, err } + } else { + // Deprecation notice for non-colelction `RESTORE FROM` syntax. Remove this + // once the syntax is deleted in 22.2. + p.BufferClientNotice(ctx, + pgnotice.Newf("Note the `RESTORE FROM ` syntax will be removed in a future release, please"+ + "switch over to using `RESTORE FROM IN ` to restore a particular backup from a collection: %s", + "https://www.cockroachlabs.com/docs/stable/restore.html#view-the-backup-subdirectories")) } var incStorageFn func() ([]string, error) diff --git a/pkg/ccl/backupccl/testdata/backup-restore/column-families b/pkg/ccl/backupccl/testdata/backup-restore/column-families index cdd90a316ba8..60946be7936b 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/column-families +++ b/pkg/ccl/backupccl/testdata/backup-restore/column-families @@ -37,7 +37,7 @@ CREATE DATABASE r1; ---- exec-sql -RESTORE cfs FROM 'nodelocal://1/foo' WITH into_db='r1'; +RESTORE cfs FROM LATEST IN 'nodelocal://1/foo' WITH into_db='r1'; ---- query-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags index 8d2233aadf2d..210675465e44 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags +++ b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags @@ -36,7 +36,7 @@ SET CLUSTER SETTING feature.restore.enabled = FALSE; ---- exec-sql -RESTORE TABLE d.t FROM 'nodelocal://0/test-root/'; +RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test-root/'; ---- pq: feature RESTORE was disabled by the database administrator @@ -46,5 +46,5 @@ SET CLUSTER SETTING feature.restore.enabled = TRUE; ---- exec-sql -RESTORE TABLE d.t FROM 'nodelocal://0/test-root/'; +RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test-root/'; ---- diff --git a/pkg/ccl/backupccl/testdata/backup-restore/max-row-size b/pkg/ccl/backupccl/testdata/backup-restore/max-row-size index f8be2751b363..b29110092c8c 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/max-row-size +++ b/pkg/ccl/backupccl/testdata/backup-restore/max-row-size @@ -31,7 +31,7 @@ CREATE DATABASE d2; ---- exec-sql -RESTORE maxrow FROM 'nodelocal://1/maxrow' WITH into_db='d2'; +RESTORE maxrow FROM LATEST IN 'nodelocal://1/maxrow' WITH into_db='d2'; ---- query-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/multiregion b/pkg/ccl/backupccl/testdata/backup-restore/multiregion index 6a63f5ea44e9..8b248b79f3d4 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/multiregion +++ b/pkg/ccl/backupccl/testdata/backup-restore/multiregion @@ -27,7 +27,7 @@ new-server name=s2 share-io-dir=s1 allow-implicit-access localities=us-east-1,us ---- exec-sql -RESTORE FROM 'nodelocal://0/full_cluster_backup/'; +RESTORE FROM LATEST IN 'nodelocal://0/full_cluster_backup/'; ---- exec-sql @@ -35,7 +35,7 @@ DROP DATABASE d; ---- exec-sql -RESTORE DATABASE d FROM 'nodelocal://0/database_backup/'; +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/database_backup/'; ---- query-sql @@ -52,13 +52,13 @@ new-server name=s3 share-io-dir=s1 allow-implicit-access localities=eu-central-1 ---- exec-sql -RESTORE DATABASE d FROM 'nodelocal://0/database_backup/'; +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/database_backup/'; ---- pq: detected a mismatch in regions between the restore cluster and the backup cluster, missing regions detected: us-east-1, us-west-1. HINT: there are two ways you can resolve this issue: 1) update the cluster to which you're restoring to ensure that the regions present on the nodes' --locality flags match those present in the backup image, or 2) restore with the "skip_localities_check" option exec-sql -RESTORE FROM 'nodelocal://0/full_cluster_backup/'; +RESTORE FROM LATEST IN 'nodelocal://0/full_cluster_backup/'; ---- pq: detected a mismatch in regions between the restore cluster and the backup cluster, missing regions detected: us-east-1, us-west-1. HINT: there are two ways you can resolve this issue: 1) update the cluster to which you're restoring to ensure that the regions present on the nodes' --locality flags match those present in the backup image, or 2) restore with the "skip_localities_check" option @@ -97,7 +97,7 @@ SET CLUSTER SETTING sql.defaults.primary_region = 'non-existent-region'; ---- exec-sql -RESTORE DATABASE no_region_db FROM 'nodelocal://1/no_region_database_backup/'; +RESTORE DATABASE no_region_db FROM LATEST IN 'nodelocal://1/no_region_database_backup/'; ---- pq: region "non-existent-region" does not exist HINT: valid regions: eu-central-1, eu-north-1 @@ -109,7 +109,7 @@ SET CLUSTER SETTING sql.defaults.primary_region = 'eu-central-1'; ---- exec-sql -RESTORE DATABASE no_region_db FROM 'nodelocal://1/no_region_database_backup/'; +RESTORE DATABASE no_region_db FROM LATEST IN 'nodelocal://1/no_region_database_backup/'; ---- NOTICE: setting the PRIMARY REGION as eu-central-1 on database no_region_db HINT: to change the default primary region, use SET CLUSTER SETTING sql.defaults.primary_region = 'region' or use RESET CLUSTER SETTING sql.defaults.primary_region to disable this behavior @@ -148,7 +148,7 @@ SET CLUSTER SETTING sql.defaults.primary_region = 'eu-north-1'; ---- exec-sql -RESTORE FROM 'nodelocal://1/no_region_cluster_backup/'; +RESTORE FROM LATEST IN 'nodelocal://1/no_region_cluster_backup/'; ---- NOTICE: setting the PRIMARY REGION as eu-north-1 on database defaultdb HINT: to change the default primary region, use SET CLUSTER SETTING sql.defaults.primary_region = 'region' or use RESET CLUSTER SETTING sql.defaults.primary_region to disable this behavior @@ -176,7 +176,7 @@ public t table root REGIONAL BY TABLE IN PRIMARY REGION # Check we can restore without triggering the default primary region. exec-sql -RESTORE DATABASE eu_central_db FROM 'nodelocal://1/eu_central_database_backup/'; +RESTORE DATABASE eu_central_db FROM LATEST IN 'nodelocal://1/eu_central_database_backup/'; ---- query-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/restore-grants b/pkg/ccl/backupccl/testdata/backup-restore/restore-grants index f2040fdca178..f59dbd38c4fa 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/restore-grants +++ b/pkg/ccl/backupccl/testdata/backup-restore/restore-grants @@ -148,7 +148,7 @@ GRANT CREATE ON DATABASE testuser_db TO testuser; ---- exec-sql user=testuser -RESTORE testdb.sc.othertable, testdb.testtable_greeting_usage FROM 'nodelocal://1/test' WITH into_db='testuser_db'; +RESTORE testdb.sc.othertable, testdb.testtable_greeting_usage FROM LATEST IN 'nodelocal://1/test' WITH into_db='testuser_db'; ---- # Check that user1 doesn't have any privs, but testuser should be the owner. @@ -211,7 +211,7 @@ GRANT CREATE ON DATABASE restoredb TO user1; ---- exec-sql -RESTORE testdb.sc.othertable, testdb.testtable_greeting_usage, testdb.testtable_greeting_owner FROM 'nodelocal://1/test' WITH into_db='restoredb'; +RESTORE testdb.sc.othertable, testdb.testtable_greeting_usage, testdb.testtable_greeting_owner FROM LATEST IN 'nodelocal://1/test' WITH into_db='restoredb'; ---- query-sql @@ -268,7 +268,7 @@ DROP DATABASE testdb CASCADE; ---- exec-sql -RESTORE DATABASE testdb FROM 'nodelocal://0/test/'; +RESTORE DATABASE testdb FROM LATEST IN 'nodelocal://0/test/'; ---- @@ -350,7 +350,7 @@ DROP DATABASE testdb CASCADE; # Now, let's restore a single database as a non-admin (testuser). exec-sql user=testuser -RESTORE DATABASE testdb FROM 'nodelocal://0/test/'; +RESTORE DATABASE testdb FROM LATEST IN 'nodelocal://0/test/'; ---- # Check that user1 doesn't have any privs. @@ -435,7 +435,7 @@ new-server name=s2 share-io-dir=s1 allow-implicit-access ---- exec-sql -RESTORE FROM 'nodelocal://0/test/'; +RESTORE FROM LATEST IN 'nodelocal://0/test/'; ---- # Check user1. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions b/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions index bedc9bfdd147..fb7849ef48ad 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions +++ b/pkg/ccl/backupccl/testdata/backup-restore/restore-permissions @@ -23,7 +23,7 @@ DROP DATABASE d; ---- exec-sql user=testuser -RESTORE DATABASE d FROM 'nodelocal://0/test/'; +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/test/'; ---- # Start a new cluster with the same IO dir. @@ -36,12 +36,12 @@ CREATE USER testuser # Restore into the new cluster. exec-sql server=s2 user=testuser -RESTORE FROM 'nodelocal://0/test/' +RESTORE FROM LATEST IN 'nodelocal://0/test/' ---- pq: only users with the admin role are allowed to restore full cluster backups exec-sql server=s2 user=testuser -RESTORE DATABASE d FROM 'nodelocal://0/test/' +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/test/' ---- pq: only users with the CREATEDB privilege can restore databases @@ -50,7 +50,7 @@ CREATE DATABASE d ---- exec-sql server=s2 user=testuser -RESTORE TABLE d.t FROM 'nodelocal://0/test/' +RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test/' ---- pq: user testuser does not have CREATE privilege on database d @@ -59,7 +59,7 @@ GRANT CREATE ON DATABASE d TO testuser ---- exec-sql server=s2 user=testuser -RESTORE TABLE d.t FROM 'nodelocal://0/test/' +RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test/' ---- query-sql server=s2 @@ -78,7 +78,7 @@ ALTER USER testuser CREATEDB ---- exec-sql server=s2 user=testuser -RESTORE DATABASE d FROM 'nodelocal://0/test/' +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/test/' ---- query-sql server=s2 @@ -97,6 +97,6 @@ CREATE USER testuser ---- exec-sql server=s3 user=testuser -RESTORE TABLE d.t FROM 'nodelocal://0/test/' +RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test/' ---- pq: only users with the admin role are allowed to RESTORE from the specified nodelocal URI diff --git a/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl b/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl index cb73c6e9d4c3..94d8571a77a6 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl +++ b/pkg/ccl/backupccl/testdata/backup-restore/row_level_ttl @@ -25,7 +25,7 @@ WHERE label LIKE 'row-level-ttl-%' 0 exec-sql -RESTORE FROM 'nodelocal://0/full_cluster_backup/' +RESTORE FROM LATEST IN 'nodelocal://0/full_cluster_backup/' ---- query-sql @@ -54,7 +54,7 @@ WHERE label LIKE 'row-level-ttl-%' 0 exec-sql -RESTORE DATABASE d FROM 'nodelocal://0/database_backup/' +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/database_backup/' ---- query-sql @@ -87,7 +87,7 @@ CREATE DATABASE d ---- exec-sql -RESTORE TABLE d.public.t FROM 'nodelocal://0/database_backup/' +RESTORE TABLE d.public.t FROM LATEST IN 'nodelocal://0/database_backup/' ---- query-sql diff --git a/pkg/ccl/backupccl/testdata/backup-restore/temp-tables b/pkg/ccl/backupccl/testdata/backup-restore/temp-tables index 658dc03ed00d..6418363b014f 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/temp-tables +++ b/pkg/ccl/backupccl/testdata/backup-restore/temp-tables @@ -59,7 +59,7 @@ DROP DATABASE d1 ---- exec-sql -RESTORE DATABASE d1 FROM 'nodelocal://0/d1_backup/' +RESTORE DATABASE d1 FROM LATEST IN 'nodelocal://0/d1_backup/' ---- exec-sql @@ -88,7 +88,7 @@ DROP DATABASE d1 ---- exec-sql -RESTORE DATABASE d1 FROM 'nodelocal://0/d1_star_backup/' +RESTORE DATABASE d1 FROM LATEST IN 'nodelocal://0/d1_star_backup/' ---- exec-sql @@ -120,7 +120,7 @@ USE defaultdb; ---- exec-sql -RESTORE FROM 'nodelocal://0/full_cluster_backup/'; +RESTORE FROM LATEST IN 'nodelocal://0/full_cluster_backup/'; ---- # The pg_temp schema from the BACKUP should show up in its original database. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types b/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types index 557f085f8644..a7cc238c26fa 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types +++ b/pkg/ccl/backupccl/testdata/backup-restore/user-defined-types @@ -29,7 +29,7 @@ new-server name=s2 share-io-dir=s1 # Restore into the new cluster. exec-sql server=s2 -RESTORE FROM 'nodelocal://0/test/' +RESTORE FROM LATEST IN 'nodelocal://0/test/' ---- # Check all of the tables have the right data. @@ -129,7 +129,7 @@ CREATE TABLE d.expr ( # Backup the database now. exec-sql -BACKUP DATABASE d INTO LATEST IN 'nodelocal://0/test/' +BACKUP DATABASE d INTO 'nodelocal://0/test/' ---- exec-sql @@ -137,7 +137,7 @@ DROP DATABASE d ---- exec-sql -RESTORE DATABASE d FROM 'nodelocal://0/test/'; +RESTORE DATABASE d FROM LATEST IN 'nodelocal://0/test/'; ---- # Check the table data. diff --git a/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns b/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns index 1072437d8ef9..37cdb14e1b2b 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns +++ b/pkg/ccl/backupccl/testdata/backup-restore/virtual-columns @@ -26,7 +26,7 @@ new-server name=s2 share-io-dir=s1 ---- exec-sql server=s2 -RESTORE FROM 'nodelocal://0/test/' +RESTORE FROM LATEST IN 'nodelocal://0/test/' ---- query-sql From b5b1dd9c24bfc8e81358e6ae1444abe7df5ac051 Mon Sep 17 00:00:00 2001 From: Aditya Maru Date: Mon, 21 Mar 2022 11:36:36 +0000 Subject: [PATCH 3/3] backupccl: add datadriven tests for deprecation notice Informs: #78153 Release note: None --- pkg/ccl/backupccl/restore_planning.go | 4 +-- .../testdata/backup-restore/feature-flags | 35 +++++++++++++++++++ 2 files changed, 37 insertions(+), 2 deletions(-) diff --git a/pkg/ccl/backupccl/restore_planning.go b/pkg/ccl/backupccl/restore_planning.go index f085cc2d9b20..da7d3b2a1ae8 100644 --- a/pkg/ccl/backupccl/restore_planning.go +++ b/pkg/ccl/backupccl/restore_planning.go @@ -1079,8 +1079,8 @@ func restorePlanHook( // Deprecation notice for non-colelction `RESTORE FROM` syntax. Remove this // once the syntax is deleted in 22.2. p.BufferClientNotice(ctx, - pgnotice.Newf("Note the `RESTORE FROM ` syntax will be removed in a future release, please"+ - "switch over to using `RESTORE FROM IN ` to restore a particular backup from a collection: %s", + pgnotice.Newf("The `RESTORE FROM ` syntax will be removed in a future release, please"+ + " switch over to using `RESTORE FROM IN ` to restore a particular backup from a collection: %s", "https://www.cockroachlabs.com/docs/stable/restore.html#view-the-backup-subdirectories")) } diff --git a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags index 210675465e44..19405d2621fd 100644 --- a/pkg/ccl/backupccl/testdata/backup-restore/feature-flags +++ b/pkg/ccl/backupccl/testdata/backup-restore/feature-flags @@ -1,3 +1,5 @@ +subtest backup-feature-flags + new-server name=s1 ---- @@ -48,3 +50,36 @@ SET CLUSTER SETTING feature.restore.enabled = TRUE; exec-sql RESTORE TABLE d.t FROM LATEST IN 'nodelocal://0/test-root/'; ---- + +subtest end + +# TODO(adityamaru): Delete in 22.2 once the syntax is removed. We don't want +# to start a testserver just for this test. +subtest backup-restore-deprecation-notice + +exec-sql +BACKUP TO 'nodelocal://1/deprecated'; +---- +NOTICE: The `BACKUP TO` syntax will be removed in a future release, please switch over to using `BACKUP INTO` to create a backup collection: https://www.cockroachlabs.com/docs/stable/backup.html#considerations. Backups created using the `BACKUP TO` syntax may not be restoreable in the next major version release. + +exec-sql +BACKUP TO 'nodelocal://1/deprecated/incfrom' INCREMENTAL FROM 'nodelocal://1/deprecated'; +---- +NOTICE: The `BACKUP TO` syntax will be removed in a future release, please switch over to using `BACKUP INTO` to create a backup collection: https://www.cockroachlabs.com/docs/stable/backup.html#considerations. Backups created using the `BACKUP TO` syntax may not be restoreable in the next major version release. + +exec-sql +DROP TABLE d.t; +---- + +exec-sql +RESTORE TABLE d.t FROM 'nodelocal://1/deprecated'; +---- +NOTICE: The `RESTORE FROM ` syntax will be removed in a future release, please switch over to using `RESTORE FROM IN ` to restore a particular backup from a collection: https://www.cockroachlabs.com/docs/stable/restore.html#view-the-backup-subdirectories + + +exec-sql +RESTORE SYSTEM USERS FROM 'nodelocal://1/deprecated'; +---- +NOTICE: The `RESTORE FROM ` syntax will be removed in a future release, please switch over to using `RESTORE FROM IN ` to restore a particular backup from a collection: https://www.cockroachlabs.com/docs/stable/restore.html#view-the-backup-subdirectories + +subtest end