From 56d704e3037840aeb87b22cc83f2b6088c79bcee Mon Sep 17 00:00:00 2001 From: Brenna N Epp Date: Wed, 8 Jan 2025 13:10:01 -0800 Subject: [PATCH] fix(storage): return the appropriate error for method not supported (#11416) --- storage/http_client.go | 2 +- storage/storage.go | 6 +++--- storage/storage_test.go | 8 ++++---- 3 files changed, 8 insertions(+), 8 deletions(-) diff --git a/storage/http_client.go b/storage/http_client.go index abbb30a347e6..61b20555f449 100644 --- a/storage/http_client.go +++ b/storage/http_client.go @@ -863,7 +863,7 @@ func (c *httpStorageClient) RewriteObject(ctx context.Context, req *rewriteObjec // NewMultiRangeDownloader is not supported by http client. func (c *httpStorageClient) NewMultiRangeDownloader(ctx context.Context, params *newMultiRangeDownloaderParams, opts ...storageOption) (mr *MultiRangeDownloader, err error) { - return nil, errMethodNotValid + return nil, errMethodNotSupported } func (c *httpStorageClient) NewRangeReader(ctx context.Context, params *newRangeReaderParams, opts ...storageOption) (r *Reader, err error) { diff --git a/storage/storage.go b/storage/storage.go index 6e9615d68465..71bc5aaf92fe 100644 --- a/storage/storage.go +++ b/storage/storage.go @@ -72,8 +72,8 @@ var ( // errMethodNotSupported indicates that the method called is not currently supported by the client. // TODO: Export this error when launching the transport-agnostic client. errMethodNotSupported = errors.New("storage: method is not currently supported") - // errMethodNotValid indicates that given HTTP method is not valid. - errMethodNotValid = fmt.Errorf("storage: HTTP method should be one of %v", reflect.ValueOf(signedURLMethods).MapKeys()) + // errSignedURLMethodNotValid indicates that given HTTP method is not valid. + errSignedURLMethodNotValid = fmt.Errorf("storage: HTTP method should be one of %v", reflect.ValueOf(signedURLMethods).MapKeys()) ) var userAgent = fmt.Sprintf("gcloud-golang-storage/%s", internal.Version) @@ -689,7 +689,7 @@ func validateOptions(opts *SignedURLOptions, now time.Time) error { } opts.Method = strings.ToUpper(opts.Method) if _, ok := signedURLMethods[opts.Method]; !ok { - return errMethodNotValid + return errSignedURLMethodNotValid } if opts.Expires.IsZero() { return errors.New("storage: missing required expires option") diff --git a/storage/storage_test.go b/storage/storage_test.go index 0715e39ae611..56f9bfd2eda4 100644 --- a/storage/storage_test.go +++ b/storage/storage_test.go @@ -540,7 +540,7 @@ func TestSignedURL_MissingOptions(t *testing.T) { GoogleAccessID: "access_id", PrivateKey: pk, }, - errMethodNotValid.Error(), + errSignedURLMethodNotValid.Error(), }, { &SignedURLOptions{ @@ -548,7 +548,7 @@ func TestSignedURL_MissingOptions(t *testing.T) { PrivateKey: pk, Method: "getMethod", // wrong method name }, - errMethodNotValid.Error(), + errSignedURLMethodNotValid.Error(), }, { &SignedURLOptions{ @@ -563,7 +563,7 @@ func TestSignedURL_MissingOptions(t *testing.T) { GoogleAccessID: "access_id", SignBytes: func(b []byte) ([]byte, error) { return b, nil }, }, - errMethodNotValid.Error(), + errSignedURLMethodNotValid.Error(), }, { &SignedURLOptions{ @@ -611,7 +611,7 @@ func TestSignedURL_MissingOptions(t *testing.T) { Expires: expires, Scheme: SigningSchemeV4, }, - errMethodNotValid.Error(), + errSignedURLMethodNotValid.Error(), }, { &SignedURLOptions{