From 468404116ccec7964e04419c9254b4cf33da428a Mon Sep 17 00:00:00 2001 From: Robin Tang Date: Thu, 26 Sep 2024 15:13:21 -0700 Subject: [PATCH 1/2] Rewriting tests (#929) --- lib/cdc/util/optional_schema_test.go | 179 +++++++++++++++------------ lib/stringutil/strings_test.go | 55 ++++---- 2 files changed, 125 insertions(+), 109 deletions(-) diff --git a/lib/cdc/util/optional_schema_test.go b/lib/cdc/util/optional_schema_test.go index c3347abc1..8e5d16c6e 100644 --- a/lib/cdc/util/optional_schema_test.go +++ b/lib/cdc/util/optional_schema_test.go @@ -2,7 +2,6 @@ package util import ( "encoding/json" - "fmt" "testing" "github.com/stretchr/testify/assert" @@ -12,91 +11,111 @@ import ( ) func TestGetOptionalSchema(t *testing.T) { - type _tc struct { - body string - expected map[string]typing.KindDetails - } - - tcs := []_tc{ - { - body: MySQLInsert, - expected: map[string]typing.KindDetails{ - "id": typing.Integer, - "first_name": typing.String, - "last_name": typing.String, - "email": typing.String, - }, - }, - { - body: MySQLUpdate, - expected: map[string]typing.KindDetails{ - "id": typing.Integer, - "first_name": typing.String, - "last_name": typing.String, - "email": typing.String, - }, - }, + { + // MySQL { - body: MySQLDelete, - expected: map[string]typing.KindDetails{ - "id": typing.Integer, - "first_name": typing.String, - "last_name": typing.String, - "email": typing.String, - }, - }, - { - body: PostgresDelete, - expected: map[string]typing.KindDetails{ - "id": typing.Integer, - "first_name": typing.String, - "last_name": typing.String, - "email": typing.String, - }, - }, + // Insert + var schemaEventPayload SchemaEventPayload + assert.NoError(t, json.Unmarshal([]byte(MySQLInsert), &schemaEventPayload)) + + optionalSchema, err := schemaEventPayload.GetOptionalSchema() + assert.NoError(t, err) + assert.Equal( + t, + optionalSchema, + map[string]typing.KindDetails{ + "id": typing.Integer, + "first_name": typing.String, + "last_name": typing.String, + "email": typing.String, + }, + ) + } { - body: PostgresUpdate, - expected: map[string]typing.KindDetails{ - "id": typing.Integer, - "first_name": typing.String, - "last_name": typing.String, - "email": typing.String, - "boolean_test": typing.Boolean, - "bool_test": typing.Boolean, - "bit_test": typing.Boolean, - "numeric_test": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(decimal.PrecisionNotSpecified, decimal.DefaultScale)), - "numeric_5": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 0)), - "numeric_5_0": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 0)), - "numeric_5_2": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 2)), - "numeric_5_6": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 6)), - "numeric_39_0": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 0)), - "numeric_39_2": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 2)), - "numeric_39_6": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 6)), - }, - }, - } + // Update + var schemaEventPayload SchemaEventPayload + assert.NoError(t, json.Unmarshal([]byte(MySQLUpdate), &schemaEventPayload)) - for idx, tc := range tcs { - var schemaEventPayload SchemaEventPayload - err := json.Unmarshal([]byte(tc.body), &schemaEventPayload) - assert.NoError(t, err, idx) + optionalSchema, err := schemaEventPayload.GetOptionalSchema() + assert.NoError(t, err) + assert.Equal( + t, + optionalSchema, + map[string]typing.KindDetails{ + "id": typing.Integer, + "first_name": typing.String, + "last_name": typing.String, + "email": typing.String, + }, + ) + } + { + // Delete + var schemaEventPayload SchemaEventPayload + assert.NoError(t, json.Unmarshal([]byte(MySQLDelete), &schemaEventPayload)) - actualData, err := schemaEventPayload.GetOptionalSchema() - assert.NoError(t, err) + optionalSchema, err := schemaEventPayload.GetOptionalSchema() + assert.NoError(t, err) + assert.Equal( + t, + optionalSchema, + map[string]typing.KindDetails{ + "id": typing.Integer, + "first_name": typing.String, + "last_name": typing.String, + "email": typing.String, + }, + ) + } + } + { + // Postgres + { + // Delete + var schemaEventPayload SchemaEventPayload + assert.NoError(t, json.Unmarshal([]byte(PostgresDelete), &schemaEventPayload)) - for actualKey, actualVal := range actualData { - testMsg := fmt.Sprintf("key: %s, actualKind: %s, index: %d", actualKey, actualVal.Kind, idx) + optionalSchema, err := schemaEventPayload.GetOptionalSchema() + assert.NoError(t, err) + assert.Equal( + t, + optionalSchema, + map[string]typing.KindDetails{ + "id": typing.Integer, + "first_name": typing.String, + "last_name": typing.String, + "email": typing.String, + }, + ) + } + { + // Update + var schemaEventPayload SchemaEventPayload + assert.NoError(t, json.Unmarshal([]byte(PostgresUpdate), &schemaEventPayload)) - expectedValue, isOk := tc.expected[actualKey] - assert.True(t, isOk, testMsg) - assert.Equal(t, expectedValue.Kind, actualVal.Kind, testMsg) - if expectedValue.ExtendedDecimalDetails != nil || actualVal.ExtendedDecimalDetails != nil { - assert.NotNil(t, actualVal.ExtendedDecimalDetails, testMsg) - assert.Equal(t, expectedValue.ExtendedDecimalDetails.Scale(), actualVal.ExtendedDecimalDetails.Scale(), testMsg) - assert.Equal(t, expectedValue.ExtendedDecimalDetails.Precision(), actualVal.ExtendedDecimalDetails.Precision(), testMsg) - } else { - assert.Nil(t, actualVal.ExtendedDecimalDetails, testMsg) - } + optionalSchema, err := schemaEventPayload.GetOptionalSchema() + assert.NoError(t, err) + assert.Equal( + t, + optionalSchema, + map[string]typing.KindDetails{ + "id": typing.Integer, + "first_name": typing.String, + "last_name": typing.String, + "email": typing.String, + "boolean_test": typing.Boolean, + "bool_test": typing.Boolean, + "bit_test": typing.Boolean, + "numeric_test": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(decimal.PrecisionNotSpecified, decimal.DefaultScale)), + "numeric_5": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 0)), + "numeric_5_0": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 0)), + "numeric_5_2": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 2)), + "numeric_5_6": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(5, 6)), + "numeric_39_0": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 0)), + "numeric_39_2": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 2)), + "numeric_39_6": typing.NewDecimalDetailsFromTemplate(typing.EDecimal, decimal.NewDetails(39, 6)), + }, + ) } } } diff --git a/lib/stringutil/strings_test.go b/lib/stringutil/strings_test.go index c00b1d354..44690492f 100644 --- a/lib/stringutil/strings_test.go +++ b/lib/stringutil/strings_test.go @@ -19,44 +19,41 @@ func TestCapitalizeFirstLetter(t *testing.T) { } func TestEscapeBackslashes(t *testing.T) { - testCases := []struct { - name string - colVal string - expectedString string - }{ - { - name: "string", - colVal: "hello", - expectedString: "hello", - }, + { + // No escape { - name: "string", - colVal: "bobby o'reilly", - expectedString: "bobby o'reilly", - }, + assert.Equal(t, "hello", EscapeBackslashes("hello")) + } { - name: "string with line breaks", - colVal: "line1 \n line 2", - expectedString: "line1 \n line 2", - }, + // Special char + assert.Equal(t, `bobby o'reilly`, EscapeBackslashes(`bobby o'reilly`)) + } { - name: "string with existing backslash", - colVal: `hello \ there \ hh`, - expectedString: `hello \\ there \\ hh`, - }, + // Line breaks + assert.Equal(t, "line1 \n line 2", EscapeBackslashes("line1 \n line 2")) + } } + { + // Escape + { + // Backslash + assert.Equal(t, `hello \\ there \\ hh`, EscapeBackslashes(`hello \ there \ hh`)) - for _, testCase := range testCases { - assert.Equal(t, testCase.expectedString, EscapeBackslashes(testCase.colVal), testCase.name) + } } } func TestEmpty(t *testing.T) { - assert.False(t, Empty("hi", "there", "artie", "transfer")) - assert.False(t, Empty("dusty")) - - assert.True(t, Empty("robin", "jacqueline", "charlie", "")) - assert.True(t, Empty("")) + { + // No empty + assert.False(t, Empty("hi", "there", "artie", "transfer")) + assert.False(t, Empty("dusty")) + } + { + // Empty + assert.True(t, Empty("robin", "jacqueline", "charlie", "")) + assert.True(t, Empty("")) + } } func TestEscapeSpaces(t *testing.T) { From 72a4b3bf172a8f6b7b60fdc53d42f8d7a6557d5d Mon Sep 17 00:00:00 2001 From: Robin Tang Date: Thu, 26 Sep 2024 15:21:51 -0700 Subject: [PATCH 2/2] Adding parentTableID to `PrepareTempTable` (#933) --- clients/bigquery/bigquery.go | 2 +- clients/mssql/staging.go | 2 +- clients/redshift/redshift.go | 12 +++++------ clients/redshift/staging.go | 2 +- clients/shared/append.go | 4 +++- clients/shared/merge.go | 2 +- clients/snowflake/snowflake.go | 12 +++++------ clients/snowflake/staging.go | 2 +- clients/snowflake/staging_test.go | 4 ++-- go.mod | 18 ++++++++-------- go.sum | 36 +++++++++++++++---------------- lib/destination/dwh.go | 2 +- 12 files changed, 48 insertions(+), 50 deletions(-) diff --git a/clients/bigquery/bigquery.go b/clients/bigquery/bigquery.go index 743e6dbb6..d2883c57d 100644 --- a/clients/bigquery/bigquery.go +++ b/clients/bigquery/bigquery.go @@ -78,7 +78,7 @@ func (s *Store) Append(tableData *optimization.TableData, useTempTable bool) err return nil } -func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { +func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { if createTempTable { tempAlterTableArgs := ddl.AlterTableArgs{ Dialect: s.Dialect(), diff --git a/clients/mssql/staging.go b/clients/mssql/staging.go index 68fd19918..89a2026ec 100644 --- a/clients/mssql/staging.go +++ b/clients/mssql/staging.go @@ -13,7 +13,7 @@ import ( "github.com/artie-labs/transfer/lib/typing/columns" ) -func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { +func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { if createTempTable { tempAlterTableArgs := ddl.AlterTableArgs{ Dialect: s.Dialect(), diff --git a/clients/redshift/redshift.go b/clients/redshift/redshift.go index 735a66a69..cd46578a0 100644 --- a/clients/redshift/redshift.go +++ b/clients/redshift/redshift.go @@ -14,7 +14,6 @@ import ( "github.com/artie-labs/transfer/lib/kafkalib" "github.com/artie-labs/transfer/lib/optimization" "github.com/artie-labs/transfer/lib/sql" - "github.com/artie-labs/transfer/lib/typing" ) type Store struct { @@ -52,6 +51,10 @@ func (s *Store) GetConfigMap() *types.DwhToTablesConfigMap { } func (s *Store) Dialect() sql.Dialect { + return s.dialect() +} + +func (s *Store) dialect() dialect.RedshiftDialect { return dialect.RedshiftDialect{} } @@ -76,12 +79,7 @@ func (s *Store) Sweep() error { return err } - redshiftDialect, err := typing.AssertType[dialect.RedshiftDialect](s.Dialect()) - if err != nil { - return err - } - - return shared.Sweep(s, tcs, redshiftDialect.BuildSweepQuery) + return shared.Sweep(s, tcs, s.dialect().BuildSweepQuery) } func (s *Store) Dedupe(tableID sql.TableIdentifier, primaryKeys []string, includeArtieUpdatedAt bool) error { diff --git a/clients/redshift/staging.go b/clients/redshift/staging.go index 9d5893f99..85de9e39b 100644 --- a/clients/redshift/staging.go +++ b/clients/redshift/staging.go @@ -17,7 +17,7 @@ import ( "github.com/artie-labs/transfer/lib/sql" ) -func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { +func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ sql.TableIdentifier, _ types.AdditionalSettings, createTempTable bool) error { if createTempTable { tempAlterTableArgs := ddl.AlterTableArgs{ Dialect: s.Dialect(), diff --git a/clients/shared/append.go b/clients/shared/append.go index fe668962d..dd12d568b 100644 --- a/clients/shared/append.go +++ b/clients/shared/append.go @@ -51,14 +51,16 @@ func Append(dwh destination.DataWarehouse, tableData *optimization.TableData, op return fmt.Errorf("failed to merge columns from destination: %w", err) } + tempTableID := tableID if opts.UseTempTable { // Override tableID with tempTableID if we're using a temporary table - tableID = opts.TempTableID + tempTableID = opts.TempTableID } return dwh.PrepareTemporaryTable( tableData, tableConfig, + tempTableID, tableID, opts, opts.UseTempTable, diff --git a/clients/shared/merge.go b/clients/shared/merge.go index 71e32e9bb..1ce39e74a 100644 --- a/clients/shared/merge.go +++ b/clients/shared/merge.go @@ -76,7 +76,7 @@ func Merge(dwh destination.DataWarehouse, tableData *optimization.TableData, opt } }() - if err = dwh.PrepareTemporaryTable(tableData, tableConfig, temporaryTableID, types.AdditionalSettings{}, true); err != nil { + if err = dwh.PrepareTemporaryTable(tableData, tableConfig, temporaryTableID, tableID, types.AdditionalSettings{}, true); err != nil { return fmt.Errorf("failed to prepare temporary table: %w", err) } diff --git a/clients/snowflake/snowflake.go b/clients/snowflake/snowflake.go index 95a3e8575..5651b19d4 100644 --- a/clients/snowflake/snowflake.go +++ b/clients/snowflake/snowflake.go @@ -14,7 +14,6 @@ import ( "github.com/artie-labs/transfer/lib/kafkalib" "github.com/artie-labs/transfer/lib/optimization" "github.com/artie-labs/transfer/lib/sql" - "github.com/artie-labs/transfer/lib/typing" ) type Store struct { @@ -47,15 +46,14 @@ func (s *Store) Sweep() error { return err } - snowflakeDialect, err := typing.AssertType[dialect.SnowflakeDialect](s.Dialect()) - if err != nil { - return err - } - - return shared.Sweep(s, tcs, snowflakeDialect.BuildSweepQuery) + return shared.Sweep(s, tcs, s.dialect().BuildSweepQuery) } func (s *Store) Dialect() sql.Dialect { + return s.dialect() +} + +func (s *Store) dialect() dialect.SnowflakeDialect { return dialect.SnowflakeDialect{} } diff --git a/clients/snowflake/staging.go b/clients/snowflake/staging.go index 2e58ba6d4..6a279c7b0 100644 --- a/clients/snowflake/staging.go +++ b/clients/snowflake/staging.go @@ -54,7 +54,7 @@ func castColValStaging(colVal any, colKind typing.KindDetails) (string, error) { return replaceExceededValues(value, colKind), nil } -func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, additionalSettings types.AdditionalSettings, createTempTable bool) error { +func (s *Store) PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sql.TableIdentifier, _ sql.TableIdentifier, additionalSettings types.AdditionalSettings, createTempTable bool) error { if createTempTable { tempAlterTableArgs := ddl.AlterTableArgs{ Dialect: s.Dialect(), diff --git a/clients/snowflake/staging_test.go b/clients/snowflake/staging_test.go index ae7447c18..8202074d6 100644 --- a/clients/snowflake/staging_test.go +++ b/clients/snowflake/staging_test.go @@ -157,7 +157,7 @@ func (s *SnowflakeTestSuite) TestPrepareTempTable() { sflkTc := s.stageStore.GetConfigMap().TableConfigCache(tempTableID) { - assert.NoError(s.T(), s.stageStore.PrepareTemporaryTable(tableData, sflkTc, tempTableID, types.AdditionalSettings{}, true)) + assert.NoError(s.T(), s.stageStore.PrepareTemporaryTable(tableData, sflkTc, tempTableID, tempTableID, types.AdditionalSettings{}, true)) assert.Equal(s.T(), 3, s.fakeStageStore.ExecCallCount()) // First call is to create the temp table @@ -179,7 +179,7 @@ func (s *SnowflakeTestSuite) TestPrepareTempTable() { } { // Don't create the temporary table. - assert.NoError(s.T(), s.stageStore.PrepareTemporaryTable(tableData, sflkTc, tempTableID, types.AdditionalSettings{}, false)) + assert.NoError(s.T(), s.stageStore.PrepareTemporaryTable(tableData, sflkTc, tempTableID, tempTableID, types.AdditionalSettings{}, false)) assert.Equal(s.T(), 5, s.fakeStageStore.ExecCallCount()) } diff --git a/go.mod b/go.mod index 260d76ef2..fc5dfb122 100644 --- a/go.mod +++ b/go.mod @@ -124,17 +124,17 @@ require ( go.opentelemetry.io/otel v1.24.0 // indirect go.opentelemetry.io/otel/metric v1.24.0 // indirect go.opentelemetry.io/otel/trace v1.24.0 // indirect - golang.org/x/crypto v0.25.0 // indirect - golang.org/x/exp v0.0.0-20231006140011-7918f672742d // indirect - golang.org/x/mod v0.17.0 // indirect - golang.org/x/net v0.25.0 // indirect + golang.org/x/crypto v0.27.0 // indirect + golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 // indirect + golang.org/x/mod v0.21.0 // indirect + golang.org/x/net v0.29.0 // indirect golang.org/x/oauth2 v0.19.0 // indirect - golang.org/x/sync v0.7.0 // indirect - golang.org/x/sys v0.22.0 // indirect - golang.org/x/term v0.22.0 // indirect - golang.org/x/text v0.16.0 // indirect + golang.org/x/sync v0.8.0 // indirect + golang.org/x/sys v0.25.0 // indirect + golang.org/x/term v0.24.0 // indirect + golang.org/x/text v0.18.0 // indirect golang.org/x/time v0.5.0 // indirect - golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d // indirect + golang.org/x/tools v0.25.0 // indirect golang.org/x/xerrors v0.0.0-20231012003039-104605ab7028 // indirect google.golang.org/genproto v0.0.0-20240401170217-c3f982113cda // indirect google.golang.org/genproto/googleapis/api v0.0.0-20240415180920-8c6c420018be // indirect diff --git a/go.sum b/go.sum index e201dc844..4ca5ceaed 100644 --- a/go.sum +++ b/go.sum @@ -519,8 +519,8 @@ golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPh golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= golang.org/x/crypto v0.0.0-20220622213112-05595931fe9d/go.mod h1:IxCIyHEi3zRg3s0A5j5BB6A9Jmi73HwBIUl50j+osU4= golang.org/x/crypto v0.14.0/go.mod h1:MVFd36DqK4CsrnJYDkBA3VC4m2GkXAM0PvzMCn4JQf4= -golang.org/x/crypto v0.25.0 h1:ypSNr+bnYL2YhwoMt2zPxHFmbAN1KZs/njMG3hxUp30= -golang.org/x/crypto v0.25.0/go.mod h1:T+wALwcMOSE0kXgUAnPAHqTLW+XHgcELELW8VaDgm/M= +golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= +golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= golang.org/x/exp v0.0.0-20190121172915-509febef88a4/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190306152737-a1d7652674e8/go.mod h1:CJ0aWSM057203Lf6IL+f9T1iT9GByDxfZKAQTCR3kQA= golang.org/x/exp v0.0.0-20190510132918-efd6b22b2522/go.mod h1:ZjyILWgesfNpC6sMxTJOJm9Kp84zZh5NQWvqDGG3Qr8= @@ -531,8 +531,8 @@ golang.org/x/exp v0.0.0-20191227195350-da58074b4299/go.mod h1:2RIsYlXP63K8oxa1u0 golang.org/x/exp v0.0.0-20200119233911-0405dc783f0a/go.mod h1:2RIsYlXP63K8oxa1u096TMicItID8zy7Y6sNkU49FU4= golang.org/x/exp v0.0.0-20200207192155-f17229e696bd/go.mod h1:J/WKrq2StrnmMY6+EHIKF9dgMWnmCNThgcyBT1FY9mM= golang.org/x/exp v0.0.0-20200224162631-6cc2880d07d6/go.mod h1:3jZMyOhIsHpP37uCMkUooju7aAi5cS1Q23tOzKc+0MU= -golang.org/x/exp v0.0.0-20231006140011-7918f672742d h1:jtJma62tbqLibJ5sFQz8bKtEM8rJBtfilJ2qTU199MI= -golang.org/x/exp v0.0.0-20231006140011-7918f672742d/go.mod h1:ldy0pHrwJyGW56pPQzzkH36rKxoZW1tw7ZJpeKx+hdo= +golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 h1:2dVuKD2vS7b0QIHQbpyTISPd0LeHDbnYEryqj5Q1ug8= +golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56/go.mod h1:M4RDyNAINzryxdtnbRXRL/OHtkFuWGRjvuhBJpk2IlY= golang.org/x/image v0.0.0-20190227222117-0694c2d4d067/go.mod h1:kZ7UVZpmo3dzQBMxlp+ypCbDeSB+sBbTgSJuh5dn5js= golang.org/x/image v0.0.0-20190802002840-cff245a6509b/go.mod h1:FeLwcggjj3mMvU+oOTbSwawSJRM1uh48EjtB4UJZlP0= golang.org/x/lint v0.0.0-20180702182130-06c8688daad7/go.mod h1:UVdnD1Gm6xHRNCYTkRU2/jEulfH38KcIWyp/GAMgvoE= @@ -555,8 +555,8 @@ golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.4.2/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA= golang.org/x/mod v0.6.0-dev.0.20220419223038-86c51ed26bb4/go.mod h1:jJ57K6gSWd91VN4djpZkiMVwK6gcyfeH4XE8wZrZaV4= golang.org/x/mod v0.8.0/go.mod h1:iBbtSCu2XBx23ZKBPSOrRkjjQPZFPuis4dIYUhu/chs= -golang.org/x/mod v0.17.0 h1:zY54UmvipHiNd+pm+m0x9KhZ9hl1/7QNMyxXbc6ICqA= -golang.org/x/mod v0.17.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= +golang.org/x/mod v0.21.0 h1:vvrHzRwRfVKSiLrG+d4FMl/Qi4ukBCE6kZlTUkDYRT0= +golang.org/x/mod v0.21.0/go.mod h1:6SkKJ3Xj0I0BrPOZoBy3bdMptDDU9oJrpohJ3eWZ1fY= golang.org/x/net v0.0.0-20180724234803-3673e40ba225/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180826012351-8a410e7b638d/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= golang.org/x/net v0.0.0-20180906233101-161cd47e91fd/go.mod h1:mL1N/T3taQHkDXs73rZJwtUhF3w3ftmwwsq0BUmARs4= @@ -585,8 +585,8 @@ golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= golang.org/x/net v0.10.0/go.mod h1:0qNGK6F8kojg2nk9dLZ2mShWaEBan6FAoqfSigmmuDg= golang.org/x/net v0.17.0/go.mod h1:NxSsAGuq816PNPmqtQdLE42eU2Fs7NoRIZrHJAlaCOE= -golang.org/x/net v0.25.0 h1:d/OCCoBEUq33pjydKrGQhw7IlUPI2Oylr+8qLx49kac= -golang.org/x/net v0.25.0/go.mod h1:JkAGAh7GEvH74S6FOH42FLoXpXbE/aqXSrIQjXgsiwM= +golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= +golang.org/x/net v0.29.0/go.mod h1:gLkgy8jTGERgjzMic6DS9+SP0ajcu6Xu3Orq/SpETg0= golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20181017192945-9dcd33a902f4/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= golang.org/x/oauth2 v0.0.0-20181203162652-d668ce993890/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= @@ -606,8 +606,8 @@ golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJ golang.org/x/sync v0.0.0-20210220032951-036812b2e83c/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.0.0-20220722155255-886fb9371eb4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= -golang.org/x/sync v0.7.0 h1:YsImfSBoP9QPYL0xyKJPq0gcaJdG3rInoqxTWbfQu9M= -golang.org/x/sync v0.7.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= +golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ= +golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20180909124046-d0be0721c37e/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= golang.org/x/sys v0.0.0-20181029174526-d69651ed3497/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= @@ -646,15 +646,15 @@ golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.8.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.13.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= -golang.org/x/sys v0.22.0 h1:RI27ohtqKCnwULzJLqkv897zojh5/DwS/ENaMzUOaWI= -golang.org/x/sys v0.22.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= +golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34= +golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= golang.org/x/term v0.8.0/go.mod h1:xPskH00ivmX89bAKVGSKKtLOWNx2+17Eiy94tnKShWo= golang.org/x/term v0.13.0/go.mod h1:LTmsnFJwVN6bCy1rVCoS+qHT1HhALEFxKncY3WNNh4U= -golang.org/x/term v0.22.0 h1:BbsgPEJULsl2fV/AT3v15Mjva5yXKQDyKf+TbDz7QJk= -golang.org/x/term v0.22.0/go.mod h1:F3qCibpT5AMpCRfhfT53vVJwhLtIVHhB9XDjfFvnMI4= +golang.org/x/term v0.24.0 h1:Mh5cbb+Zk2hqqXNO7S1iTjEphVL+jb8ZWaqh/g+JWkM= +golang.org/x/term v0.24.0/go.mod h1:lOBK/LVxemqiMij05LGJ0tzNr8xlmwBRJ81PX6wVLH8= golang.org/x/text v0.0.0-20170915032832-14c0d48ead0c/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= golang.org/x/text v0.3.1-0.20180807135948-17ff2d5776d2/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= @@ -666,8 +666,8 @@ golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= golang.org/x/text v0.9.0/go.mod h1:e1OnstbJyHTd6l/uOt8jFFHp6TRDWZR/bV3emEE/zU8= golang.org/x/text v0.13.0/go.mod h1:TvPlkZtksWOMsz7fbANvkp4WM8x/WCo/om8BMLbz+aE= -golang.org/x/text v0.16.0 h1:a94ExnEXNtEwYLGJSIUxnWoxoRz/ZcCsV63ROupILh4= -golang.org/x/text v0.16.0/go.mod h1:GhwF1Be+LQoKShO3cGOHzqOgRrGaYc9AvblQOmPVHnI= +golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224= +golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= golang.org/x/time v0.0.0-20180412165947-fbb02b2291d2/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20181108054448-85acf8d2951c/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= golang.org/x/time v0.0.0-20190308202827-9d24e82272b4/go.mod h1:tRJNPiyCQ0inRvYxbN9jk5I+vvW/OXSQhTDSoE431IQ= @@ -708,8 +708,8 @@ golang.org/x/tools v0.0.0-20200224181240-023911ca70b2/go.mod h1:TB2adYChydJhpapK golang.org/x/tools v0.1.1/go.mod h1:o0xws9oXOQQZyjljx8fwUC0k7L1pTE6eaCbjGeHmOkk= golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= golang.org/x/tools v0.6.0/go.mod h1:Xwgl3UAJ/d3gWutnCtw505GrjyAbvKui8lOU390QaIU= -golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d h1:vU5i/LfpvrRCpgM/VPfJLg5KjxD3E+hfT1SH+d9zLwg= -golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d/go.mod h1:aiJjzUbINMkxbQROHiO6hDPo2LHcIPhhQsa9DLh0yGk= +golang.org/x/tools v0.25.0 h1:oFU9pkj/iJgs+0DT+VMHrx+oBKs/LJMV+Uvg78sl+fE= +golang.org/x/tools v0.25.0/go.mod h1:/vtpO8WL1N9cQC3FN5zPqb//fRXskFHbLKk4OW1Q7rg= golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= diff --git a/lib/destination/dwh.go b/lib/destination/dwh.go index 44484c356..d5adb54f2 100644 --- a/lib/destination/dwh.go +++ b/lib/destination/dwh.go @@ -23,7 +23,7 @@ type DataWarehouse interface { // Helper functions for merge GetTableConfig(tableData *optimization.TableData) (*types.DwhTableConfig, error) - PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sqllib.TableIdentifier, additionalSettings types.AdditionalSettings, createTempTable bool) error + PrepareTemporaryTable(tableData *optimization.TableData, tableConfig *types.DwhTableConfig, tempTableID sqllib.TableIdentifier, parentTableID sqllib.TableIdentifier, additionalSettings types.AdditionalSettings, createTempTable bool) error } type Baseline interface {