From 1136a3d6f37fee9ab5a12093aa96a4700387bba0 Mon Sep 17 00:00:00 2001 From: Nathan <148575555+nathan-artie@users.noreply.github.com> Date: Mon, 22 Apr 2024 14:26:02 -0700 Subject: [PATCH] [sql] Kill `NameArgs.Escape` (#484) --- clients/bigquery/tableid.go | 2 +- clients/mssql/tableid.go | 2 +- clients/redshift/tableid.go | 2 +- clients/shared/merge.go | 2 +- clients/shared/utils.go | 2 +- clients/snowflake/staging.go | 1 - clients/snowflake/tableid.go | 2 +- lib/destination/ddl/ddl.go | 2 -- lib/destination/ddl/ddl_bq_test.go | 3 -- lib/destination/ddl/ddl_sflk_test.go | 3 +- lib/destination/dml/merge.go | 3 -- lib/destination/dml/merge_parts_test.go | 2 -- lib/destination/dml/merge_test.go | 2 -- lib/sql/escape.go | 4 +-- lib/sql/escape_test.go | 37 +++++++------------------ lib/typing/columns/columns.go | 2 +- lib/typing/columns/columns_test.go | 10 ------- lib/typing/columns/wrapper_test.go | 5 ---- 18 files changed, 20 insertions(+), 66 deletions(-) diff --git a/clients/bigquery/tableid.go b/clients/bigquery/tableid.go index ca3bcb53f..d7a4615e5 100644 --- a/clients/bigquery/tableid.go +++ b/clients/bigquery/tableid.go @@ -45,6 +45,6 @@ func (ti TableIdentifier) FullyQualifiedName() string { "`%s`.`%s`.%s", ti.projectID, ti.dataset, - sql.EscapeNameIfNecessary(ti.table, false, &sql.NameArgs{Escape: true, DestKind: constants.BigQuery}), + sql.EscapeNameIfNecessary(ti.table, false, &sql.NameArgs{DestKind: constants.BigQuery}), ) } diff --git a/clients/mssql/tableid.go b/clients/mssql/tableid.go index 37531185a..196f4080e 100644 --- a/clients/mssql/tableid.go +++ b/clients/mssql/tableid.go @@ -33,6 +33,6 @@ func (ti TableIdentifier) FullyQualifiedName() string { return fmt.Sprintf( "%s.%s", ti.schema, - sql.EscapeNameIfNecessary(ti.table, false, &sql.NameArgs{Escape: true, DestKind: constants.MSSQL}), + sql.EscapeNameIfNecessary(ti.table, false, &sql.NameArgs{DestKind: constants.MSSQL}), ) } diff --git a/clients/redshift/tableid.go b/clients/redshift/tableid.go index 6edf8ca3a..c7cff0a80 100644 --- a/clients/redshift/tableid.go +++ b/clients/redshift/tableid.go @@ -36,6 +36,6 @@ func (ti TableIdentifier) FullyQualifiedName() string { return fmt.Sprintf( "%s.%s", ti.schema, - sql.EscapeNameIfNecessary(ti.table, ti.uppercaseEscapedNames, &sql.NameArgs{Escape: true, DestKind: constants.Redshift}), + sql.EscapeNameIfNecessary(ti.table, ti.uppercaseEscapedNames, &sql.NameArgs{DestKind: constants.Redshift}), ) } diff --git a/clients/shared/merge.go b/clients/shared/merge.go index 735bd6ac5..232f02d82 100644 --- a/clients/shared/merge.go +++ b/clients/shared/merge.go @@ -123,7 +123,7 @@ func Merge(dwh destination.DataWarehouse, tableData *optimization.TableData, cfg TableID: tableID, SubQuery: subQuery, IdempotentKey: tableData.TopicConfig().IdempotentKey, - PrimaryKeys: tableData.PrimaryKeys(dwh.ShouldUppercaseEscapedNames(), &sql.NameArgs{Escape: true, DestKind: dwh.Label()}), + PrimaryKeys: tableData.PrimaryKeys(dwh.ShouldUppercaseEscapedNames(), &sql.NameArgs{DestKind: dwh.Label()}), Columns: tableData.ReadOnlyInMemoryCols(), SoftDelete: tableData.TopicConfig().SoftDelete, DestKind: dwh.Label(), diff --git a/clients/shared/utils.go b/clients/shared/utils.go index 2fefe7b2c..0425be017 100644 --- a/clients/shared/utils.go +++ b/clients/shared/utils.go @@ -32,7 +32,7 @@ func BackfillColumn(cfg config.Config, dwh destination.DataWarehouse, column col return fmt.Errorf("failed to escape default value: %w", err) } - escapedCol := column.Name(dwh.ShouldUppercaseEscapedNames(), &sql.NameArgs{Escape: true, DestKind: dwh.Label()}) + escapedCol := column.Name(dwh.ShouldUppercaseEscapedNames(), &sql.NameArgs{DestKind: dwh.Label()}) // TODO: This is added because `default` is not technically a column that requires escaping, but it is required when it's in the where clause. // Once we escape everything by default, we can remove this patch of code. diff --git a/clients/snowflake/staging.go b/clients/snowflake/staging.go index a41151eaf..3bfd07643 100644 --- a/clients/snowflake/staging.go +++ b/clients/snowflake/staging.go @@ -87,7 +87,6 @@ func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableCo copyCommand := fmt.Sprintf("COPY INTO %s (%s) FROM (SELECT %s FROM @%s)", tempTableID.FullyQualifiedName(), strings.Join(tableData.ReadOnlyInMemoryCols().GetColumnsToUpdate(s.ShouldUppercaseEscapedNames(), &sql.NameArgs{ - Escape: true, DestKind: s.Label(), }), ","), escapeColumns(tableData.ReadOnlyInMemoryCols(), ","), addPrefixToTableName(tempTableID, "%")) diff --git a/clients/snowflake/tableid.go b/clients/snowflake/tableid.go index 20064ffef..af6a99812 100644 --- a/clients/snowflake/tableid.go +++ b/clients/snowflake/tableid.go @@ -45,6 +45,6 @@ func (ti TableIdentifier) FullyQualifiedName() string { "%s.%s.%s", ti.database, ti.schema, - sql.EscapeNameIfNecessary(ti.table, ti.uppercaseEscapedNames, &sql.NameArgs{Escape: true, DestKind: constants.Snowflake}), + sql.EscapeNameIfNecessary(ti.table, ti.uppercaseEscapedNames, &sql.NameArgs{DestKind: constants.Snowflake}), ) } diff --git a/lib/destination/ddl/ddl.go b/lib/destination/ddl/ddl.go index 21554050f..6aae6d63b 100644 --- a/lib/destination/ddl/ddl.go +++ b/lib/destination/ddl/ddl.go @@ -107,7 +107,6 @@ func (a AlterTableArgs) AlterTable(cols ...columns.Column) error { switch a.ColumnOp { case constants.Add: colName := col.Name(*a.UppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: a.Dwh.Label(), }) @@ -119,7 +118,6 @@ func (a AlterTableArgs) AlterTable(cols ...columns.Column) error { colSQLParts = append(colSQLParts, fmt.Sprintf(`%s %s`, colName, typing.KindToDWHType(col.KindDetails, a.Dwh.Label(), col.PrimaryKey()))) case constants.Delete: colSQLParts = append(colSQLParts, col.Name(*a.UppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: a.Dwh.Label(), })) } diff --git a/lib/destination/ddl/ddl_bq_test.go b/lib/destination/ddl/ddl_bq_test.go index bdac9a6a4..78e43edc1 100644 --- a/lib/destination/ddl/ddl_bq_test.go +++ b/lib/destination/ddl/ddl_bq_test.go @@ -93,7 +93,6 @@ func (d *DDLTestSuite) TestAlterTableDropColumnsBigQuery() { assert.NoError(d.T(), alterTableArgs.AlterTable(column)) query, _ := d.fakeBigQueryStore.ExecArgsForCall(callIdx) assert.Equal(d.T(), fmt.Sprintf("ALTER TABLE %s drop COLUMN %s", fqName, column.Name(false, &artieSQL.NameArgs{ - Escape: true, DestKind: d.bigQueryStore.Label(), })), query) callIdx += 1 @@ -154,7 +153,6 @@ func (d *DDLTestSuite) TestAlterTableAddColumns() { assert.NoError(d.T(), alterTableArgs.AlterTable(col)) query, _ := d.fakeBigQueryStore.ExecArgsForCall(callIdx) assert.Equal(d.T(), fmt.Sprintf("ALTER TABLE %s %s COLUMN %s %s", fqName, constants.Add, col.Name(false, &artieSQL.NameArgs{ - Escape: true, DestKind: d.bigQueryStore.Label(), }), typing.KindToDWHType(kind, d.bigQueryStore.Label(), false)), query) callIdx += 1 @@ -216,7 +214,6 @@ func (d *DDLTestSuite) TestAlterTableAddColumnsSomeAlreadyExist() { assert.NoError(d.T(), alterTableArgs.AlterTable(column)) query, _ := d.fakeBigQueryStore.ExecArgsForCall(callIdx) assert.Equal(d.T(), fmt.Sprintf("ALTER TABLE %s %s COLUMN %s %s", fqName, constants.Add, column.Name(false, &artieSQL.NameArgs{ - Escape: true, DestKind: d.bigQueryStore.Label(), }), typing.KindToDWHType(column.KindDetails, d.bigQueryStore.Label(), false)), query) callIdx += 1 diff --git a/lib/destination/ddl/ddl_sflk_test.go b/lib/destination/ddl/ddl_sflk_test.go index 376035c37..67c46c535 100644 --- a/lib/destination/ddl/ddl_sflk_test.go +++ b/lib/destination/ddl/ddl_sflk_test.go @@ -50,7 +50,6 @@ func (d *DDLTestSuite) TestAlterComplexObjects() { for i := 0; i < len(cols); i++ { execQuery, _ := d.fakeSnowflakeStagesStore.ExecArgsForCall(i) assert.Equal(d.T(), fmt.Sprintf("ALTER TABLE %s add COLUMN %s %s", fqTable, cols[i].Name(false, &sql.NameArgs{ - Escape: true, DestKind: d.snowflakeStagesStore.Label(), }), typing.KindToDWHType(cols[i].KindDetails, d.snowflakeStagesStore.Label(), false)), execQuery) @@ -186,7 +185,7 @@ func (d *DDLTestSuite) TestAlterTableDeleteDryRun() { execArg, _ := d.fakeSnowflakeStagesStore.ExecArgsForCall(i) assert.Equal(d.T(), execArg, fmt.Sprintf("ALTER TABLE %s %s COLUMN %s", fqTable, constants.Delete, - cols[i].Name(false, &sql.NameArgs{Escape: true, DestKind: d.snowflakeStagesStore.Label()}))) + cols[i].Name(false, &sql.NameArgs{DestKind: d.snowflakeStagesStore.Label()}))) } } diff --git a/lib/destination/dml/merge.go b/lib/destination/dml/merge.go index d1ecf6000..29de026c0 100644 --- a/lib/destination/dml/merge.go +++ b/lib/destination/dml/merge.go @@ -99,7 +99,6 @@ func (m *MergeArgument) GetParts() ([]string, error) { } cols := m.Columns.GetColumnsToUpdate(*m.UppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: m.DestKind, }) @@ -234,7 +233,6 @@ func (m *MergeArgument) GetStatement() (string, error) { } cols := m.Columns.GetColumnsToUpdate(*m.UppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: m.DestKind, }) @@ -306,7 +304,6 @@ func (m *MergeArgument) GetMSSQLStatement() (string, error) { } cols := m.Columns.GetColumnsToUpdate(*m.UppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: m.DestKind, }) diff --git a/lib/destination/dml/merge_parts_test.go b/lib/destination/dml/merge_parts_test.go index 1cef5a8c1..a4b4c6eca 100644 --- a/lib/destination/dml/merge_parts_test.go +++ b/lib/destination/dml/merge_parts_test.go @@ -49,13 +49,11 @@ func getBasicColumnsForTest(compositeKey bool, uppercaseEscNames bool) result { var pks []columns.Wrapper pks = append(pks, columns.NewWrapper(idCol, uppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: constants.Redshift, })) if compositeKey { pks = append(pks, columns.NewWrapper(emailCol, uppercaseEscNames, &sql.NameArgs{ - Escape: true, DestKind: constants.Redshift, })) } diff --git a/lib/destination/dml/merge_test.go b/lib/destination/dml/merge_test.go index 0c7177368..1c59754d0 100644 --- a/lib/destination/dml/merge_test.go +++ b/lib/destination/dml/merge_test.go @@ -250,11 +250,9 @@ func TestMergeStatementEscapePrimaryKeys(t *testing.T) { IdempotentKey: "", PrimaryKeys: []columns.Wrapper{ columns.NewWrapper(columns.NewColumn("id", typing.Invalid), false, &sql.NameArgs{ - Escape: true, DestKind: constants.Snowflake, }), columns.NewWrapper(columns.NewColumn("group", typing.Invalid), false, &sql.NameArgs{ - Escape: true, DestKind: constants.Snowflake, }), }, diff --git a/lib/sql/escape.go b/lib/sql/escape.go index 925de75dc..7704b3207 100644 --- a/lib/sql/escape.go +++ b/lib/sql/escape.go @@ -10,7 +10,6 @@ import ( ) type NameArgs struct { - Escape bool DestKind constants.DestinationKind } @@ -18,7 +17,8 @@ type NameArgs struct { var symbolsToEscape = []string{":"} func EscapeNameIfNecessary(name string, uppercaseEscNames bool, args *NameArgs) string { - if args == nil || !args.Escape { + // TODO: Kill [NameArgs] and just pass [DestinationKind]. + if args == nil { return name } diff --git a/lib/sql/escape_test.go b/lib/sql/escape_test.go index 7b70201d6..dbb05c810 100644 --- a/lib/sql/escape_test.go +++ b/lib/sql/escape_test.go @@ -24,16 +24,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: "order", }, { - name: "escape = false", - args: &NameArgs{}, - nameToEscape: "order", - expectedName: "order", - expectedNameWhenUpperCfg: "order", - }, - { - name: "escape = true, snowflake", + name: "snowflake", args: &NameArgs{ - Escape: true, DestKind: constants.Snowflake, }, nameToEscape: "order", @@ -41,9 +33,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: `"ORDER"`, }, { - name: "escape = true, snowflake #2", + name: "snowflake #2", args: &NameArgs{ - Escape: true, DestKind: constants.Snowflake, }, nameToEscape: "hello", @@ -51,9 +42,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: "hello", }, { - name: "escape = true, redshift", + name: "redshift", args: &NameArgs{ - Escape: true, DestKind: constants.Redshift, }, nameToEscape: "order", @@ -61,9 +51,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: `"ORDER"`, }, { - name: "escape = true, redshift #2", + name: "redshift #2", args: &NameArgs{ - Escape: true, DestKind: constants.Redshift, }, nameToEscape: "hello", @@ -71,9 +60,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: "hello", }, { - name: "escape = true, bigquery", + name: "bigquery", args: &NameArgs{ - Escape: true, DestKind: constants.BigQuery, }, nameToEscape: "order", @@ -81,9 +69,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: "`ORDER`", }, { - name: "escape = true, bigquery, #2", + name: "bigquery, #2", args: &NameArgs{ - Escape: true, DestKind: constants.BigQuery, }, nameToEscape: "hello", @@ -91,9 +78,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: "hello", }, { - name: "escape = true, redshift, #1 (delta)", + name: "redshift, #1 (delta)", args: &NameArgs{ - Escape: true, DestKind: constants.Redshift, }, nameToEscape: "delta", @@ -101,9 +87,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: `"DELTA"`, }, { - name: "escape = true, snowflake, #1 (delta)", + name: "snowflake, #1 (delta)", args: &NameArgs{ - Escape: true, DestKind: constants.Snowflake, }, nameToEscape: "delta", @@ -111,9 +96,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: `delta`, }, { - name: "escape = true, redshift, symbols", + name: "redshift, symbols", args: &NameArgs{ - Escape: true, DestKind: constants.Redshift, }, nameToEscape: "receivedat:__", @@ -121,9 +105,8 @@ func TestEscapeNameIfNecessary(t *testing.T) { expectedNameWhenUpperCfg: `"RECEIVEDAT:__"`, }, { - name: "escape = true, redshift, numbers", + name: "redshift, numbers", args: &NameArgs{ - Escape: true, DestKind: constants.Redshift, }, nameToEscape: "0", diff --git a/lib/typing/columns/columns.go b/lib/typing/columns/columns.go index ba238958b..2b071cebc 100644 --- a/lib/typing/columns/columns.go +++ b/lib/typing/columns/columns.go @@ -253,7 +253,7 @@ func (c *Columns) UpdateQuery(destKind constants.DestinationKind, uppercaseEscNa continue } - colName := column.Name(uppercaseEscNames, &sql.NameArgs{Escape: true, DestKind: destKind}) + colName := column.Name(uppercaseEscNames, &sql.NameArgs{DestKind: destKind}) if column.ToastColumn { if column.KindDetails == typing.Struct { cols = append(cols, processToastStructCol(colName, destKind)) diff --git a/lib/typing/columns/columns_test.go b/lib/typing/columns/columns_test.go index 3b208b588..8ccae0206 100644 --- a/lib/typing/columns/columns_test.go +++ b/lib/typing/columns/columns_test.go @@ -170,16 +170,11 @@ func TestColumn_Name(t *testing.T) { } assert.Equal(t, testCase.expectedName, col.RawName(), testCase.colName) - assert.Equal(t, testCase.expectedName, col.Name(false, &sql.NameArgs{ - Escape: false, - }), testCase.colName) assert.Equal(t, testCase.expectedNameEsc, col.Name(false, &sql.NameArgs{ - Escape: true, DestKind: constants.Snowflake, }), testCase.colName) assert.Equal(t, testCase.expectedNameEscBq, col.Name(false, &sql.NameArgs{ - Escape: true, DestKind: constants.BigQuery, }), testCase.colName) } @@ -242,17 +237,12 @@ func TestColumns_GetColumnsToUpdate(t *testing.T) { } assert.Equal(t, testCase.expectedCols, cols.GetColumnsToUpdate(false, nil), testCase.name) - assert.Equal(t, testCase.expectedCols, cols.GetColumnsToUpdate(false, &sql.NameArgs{ - Escape: false, - }), testCase.name) assert.Equal(t, testCase.expectedColsEsc, cols.GetColumnsToUpdate(false, &sql.NameArgs{ - Escape: true, DestKind: constants.Snowflake, }), testCase.name) assert.Equal(t, testCase.expectedColsEscBq, cols.GetColumnsToUpdate(false, &sql.NameArgs{ - Escape: true, DestKind: constants.BigQuery, }), testCase.name) } diff --git a/lib/typing/columns/wrapper_test.go b/lib/typing/columns/wrapper_test.go index 0d7b31c48..6b96001a7 100644 --- a/lib/typing/columns/wrapper_test.go +++ b/lib/typing/columns/wrapper_test.go @@ -44,7 +44,6 @@ func TestWrapper_Complete(t *testing.T) { for _, testCase := range testCases { // Snowflake escape w := NewWrapper(NewColumn(testCase.name, typing.Invalid), false, &sql.NameArgs{ - Escape: true, DestKind: constants.Snowflake, }) @@ -53,7 +52,6 @@ func TestWrapper_Complete(t *testing.T) { // BigQuery escape w = NewWrapper(NewColumn(testCase.name, typing.Invalid), false, &sql.NameArgs{ - Escape: true, DestKind: constants.BigQuery, }) @@ -62,11 +60,8 @@ func TestWrapper_Complete(t *testing.T) { for _, destKind := range []constants.DestinationKind{constants.Snowflake, constants.BigQuery} { w = NewWrapper(NewColumn(testCase.name, typing.Invalid), false, &sql.NameArgs{ - Escape: false, DestKind: destKind, }) - - assert.Equal(t, testCase.expectedRawName, w.EscapedName(), testCase.name) assert.Equal(t, testCase.expectedRawName, w.RawName(), testCase.name) }