diff --git a/CHANGELOG.md b/CHANGELOG.md index ba968d4b9..74b9aba0a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,13 @@ ## Unreleased +## 1.18.0 / 2023-12-22 + +* [FEATURE] promlint: Allow creation of custom metric validations. #1311 +* [FEATURE] Go programs using client_golang can be built in wasip1 OS. #1350 +* [BUGFIX] histograms: Add timer to reset ASAP after bucket limiting has happened. #1367 +* [BUGFIX] testutil: Fix comparison of metrics with empty Help strings. #1378 +* [ENHANCEMENT] Improved performance of `MetricVec.WithLabelValues(...)`. #1360 + ## 1.17.0 / 2023-09-27 * [CHANGE] Minimum required go version is now 1.19 (we also test client_golang against new 1.21 version). #1325 diff --git a/VERSION b/VERSION index 092afa15d..84cc52946 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -1.17.0 +1.18.0 diff --git a/api/client.go b/api/client.go index 657705882..72a01309c 100644 --- a/api/client.go +++ b/api/client.go @@ -36,18 +36,14 @@ var DefaultRoundTripper http.RoundTripper = &http.Transport{ TLSHandshakeTimeout: 10 * time.Second, } -type HttpClient interface { - Do(req *http.Request) (*http.Response, error) -} - // Config defines configuration parameters for a new client. type Config struct { // The address of the Prometheus to connect to. Address string // Client is used by the Client to drive HTTP requests. If not provided, - // a new http.Client based on the provided RoundTripper (or DefaultRoundTripper) will be used. - Client HttpClient + // a new one based on the provided RoundTripper (or DefaultRoundTripper) will be used. + Client *http.Client // RoundTripper is used by the Client to drive HTTP requests. If not // provided, DefaultRoundTripper will be used. @@ -61,13 +57,13 @@ func (cfg *Config) roundTripper() http.RoundTripper { return cfg.RoundTripper } -func (cfg *Config) client() HttpClient { +func (cfg *Config) client() http.Client { if cfg.Client == nil { - return &http.Client{ + return http.Client{ Transport: cfg.roundTripper(), } } - return cfg.Client + return *cfg.Client } func (cfg *Config) validate() error { @@ -105,7 +101,7 @@ func NewClient(cfg Config) (Client, error) { type httpClient struct { endpoint *url.URL - client HttpClient + client http.Client } func (c *httpClient) URL(ep string, args map[string]string) *url.URL { diff --git a/api/client_test.go b/api/client_test.go index ceb704708..874387868 100644 --- a/api/client_test.go +++ b/api/client_test.go @@ -105,7 +105,7 @@ func TestClientURL(t *testing.T) { hclient := &httpClient{ endpoint: ep, - client: &http.Client{Transport: DefaultRoundTripper}, + client: http.Client{Transport: DefaultRoundTripper}, } u := hclient.URL(test.endpoint, test.args)