diff --git a/br/pkg/storage/parse_test.go b/br/pkg/storage/parse_test.go index 90f72d0778407..20e441f86aecf 100644 --- a/br/pkg/storage/parse_test.go +++ b/br/pkg/storage/parse_test.go @@ -194,3 +194,49 @@ func TestFormatBackendURL(t *testing.T) { }) require.Equal(t, "azure://bucket/some%20prefix/", backendURL.String()) } + +func TestParseRawURL(t *testing.T) { + cases := []struct { + url string + schema string + host string + path string + accessKey string + secretAccessKey string + }{ + { + url: `s3://bucket/prefix/path?access-key=NXN7IPIOSAAKDEEOLMAF&secret-access-key=nREY/7DtPaIbYKrKlEEMMF/ExCiJEX=XMLPUANw`, + schema: "s3", + host: "bucket", + path: "/prefix/path", + accessKey: "NXN7IPIOSAAKDEEOLMAF", // fake ak/sk + secretAccessKey: "nREY/7DtPaIbYKrKlEEMMF/ExCiJEX=XMLPUANw", // w/o "+" + }, + { + url: `s3://bucket/prefix/path?access-key=NXN7IPIOSAAKDEEOLMAF&secret-access-key=nREY/7Dt+PaIbYKrKlEEMMF/ExCiJEX=XMLPUANw`, + schema: "s3", + host: "bucket", + path: "/prefix/path", + accessKey: "NXN7IPIOSAAKDEEOLMAF", // fake ak/sk + secretAccessKey: "nREY/7Dt+PaIbYKrKlEEMMF/ExCiJEX=XMLPUANw", // with "+" + }, + } + + for _, c := range cases { + storageRawURL := c.url + storageURL, err := ParseRawURL(storageRawURL) + require.NoError(t, err) + + require.Equal(t, c.schema, storageURL.Scheme) + require.Equal(t, c.host, storageURL.Host) + require.Equal(t, c.path, storageURL.Path) + + require.Equal(t, 1, len(storageURL.Query()["access-key"])) + accessKey := storageURL.Query()["access-key"][0] + require.Equal(t, c.accessKey, accessKey) + + require.Equal(t, 1, len(storageURL.Query()["secret-access-key"])) + secretAccessKey := storageURL.Query()["secret-access-key"][0] + require.Equal(t, c.secretAccessKey, secretAccessKey) + } +} diff --git a/executor/brie.go b/executor/brie.go index 6aa1f4e7c389b..d1c5960802058 100644 --- a/executor/brie.go +++ b/executor/brie.go @@ -16,7 +16,6 @@ package executor import ( "context" - "net/url" "strings" "sync" "sync/atomic" @@ -224,7 +223,7 @@ func (b *executorBuilder) buildBRIE(s *ast.BRIEStmt, schema *expression.Schema) }, } - storageURL, err := url.Parse(s.Storage) + storageURL, err := storage.ParseRawURL(s.Storage) if err != nil { b.err = errors.Annotate(err, "invalid destination URL") return nil