Skip to content

Commit

Permalink
Apply suggestions from code review
Browse files Browse the repository at this point in the history
Co-authored-by: Bartlomiej Plotka <[email protected]>
Signed-off-by: Manuel Rüger <[email protected]>
  • Loading branch information
mrueg and bwplotka committed Jun 5, 2024
1 parent 9fea575 commit 140db7a
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 37 deletions.
43 changes: 14 additions & 29 deletions prometheus/promhttp/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ func HandlerForTransactional(reg prometheus.TransactionalGatherer, opts HandlerO
}
rsp.Header().Set(contentTypeHeader, string(contentType))

w, encodingHeader, closeWriter, err := NegotiateEncodingWriter(req, rsp, opts.DisableCompression, compressions)
w, encodingHeader, closeWriter, err := negotiateEncodingWriter(req, rsp, compressions)
if err != nil {
if opts.ErrorLog != nil {
opts.ErrorLog.Println("error getting writer", err)
Expand All @@ -199,16 +199,7 @@ func HandlerForTransactional(reg prometheus.TransactionalGatherer, opts HandlerO
encodingHeader = string(Identity)
}

if closeWriter != nil {
defer func() {
err := closeWriter()
if err != nil {
if opts.ErrorLog != nil {
opts.ErrorLog.Println("error closing writer:", err)
}
}
}()
}
defer closeWriter()

rsp.Header().Set(contentEncodingHeader, encodingHeader)

Expand Down Expand Up @@ -440,41 +431,35 @@ func httpError(rsp http.ResponseWriter, err error) {
// selects the right compression based on an allow-list of supported
// compressions. It returns a writer implementing the compression and an the
// correct value that the caller can set in the response header.
func NegotiateEncodingWriter(r *http.Request, rw io.Writer, disableCompression bool, compressions []string) (_ io.Writer, encodingHeaderValue string, closeWriter func() error, _ error) {
w := rw

if disableCompression {
return w, string(Identity), nil, nil
func negotiateEncodingWriter(r *http.Request, rw io.Writer, compressions []string) (_ io.Writer, encodingHeaderValue string, closeWriter func(), _ error) {
if len(compressions) == 0 {
return rw, string(Identity), func() {}, nil
}

// TODO(mrueg): Replace internal/github.com/gddo once https://github.com/golang/go/issues/19307 is implemented.
compression := httputil.NegotiateContentEncoding(r, compressions)
selected := httputil.NegotiateContentEncoding(r, compressions)

switch compression {
switch selected {
case "zstd":
// TODO(mrueg): Replace klauspost/compress with stdlib implementation once https://github.com/golang/go/issues/62513 is implemented.
z, err := zstd.NewWriter(rw, zstd.WithEncoderLevel(zstd.SpeedFastest))
if err != nil {
return nil, "", nil, err
return nil, "", func() {}, err
}

z.Reset(w)
w = z

return w, compression, z.Close, nil
z.Reset(rw)
return z, selected, func() { _ = z.Close() }, nil
case "gzip":
gz := gzipPool.Get().(*gzip.Writer)
defer gzipPool.Put(gz)

gz.Reset(w)

w = gz
return w, compression, gz.Close, nil
gz.Reset(rw)
return gz, selected, func() { _ = gz.Close(); gzipPool.Put(gz) }, nil
case "identity":
// This means the content is not compressed.
return w, compression, nil, nil
return rw, selected, func() {}, nil
default:
// The content encoding was not implemented yet.
return nil, "", nil, fmt.Errorf("content compression format not recognized: %s. Valid formats are: %s", compression, defaultCompressionFormats)
return nil, "", func() {}, fmt.Errorf("content compression format not recognized: %s. Valid formats are: %s", selected, defaultCompressionFormats)
}
}
10 changes: 2 additions & 8 deletions prometheus/promhttp/http_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -490,47 +490,41 @@ func TestNegotiateEncodingWriter(t *testing.T) {

testCases := []struct {
name string
disableCompression bool
offeredCompressions []string
acceptEncoding string
expectedCompression string
err error
}{
{
name: "test without compression enabled",
disableCompression: true,
offeredCompressions: defaultCompressions,
offeredCompressions: []string{},
acceptEncoding: "",
expectedCompression: "identity",
err: nil,
},
{
name: "test with compression enabled with empty accept-encoding header",
disableCompression: false,
offeredCompressions: defaultCompressions,
acceptEncoding: "",
expectedCompression: "identity",
err: nil,
},
{
name: "test with gzip compression requested",
disableCompression: false,
offeredCompressions: defaultCompressions,
acceptEncoding: "gzip",
expectedCompression: "gzip",
err: nil,
},
{
name: "test with gzip, zstd compression requested",
disableCompression: false,
offeredCompressions: defaultCompressions,
acceptEncoding: "gzip,zstd",
expectedCompression: "gzip",
err: nil,
},
{
name: "test with zstd, gzip compression requested",
disableCompression: false,
offeredCompressions: defaultCompressions,
acceptEncoding: "zstd,gzip",
expectedCompression: "gzip",
Expand All @@ -542,7 +536,7 @@ func TestNegotiateEncodingWriter(t *testing.T) {
request, _ := http.NewRequest("GET", "/", nil)
request.Header.Add(acceptEncodingHeader, test.acceptEncoding)
rr := httptest.NewRecorder()
_, encodingHeader, _, err := NegotiateEncodingWriter(request, rr, test.disableCompression, test.offeredCompressions)
_, encodingHeader, _, err := negotiateEncodingWriter(request, rr, test.offeredCompressions)

if !errors.Is(err, test.err) {
t.Errorf("got error: %v, expected: %v", err, test.err)
Expand Down

0 comments on commit 140db7a

Please sign in to comment.