From c99b8cc5fe415447391b1d3b2d1489bead4d2c37 Mon Sep 17 00:00:00 2001 From: Elias Kassell Date: Tue, 26 Mar 2024 14:25:59 +0000 Subject: [PATCH 1/2] Fix CLI tags, allow comma delisted tags, add test --- cli/index.ts | 12 +++++++++++- cli/index_test.ts | 11 +++++++---- docs/configs-reference.md | 2 +- protos/configs.proto | 2 +- 4 files changed, 20 insertions(+), 7 deletions(-) diff --git a/cli/index.ts b/cli/index.ts index 43507a96e..2294cab7f 100644 --- a/cli/index.ts +++ b/cli/index.ts @@ -86,7 +86,16 @@ const tagsOption: INamedOption = { name: "tags", option: { describe: "A list of tags to filter the actions to run.", - type: "array" + type: "array", + coerce: (rawTags: string[] | null) => { + const tags: string[] = []; + rawTags.forEach(rawTag => + rawTag?.split(",").forEach(tag => { + tags.push(tag); + }) + ); + return tags; + } } }; @@ -469,6 +478,7 @@ export function runCli() { credentialsOption, jsonOutputOption, timeoutOption, + tagsOption, ...ProjectConfigOptions.allYargsOptions ], processFn: async argv => { diff --git a/cli/index_test.ts b/cli/index_test.ts index 3806e1de7..fd3ac80c3 100644 --- a/cli/index_test.ts +++ b/cli/index_test.ts @@ -194,7 +194,7 @@ defaultAssertionDataset: dataform_assertions fs.writeFileSync( filePath, ` -config { type: "table" } +config { type: "table", tags: ["someTag"] } select 1 as \${dataform.projectConfig.vars.testVar2} ` ); @@ -230,7 +230,8 @@ select 1 as \${dataform.projectConfig.vars.testVar2} }, query: "\n\nselect 1 as testValue2\n", disabled: false, - fileName: "definitions/example.sqlx" + fileName: "definitions/example.sqlx", + tags: ["someTag"] } ], projectConfig: { @@ -267,7 +268,8 @@ select 1 as \${dataform.projectConfig.vars.testVar2} "--dry-run", "--json", "--vars=testVar1=testValue1,testVar2=testValue2", - "--default-location=europe" + "--default-location=europe", + "--tags=someTag,someOtherTag" ]) ); @@ -306,7 +308,8 @@ select 1 as \${dataform.projectConfig.vars.testVar2} } }, runConfig: { - fullRefresh: false + fullRefresh: false, + tags: ["someTag", "someOtherTag"] }, warehouseState: {} }); diff --git a/docs/configs-reference.md b/docs/configs-reference.md index 388735de1..1402016db 100644 --- a/docs/configs-reference.md +++ b/docs/configs-reference.md @@ -39,7 +39,7 @@ ### ActionConfig -Action config defines the configuration properties of actions. +Action config defines the contents of `actions.yaml` configuration files. | Field | Type | Label | Description | diff --git a/protos/configs.proto b/protos/configs.proto index 649c2e88f..5b1b870fa 100644 --- a/protos/configs.proto +++ b/protos/configs.proto @@ -51,7 +51,7 @@ message ActionConfigs { repeated ActionConfig actions = 1; } -// Action config defines the configuration properties of actions. +// Action config defines the contents of `actions.yaml` configuration files. message ActionConfig { // Target represents a unique action identifier. message Target { From d2b90c909e2f582d38400af7318f5bea39c3da02 Mon Sep 17 00:00:00 2001 From: Elias Kassell Date: Tue, 26 Mar 2024 16:00:57 +0000 Subject: [PATCH 2/2] =?UTF-8?q?=F0=9F=A4=8C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cli/index.ts | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/cli/index.ts b/cli/index.ts index 2294cab7f..9b212bc4b 100644 --- a/cli/index.ts +++ b/cli/index.ts @@ -87,15 +87,7 @@ const tagsOption: INamedOption = { option: { describe: "A list of tags to filter the actions to run.", type: "array", - coerce: (rawTags: string[] | null) => { - const tags: string[] = []; - rawTags.forEach(rawTag => - rawTag?.split(",").forEach(tag => { - tags.push(tag); - }) - ); - return tags; - } + coerce: (rawTags: string[] | null) => rawTags.map(tags => tags.split(",")).flat() } };