Skip to content

Commit

Permalink
cli: fix debug zip with new columns for cluster settings
Browse files Browse the repository at this point in the history
The addition of new columns on cluster_settings view done
on #104449 were causing debug zip fails to add the
information from that table, since the query used to
gather the information was doing a join and not considering
the new columns.

This commit updates the query to use the explicit columns,
so even if new columns are added it won't be a problem in the future.
It also adds tests for all custom querys used to generate the
debug zip, so this type of issue would have been caught.

Fixes #107103

Release note (bug fix): Debug zip now are properly showing the
information from cluster_settings.
  • Loading branch information
maryliag committed Jul 18, 2023
1 parent 25855ac commit 5173754
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 2 deletions.
4 changes: 2 additions & 2 deletions pkg/cli/zip_table_registry.go
Original file line number Diff line number Diff line change
Expand Up @@ -217,12 +217,12 @@ var zipInternalTablesPerCluster = DebugZipTableRegistry{
},
},
"crdb_internal.cluster_settings": {
customQueryRedacted: `SELECT * FROM (
customQueryRedacted: `SELECT variable, value, type, public, description, default_value, origin FROM (
SELECT *
FROM crdb_internal.cluster_settings
WHERE type <> 's'
) UNION (
SELECT variable, '<redacted>' as value, type, public, description
SELECT variable, '<redacted>' as value, type, public, description, default_value, origin
FROM crdb_internal.cluster_settings g
WHERE type = 's'
)`,
Expand Down
37 changes: 37 additions & 0 deletions pkg/cli/zip_table_registry_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,17 @@
package cli

import (
"context"
"fmt"
"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"
"testing"

"github.com/cockroachdb/cockroach/pkg/util/leaktest"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)

func TestQueryForTable(t *testing.T) {
Expand Down Expand Up @@ -134,3 +140,34 @@ 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)
}

0 comments on commit 5173754

Please sign in to comment.