diff --git a/pkg/cli/zip_table_registry.go b/pkg/cli/zip_table_registry.go index 6050c1d64f49..18d897012956 100644 --- a/pkg/cli/zip_table_registry.go +++ b/pkg/cli/zip_table_registry.go @@ -217,15 +217,15 @@ var zipInternalTablesPerCluster = DebugZipTableRegistry{ }, }, "crdb_internal.cluster_settings": { - customQueryRedacted: `SELECT * FROM ( - SELECT * - FROM crdb_internal.cluster_settings - WHERE type <> 's' - ) UNION ( - SELECT variable, '' as value, type, public, description - FROM crdb_internal.cluster_settings g - WHERE type = 's' - )`, + customQueryRedacted: `SELECT + variable, + CASE WHEN type = 's' THEN '' ELSE value END value, + type, + public, + description, + default_value, + origin + FROM crdb_internal.cluster_settings`, }, "crdb_internal.cluster_transactions": { // `last_auto_retry_reason` contains error text that may contain diff --git a/pkg/cli/zip_table_registry_test.go b/pkg/cli/zip_table_registry_test.go index 2596b7001ffd..9d653e28aecb 100644 --- a/pkg/cli/zip_table_registry_test.go +++ b/pkg/cli/zip_table_registry_test.go @@ -11,11 +11,18 @@ package cli import ( + "context" "fmt" "testing" + "github.com/cockroachdb/cockroach/pkg/base" + "github.com/cockroachdb/cockroach/pkg/sql/tests" + "github.com/cockroachdb/cockroach/pkg/testutils/serverutils" + "github.com/cockroachdb/cockroach/pkg/testutils/sqlutils" + "github.com/cockroachdb/cockroach/pkg/util/leaktest" "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" ) func TestQueryForTable(t *testing.T) { @@ -134,3 +141,36 @@ you must redact them at the SQL level.` } } } + +func executeAllCustomQuerys( + t *testing.T, sqlDB *sqlutils.SQLRunner, tableRegistry DebugZipTableRegistry, +) { + for table, regConfig := range tableRegistry { + if regConfig.customQueryRedacted != "" { + rows := sqlDB.Query(t, regConfig.customQueryRedacted) + require.NoError(t, rows.Err(), "failed to select for table %s redacted", table) + } + + if regConfig.customQueryUnredacted != "" { + rows := sqlDB.Query(t, regConfig.customQueryUnredacted) + require.NoError(t, rows.Err(), "failed to select for table %s unredacted", table) + } + } +} + +func TestCustomQuery(t *testing.T) { + defer leaktest.AfterTest(t)() + ctx := context.Background() + + params, _ := tests.CreateTestServerParams() + cluster := serverutils.StartNewTestCluster(t, 3 /* numNodes */, base.TestClusterArgs{ + ServerArgs: params, + }) + testConn := cluster.ServerConn(0 /* idx */) + sqlDB := sqlutils.MakeSQLRunner(testConn) + defer cluster.Stopper().Stop(ctx) + + executeAllCustomQuerys(t, sqlDB, zipInternalTablesPerCluster) + executeAllCustomQuerys(t, sqlDB, zipInternalTablesPerNode) + executeAllCustomQuerys(t, sqlDB, zipSystemTables) +}