diff --git a/pkg/s3-proxy/response-handler/utils.go b/pkg/s3-proxy/response-handler/utils.go index 760fc850..bcad7d87 100644 --- a/pkg/s3-proxy/response-handler/utils.go +++ b/pkg/s3-proxy/response-handler/utils.go @@ -42,8 +42,11 @@ func (h *handler) manageHeaders(helpersContent string, headersTpl map[string]str str := buf.String() // Remove all new lines str = reg.ReplaceAllString(str, "") - // Save data - res[k] = str + // Save data only if the header isn't empty + if str != "" { + // Save + res[k] = str + } } // Return diff --git a/pkg/s3-proxy/response-handler/utils_test.go b/pkg/s3-proxy/response-handler/utils_test.go index 7f9dcdd8..8e22af51 100644 --- a/pkg/s3-proxy/response-handler/utils_test.go +++ b/pkg/s3-proxy/response-handler/utils_test.go @@ -107,6 +107,19 @@ func Test_handler_manageHeaders(t *testing.T) { "h1": "fixed", }, }, + { + name: "empty header must be removed", + args: args{ + helpersContent: "", + headersTpl: map[string]string{ + "h1": "fixed", + "h2": "", + }, + }, + want: map[string]string{ + "h1": "fixed", + }, + }, } for _, tt := range tests { t.Run(tt.name, func(t *testing.T) {