From 686f8eaa7cf0f68fac321abfc637f99df007d72c Mon Sep 17 00:00:00 2001 From: Jiaqiang Huang Date: Mon, 6 Jan 2025 11:04:04 +0800 Subject: [PATCH] dm: refine openapi table migrate rule source/target (#11933) close pingcap/tiflow#4287 --- dm/config/task_converters.go | 11 +---- dm/config/task_converters_test.go | 39 +++------------- dm/openapi/gen.server.go | 74 +++++++++++++++---------------- dm/openapi/gen.types.go | 36 ++++++++------- dm/openapi/spec/dm.yaml | 63 +++++++++++++------------- 5 files changed, 100 insertions(+), 123 deletions(-) diff --git a/dm/config/task_converters.go b/dm/config/task_converters.go index a05ca5856f8..cb8a1c83484 100644 --- a/dm/config/task_converters.go +++ b/dm/config/task_converters.go @@ -610,21 +610,14 @@ func SubTaskConfigsToOpenAPITask(subTaskConfigList []*SubTaskConfig) *openapi.Ta ruleMap := map[string]struct{}{} appendOneRule := func(sourceName, schemaPattern, tablePattern, targetSchema, targetTable string) { tableMigrateRule := openapi.TaskTableMigrateRule{ - Source: struct { - Schema string `json:"schema"` - SourceName string `json:"source_name"` - Table string `json:"table"` - }{ + Source: openapi.TaskTableMigrateRuleSource{ Schema: schemaPattern, SourceName: sourceName, Table: tablePattern, }, } if targetSchema != "" { - tableMigrateRule.Target = &struct { - Schema *string `json:"schema,omitempty"` - Table *string `json:"table,omitempty"` - }{ + tableMigrateRule.Target = &openapi.TaskTableMigrateRuleTarget{ Schema: &targetSchema, } if targetTable != "" { diff --git a/dm/config/task_converters_test.go b/dm/config/task_converters_test.go index 44562c47697..70398998685 100644 --- a/dm/config/task_converters_test.go +++ b/dm/config/task_converters_test.go @@ -459,18 +459,11 @@ func TestConvertBetweenOpenAPITaskAndTaskConfig(t *testing.T) { sourceSchema := task.TableMigrateRule[0].Source.Schema targetSchema := *task.TableMigrateRule[0].Target.Schema // only route schema - task.TableMigrateRule[0].Source = struct { - Schema string `json:"schema"` - SourceName string `json:"source_name"` - Table string `json:"table"` - }{ + task.TableMigrateRule[0].Source = openapi.TaskTableMigrateRuleSource{ SourceName: source1Name, Schema: sourceSchema, } - task.TableMigrateRule[0].Target = &struct { - Schema *string `json:"schema,omitempty"` - Table *string `json:"table,omitempty"` - }{ + task.TableMigrateRule[0].Target = &openapi.TaskTableMigrateRuleTarget{ Schema: &targetSchema, } taskCfg, err = OpenAPITaskToTaskConfig(&task, sourceCfgMap) @@ -504,38 +497,24 @@ func TestConvertBetweenOpenAPITaskAndTaskConfig(t *testing.T) { // only route table will meet error sourceTable := "tb" targetTable := "tb1" - task.TableMigrateRule[0].Source = struct { - Schema string `json:"schema"` - SourceName string `json:"source_name"` - Table string `json:"table"` - }{ + task.TableMigrateRule[0].Source = openapi.TaskTableMigrateRuleSource{ SourceName: source1Name, Schema: sourceSchema, Table: sourceTable, } - task.TableMigrateRule[0].Target = &struct { - Schema *string `json:"schema,omitempty"` - Table *string `json:"table,omitempty"` - }{ + task.TableMigrateRule[0].Target = &openapi.TaskTableMigrateRuleTarget{ Table: &targetTable, } _, err = OpenAPITaskToTaskConfig(&task, sourceCfgMap) require.True(t, terror.ErrConfigGenTableRouter.Equal(err)) // route both - task.TableMigrateRule[0].Source = struct { - Schema string `json:"schema"` - SourceName string `json:"source_name"` - Table string `json:"table"` - }{ + task.TableMigrateRule[0].Source = openapi.TaskTableMigrateRuleSource{ SourceName: source1Name, Schema: sourceSchema, Table: sourceTable, } - task.TableMigrateRule[0].Target = &struct { - Schema *string `json:"schema,omitempty"` - Table *string `json:"table,omitempty"` - }{ + task.TableMigrateRule[0].Target = &openapi.TaskTableMigrateRuleTarget{ Schema: &targetSchema, Table: &targetTable, } @@ -578,11 +557,7 @@ func TestConvertBetweenOpenAPITaskAndTaskConfig(t *testing.T) { require.EqualValues(t, taskAfterConvert, &task) // no route and sync one schema - task.TableMigrateRule[0].Source = struct { - Schema string `json:"schema"` - SourceName string `json:"source_name"` - Table string `json:"table"` - }{ + task.TableMigrateRule[0].Source = openapi.TaskTableMigrateRuleSource{ SourceName: source1Name, Schema: sourceSchema, Table: "", diff --git a/dm/openapi/gen.server.go b/dm/openapi/gen.server.go index 1b1b4d48027..a9608ce1d33 100644 --- a/dm/openapi/gen.server.go +++ b/dm/openapi/gen.server.go @@ -1320,43 +1320,43 @@ var swaggerSpec = []string{ "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", - "7f8FAAD//wuB/EzIvQAA", + "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", } // GetSwagger returns the content of the embedded swagger specification file diff --git a/dm/openapi/gen.types.go b/dm/openapi/gen.types.go index 3af0810e682..4e747dfdf0d 100644 --- a/dm/openapi/gen.types.go +++ b/dm/openapi/gen.types.go @@ -703,25 +703,31 @@ type TaskTableMigrateRule struct { BinlogFilterRule *[]string `json:"binlog_filter_rule,omitempty"` // source-related configuration - Source struct { - // schema name, wildcard support - Schema string `json:"schema"` + Source TaskTableMigrateRuleSource `json:"source"` - // source name - SourceName string `json:"source_name"` + // downstream-related configuration + Target *TaskTableMigrateRuleTarget `json:"target,omitempty"` +} - // table name, wildcard support - Table string `json:"table"` - } `json:"source"` +// source-related configuration +type TaskTableMigrateRuleSource struct { + // schema name, wildcard support + Schema string `json:"schema"` - // downstream-related configuration - Target *struct { - // schema name, does not support wildcards - Schema *string `json:"schema,omitempty"` + // source name + SourceName string `json:"source_name"` + + // table name, wildcard support + Table string `json:"table"` +} + +// downstream-related configuration +type TaskTableMigrateRuleTarget struct { + // schema name, does not support wildcards + Schema *string `json:"schema,omitempty"` - // table name, does not support wildcards - Table *string `json:"table,omitempty"` - } `json:"target,omitempty"` + // table name, does not support wildcards + Table *string `json:"table,omitempty"` } // downstream database configuration diff --git a/dm/openapi/spec/dm.yaml b/dm/openapi/spec/dm.yaml index b6de1b9c9db..69a082ea2cb 100644 --- a/dm/openapi/spec/dm.yaml +++ b/dm/openapi/spec/dm.yaml @@ -1412,6 +1412,37 @@ components: - "user" - "enable_gtid" - "enable" + TaskTableMigrateRuleSource: + description: source-related configuration + properties: + source_name: + type: string + description: source name + example: "source-name" + schema: + type: string + description: schema name, wildcard support + example: "db-*" + table: + type: string + description: table name, wildcard support + example: "tb-*" + required: + - "source_name" + - "schema" + - "table" + TaskTableMigrateRuleTarget: + type: object + description: downstream-related configuration + properties: + schema: + type: string + description: schema name, does not support wildcards + example: "db1" + table: + type: string + description: table name, does not support wildcards + example: "tb1" ShardingGroup: type: object properties: @@ -1646,37 +1677,9 @@ components: description: "upstream table to downstream migrate rules" properties: source: - type: object - description: source-related configuration - properties: - source_name: - type: string - description: source name - example: "source-name" - schema: - type: string - description: schema name, wildcard support - example: "db-*" - table: - type: string - description: table name, wildcard support - example: "tb-*" - required: - - "source_name" - - "schema" - - "table" + $ref: "#/components/schemas/TaskTableMigrateRuleSource" target: - type: object - description: downstream-related configuration - properties: - schema: - type: string - description: schema name, does not support wildcards - example: "db1" - table: - type: string - description: table name, does not support wildcards - example: "tb1" + $ref: "#/components/schemas/TaskTableMigrateRuleTarget" binlog_filter_rule: type: array description: "filter rule name"