From 5c982c69356a236ad149f5b94b2eddacc0852a73 Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Wed, 6 Nov 2024 15:51:37 +0100 Subject: [PATCH 1/5] feat: added a flag to compress files --- .../service/cli/cmd/remote/file/download/cmd.go | 16 +++++++++------- .../project/remote/file/download/options.go | 11 ++++++----- 2 files changed, 15 insertions(+), 12 deletions(-) diff --git a/internal/pkg/service/cli/cmd/remote/file/download/cmd.go b/internal/pkg/service/cli/cmd/remote/file/download/cmd.go index 160b5548de..dbdf1435d1 100644 --- a/internal/pkg/service/cli/cmd/remote/file/download/cmd.go +++ b/internal/pkg/service/cli/cmd/remote/file/download/cmd.go @@ -15,10 +15,11 @@ import ( ) type Flags struct { - StorageAPIHost configmap.Value[string] `configKey:"storage-api-host" configShorthand:"H" configUsage:"storage API host, eg. \"connection.keboola.com\""` - StorageAPIToken configmap.Value[string] `configKey:"storage-api-token" configShorthand:"t" configUsage:"storage API token from your project"` - Output configmap.Value[string] `configKey:"output" configShorthand:"o" configUsage:"path to the destination file or directory"` - AllowSliced configmap.Value[bool] `configKey:"allow-sliced" configUsage:"output sliced files as a directory containing slices as individual files"` + StorageAPIHost configmap.Value[string] `configKey:"storage-api-host" configShorthand:"H" configUsage:"storage API host, eg. \"connection.keboola.com\""` + StorageAPIToken configmap.Value[string] `configKey:"storage-api-token" configShorthand:"t" configUsage:"storage API token from your project"` + Output configmap.Value[string] `configKey:"output" configShorthand:"o" configUsage:"path to the destination file or directory"` + AllowSliced configmap.Value[bool] `configKey:"allow-sliced" configUsage:"output sliced files as a directory containing slices as individual files"` + WithOutDecompress configmap.Value[bool] `configKey:"without-decompress" configUsage:"treat the sliced files as individual files, without decompressing them."` } func DefaultFlags() Flags { @@ -83,9 +84,10 @@ func Command(p dependencies.Provider) *cobra.Command { defer d.EventSender().SendCmdEvent(cmd.Context(), time.Now(), &cmdErr, "remote-file-download") opts := download.Options{ - File: file, - Output: output, - AllowSliced: f.AllowSliced.Value, + File: file, + Output: output, + AllowSliced: f.AllowSliced.Value, + WithOutDecompress: f.WithOutDecompress, } return download.Run(cmd.Context(), opts, d) diff --git a/pkg/lib/operation/project/remote/file/download/options.go b/pkg/lib/operation/project/remote/file/download/options.go index 90e908ffd2..b4296f202a 100644 --- a/pkg/lib/operation/project/remote/file/download/options.go +++ b/pkg/lib/operation/project/remote/file/download/options.go @@ -9,11 +9,12 @@ import ( ) type Options struct { - File *keboola.FileDownloadCredentials - Output string - AllowSliced bool - Columns []string - Header configmap.Value[bool] + File *keboola.FileDownloadCredentials + Output string + AllowSliced bool + Columns []string + Header configmap.Value[bool] + WithOutDecompress configmap.Value[bool] } func (o *Options) ToStdout() bool { From a486da34ab65b3814420573aefa289dc89f74108 Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Wed, 6 Nov 2024 15:52:10 +0100 Subject: [PATCH 2/5] feat: implementation --- .../project/remote/file/download/operation.go | 22 ++++++++++--------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/pkg/lib/operation/project/remote/file/download/operation.go b/pkg/lib/operation/project/remote/file/download/operation.go index 2c836e12a6..442e32b007 100644 --- a/pkg/lib/operation/project/remote/file/download/operation.go +++ b/pkg/lib/operation/project/remote/file/download/operation.go @@ -168,16 +168,18 @@ func (d *downloader) readSliceTo(ctx context.Context, slice string, writer io.Wr } // Add decompression reader - if strings.HasSuffix(slice, GZIPFileExt) || (slice == "" && strings.HasSuffix(d.options.File.Name, GZIPFileExt)) { - if gzipReader, err := pgzip.NewReader(reader); err == nil { - defer func() { - if closeErr := gzipReader.Close(); returnErr == nil && closeErr != nil { - returnErr = closeErr - } - }() - reader = gzipReader - } else { - return errors.Errorf(`cannot create gzip reader: %w`, err) + if !d.options.WithOutDecompress.IsSet() { + if strings.HasSuffix(slice, GZIPFileExt) || (slice == "" && strings.HasSuffix(d.options.File.Name, GZIPFileExt)) { + if gzipReader, err := pgzip.NewReader(reader); err == nil { + defer func() { + if closeErr := gzipReader.Close(); returnErr == nil && closeErr != nil { + returnErr = closeErr + } + }() + reader = gzipReader + } else { + return errors.Errorf(`cannot create gzip reader: %w`, err) + } } } From 5f463008f3d87facbff4e798ea87765b6df09f5f Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Wed, 6 Nov 2024 15:52:43 +0100 Subject: [PATCH 3/5] tests: e2e tests --- .../download-file-disk-without-decompress/args | 1 + .../expected-code | 1 + .../expected-stderr | 1 + .../expected-stdout | 1 + .../in/.gitkeep | 0 .../in/description.md | 0 .../initial-state.json | 18 ++++++++++++++++++ .../out/.gitkeep | 0 .../out/description.md | 0 .../out/file.csv.gz | 1 + 10 files changed, 23 insertions(+) create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/args create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/expected-code create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/expected-stderr create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/expected-stdout create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/in/.gitkeep create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/in/description.md create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/initial-state.json create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/out/.gitkeep create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/out/description.md create mode 100644 test/cli/remote-file/download-file-disk-without-decompress/out/file.csv.gz diff --git a/test/cli/remote-file/download-file-disk-without-decompress/args b/test/cli/remote-file/download-file-disk-without-decompress/args new file mode 100644 index 0000000000..686e124102 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/args @@ -0,0 +1 @@ +remote file download %%TEST_FILE_TEST1_ID%% --output file.csv.gz --without-decompress --storage-api-host %%TEST_KBC_STORAGE_API_HOST%% --storage-api-token %%TEST_KBC_STORAGE_API_TOKEN%% diff --git a/test/cli/remote-file/download-file-disk-without-decompress/expected-code b/test/cli/remote-file/download-file-disk-without-decompress/expected-code new file mode 100644 index 0000000000..573541ac97 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/expected-code @@ -0,0 +1 @@ +0 diff --git a/test/cli/remote-file/download-file-disk-without-decompress/expected-stderr b/test/cli/remote-file/download-file-disk-without-decompress/expected-stderr new file mode 100644 index 0000000000..95982b5fd1 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/expected-stderr @@ -0,0 +1 @@ +%ADownloading%A diff --git a/test/cli/remote-file/download-file-disk-without-decompress/expected-stdout b/test/cli/remote-file/download-file-disk-without-decompress/expected-stdout new file mode 100644 index 0000000000..8d2bae91a0 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/expected-stdout @@ -0,0 +1 @@ +File "%%TEST_FILE_TEST1_ID%%" downloaded to "file.csv.gz". diff --git a/test/cli/remote-file/download-file-disk-without-decompress/in/.gitkeep b/test/cli/remote-file/download-file-disk-without-decompress/in/.gitkeep new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/remote-file/download-file-disk-without-decompress/in/description.md b/test/cli/remote-file/download-file-disk-without-decompress/in/description.md new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/remote-file/download-file-disk-without-decompress/initial-state.json b/test/cli/remote-file/download-file-disk-without-decompress/initial-state.json new file mode 100644 index 0000000000..9af15cd067 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/initial-state.json @@ -0,0 +1,18 @@ +{ + "branches": [ + { + "branch": { + "name": "Main", + "description": "", + "isDefault": true + }, + "configs": [] + } + ], + "files": [ + { + "name": "test1", + "content": "H4sIAAAAAAAAA0vOzzHUSc7PMeIqSwSygASYZQximQAAVQ0b1R0AAAA=" + } + ] +} diff --git a/test/cli/remote-file/download-file-disk-without-decompress/out/.gitkeep b/test/cli/remote-file/download-file-disk-without-decompress/out/.gitkeep new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/remote-file/download-file-disk-without-decompress/out/description.md b/test/cli/remote-file/download-file-disk-without-decompress/out/description.md new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/remote-file/download-file-disk-without-decompress/out/file.csv.gz b/test/cli/remote-file/download-file-disk-without-decompress/out/file.csv.gz new file mode 100644 index 0000000000..4424927b05 --- /dev/null +++ b/test/cli/remote-file/download-file-disk-without-decompress/out/file.csv.gz @@ -0,0 +1 @@ +H4sIAAAAAAAAA0vOzzHUSc7PMeIqSwSygASYZQximQAAVQ0b1R0AAAA= From 4f4f88cadc5914f6d2f27b7500e0cbc980b76f31 Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Wed, 13 Nov 2024 09:14:04 +0100 Subject: [PATCH 4/5] fix:update usage description --- internal/pkg/service/cli/cmd/remote/file/download/cmd.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/internal/pkg/service/cli/cmd/remote/file/download/cmd.go b/internal/pkg/service/cli/cmd/remote/file/download/cmd.go index dbdf1435d1..152c16719b 100644 --- a/internal/pkg/service/cli/cmd/remote/file/download/cmd.go +++ b/internal/pkg/service/cli/cmd/remote/file/download/cmd.go @@ -19,7 +19,7 @@ type Flags struct { StorageAPIToken configmap.Value[string] `configKey:"storage-api-token" configShorthand:"t" configUsage:"storage API token from your project"` Output configmap.Value[string] `configKey:"output" configShorthand:"o" configUsage:"path to the destination file or directory"` AllowSliced configmap.Value[bool] `configKey:"allow-sliced" configUsage:"output sliced files as a directory containing slices as individual files"` - WithOutDecompress configmap.Value[bool] `configKey:"without-decompress" configUsage:"treat the sliced files as individual files, without decompressing them."` + WithoutDecompress configmap.Value[bool] `configKey:"without-decompress" configUsage:"do not decompress the downloaded files or sliced files."` } func DefaultFlags() Flags { @@ -87,7 +87,7 @@ func Command(p dependencies.Provider) *cobra.Command { File: file, Output: output, AllowSliced: f.AllowSliced.Value, - WithOutDecompress: f.WithOutDecompress, + WithOutDecompress: f.WithoutDecompress, } return download.Run(cmd.Context(), opts, d) From b5a217ab09b7283f325025c2ab40d2c94c2b52ba Mon Sep 17 00:00:00 2001 From: Petr Hosek Date: Wed, 13 Nov 2024 14:23:44 +0100 Subject: [PATCH 5/5] test: added help test --- test/cli/help/remote-file-download/args | 1 + test/cli/help/remote-file-download/expected-code | 1 + .../help/remote-file-download/expected-stderr | 0 .../help/remote-file-download/expected-stdout | 16 ++++++++++++++++ test/cli/help/remote-file-download/in/.gitkeep | 0 .../help/remote-file-download/in/description.md | 0 test/cli/help/remote-file-download/out/.gitkeep | 0 .../help/remote-file-download/out/description.md | 0 8 files changed, 18 insertions(+) create mode 100644 test/cli/help/remote-file-download/args create mode 100644 test/cli/help/remote-file-download/expected-code create mode 100644 test/cli/help/remote-file-download/expected-stderr create mode 100644 test/cli/help/remote-file-download/expected-stdout create mode 100644 test/cli/help/remote-file-download/in/.gitkeep create mode 100644 test/cli/help/remote-file-download/in/description.md create mode 100644 test/cli/help/remote-file-download/out/.gitkeep create mode 100644 test/cli/help/remote-file-download/out/description.md diff --git a/test/cli/help/remote-file-download/args b/test/cli/help/remote-file-download/args new file mode 100644 index 0000000000..37bbb9f1d1 --- /dev/null +++ b/test/cli/help/remote-file-download/args @@ -0,0 +1 @@ +remote file download --help diff --git a/test/cli/help/remote-file-download/expected-code b/test/cli/help/remote-file-download/expected-code new file mode 100644 index 0000000000..573541ac97 --- /dev/null +++ b/test/cli/help/remote-file-download/expected-code @@ -0,0 +1 @@ +0 diff --git a/test/cli/help/remote-file-download/expected-stderr b/test/cli/help/remote-file-download/expected-stderr new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/help/remote-file-download/expected-stdout b/test/cli/help/remote-file-download/expected-stdout new file mode 100644 index 0000000000..e6eb05756b --- /dev/null +++ b/test/cli/help/remote-file-download/expected-stdout @@ -0,0 +1,16 @@ +Command "remote file download" + +Download a file from Keboola staging storage and save it to a local file or output to stdout. + +Usage: + kbc remote file download [file] [flags] + +Flags: + --allow-sliced output sliced files as a directory containing slices as individual files + -o, --output string path to the destination file or directory + -H, --storage-api-host string storage API host, eg. "connection.keboola.com" + -t, --storage-api-token string storage API token from your project + --without-decompress do not decompress the downloaded files or sliced files. + +Global Flags: +%A diff --git a/test/cli/help/remote-file-download/in/.gitkeep b/test/cli/help/remote-file-download/in/.gitkeep new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/help/remote-file-download/in/description.md b/test/cli/help/remote-file-download/in/description.md new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/help/remote-file-download/out/.gitkeep b/test/cli/help/remote-file-download/out/.gitkeep new file mode 100644 index 0000000000..e69de29bb2 diff --git a/test/cli/help/remote-file-download/out/description.md b/test/cli/help/remote-file-download/out/description.md new file mode 100644 index 0000000000..e69de29bb2