Skip to content

Commit be01f3f

Browse files
committed
chore: clusterinfo.Retriever injected into collectors
1 parent 46721e1 commit be01f3f

18 files changed

+82
-23
lines changed

collector/cluster_info.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,8 @@ import (
2323

2424
"github.com/blang/semver/v4"
2525
"github.com/prometheus/client_golang/prometheus"
26+
27+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2628
)
2729

2830
func init() {
@@ -35,7 +37,7 @@ type ClusterInfoCollector struct {
3537
hc *http.Client
3638
}
3739

38-
func NewClusterInfo(logger *slog.Logger, u *url.URL, hc *http.Client) (Collector, error) {
40+
func NewClusterInfo(logger *slog.Logger, u *url.URL, hc *http.Client, ci *clusterinfo.Retriever) (Collector, error) {
3941
return &ClusterInfoCollector{
4042
logger: logger,
4143
u: u,

collector/cluster_info_test.go

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,12 @@ import (
2121
"os"
2222
"strings"
2323
"testing"
24+
"time"
2425

2526
"github.com/prometheus/client_golang/prometheus/testutil"
2627
"github.com/prometheus/common/promslog"
28+
29+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2730
)
2831

2932
func TestClusterInfo(t *testing.T) {
@@ -80,7 +83,9 @@ func TestClusterInfo(t *testing.T) {
8083
t.Fatal(err)
8184
}
8285

83-
c, err := NewClusterInfo(promslog.NewNopLogger(), u, http.DefaultClient)
86+
logger := promslog.NewNopLogger()
87+
ci := clusterinfo.New(logger, http.DefaultClient, u, time.Duration(300000000000))
88+
c, err := NewClusterInfo(logger, u, http.DefaultClient, ci)
8489
if err != nil {
8590
t.Fatal(err)
8691
}

collector/cluster_settings.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,8 @@ import (
2626

2727
"github.com/imdario/mergo"
2828
"github.com/prometheus/client_golang/prometheus"
29+
30+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2931
)
3032

3133
func init() {
@@ -38,7 +40,7 @@ type ClusterSettingsCollector struct {
3840
hc *http.Client
3941
}
4042

41-
func NewClusterSettings(logger *slog.Logger, u *url.URL, hc *http.Client) (Collector, error) {
43+
func NewClusterSettings(logger *slog.Logger, u *url.URL, hc *http.Client, ci *clusterinfo.Retriever) (Collector, error) {
4244
return &ClusterSettingsCollector{
4345
logger: logger,
4446
u: u,

collector/cluster_settings_test.go

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,12 @@ import (
2121
"os"
2222
"strings"
2323
"testing"
24+
"time"
2425

2526
"github.com/prometheus/client_golang/prometheus/testutil"
2627
"github.com/prometheus/common/promslog"
28+
29+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2730
)
2831

2932
func TestClusterSettingsStats(t *testing.T) {
@@ -136,7 +139,9 @@ elasticsearch_clustersettings_allocation_watermark_low_bytes 5.24288e+07
136139
t.Fatal(err)
137140
}
138141

139-
c, err := NewClusterSettings(promslog.NewNopLogger(), u, http.DefaultClient)
142+
logger := promslog.NewNopLogger()
143+
ci := clusterinfo.New(logger, http.DefaultClient, u, time.Duration(300000000000))
144+
c, err := NewClusterSettings(logger, u, http.DefaultClient, ci)
140145
if err != nil {
141146
t.Fatal(err)
142147
}

collector/collector.go

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,8 @@ import (
2626

2727
"github.com/alecthomas/kingpin/v2"
2828
"github.com/prometheus/client_golang/prometheus"
29+
30+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2931
)
3032

3133
const (
@@ -36,7 +38,7 @@ const (
3638
defaultDisabled = false
3739
)
3840

39-
type factoryFunc func(logger *slog.Logger, u *url.URL, hc *http.Client) (Collector, error)
41+
type factoryFunc func(logger *slog.Logger, u *url.URL, hc *http.Client, ci *clusterinfo.Retriever) (Collector, error)
4042

4143
var (
4244
factories = make(map[string]factoryFunc)
@@ -97,7 +99,7 @@ type ElasticsearchCollector struct {
9799
type Option func(*ElasticsearchCollector) error
98100

99101
// NewElasticsearchCollector creates a new ElasticsearchCollector
100-
func NewElasticsearchCollector(logger *slog.Logger, filters []string, options ...Option) (*ElasticsearchCollector, error) {
102+
func NewElasticsearchCollector(logger *slog.Logger, filters []string, clusterInfoRetriever *clusterinfo.Retriever, options ...Option) (*ElasticsearchCollector, error) {
101103
e := &ElasticsearchCollector{logger: logger}
102104
// Apply options to customize the collector
103105
for _, o := range options {
@@ -127,7 +129,7 @@ func NewElasticsearchCollector(logger *slog.Logger, filters []string, options ..
127129
if collector, ok := initiatedCollectors[key]; ok {
128130
collectors[key] = collector
129131
} else {
130-
collector, err := factories[key](logger.With("collector", key), e.esURL, e.httpClient)
132+
collector, err := factories[key](logger.With("collector", key), e.esURL, e.httpClient, clusterInfoRetriever)
131133
if err != nil {
132134
return nil, err
133135
}

collector/data_stream.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,8 @@ import (
2222
"net/url"
2323

2424
"github.com/prometheus/client_golang/prometheus"
25+
26+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2527
)
2628

2729
var (
@@ -51,7 +53,7 @@ type DataStream struct {
5153
}
5254

5355
// NewDataStream defines DataStream Prometheus metrics
54-
func NewDataStream(logger *slog.Logger, u *url.URL, hc *http.Client) (Collector, error) {
56+
func NewDataStream(logger *slog.Logger, u *url.URL, hc *http.Client, ci *clusterinfo.Retriever) (Collector, error) {
5557
return &DataStream{
5658
logger: logger,
5759
hc: hc,

collector/data_stream_test.go

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,12 @@ import (
2121
"os"
2222
"strings"
2323
"testing"
24+
"time"
2425

2526
"github.com/prometheus/client_golang/prometheus/testutil"
2627
"github.com/prometheus/common/promslog"
28+
29+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2730
)
2831

2932
func TestDataStream(t *testing.T) {
@@ -64,7 +67,9 @@ func TestDataStream(t *testing.T) {
6467
t.Fatal(err)
6568
}
6669

67-
c, err := NewDataStream(promslog.NewNopLogger(), u, http.DefaultClient)
70+
logger := promslog.NewNopLogger()
71+
ci := clusterinfo.New(logger, http.DefaultClient, u, time.Duration(300000000000))
72+
c, err := NewDataStream(logger, u, http.DefaultClient, ci)
6873
if err != nil {
6974
t.Fatal(err)
7075
}

collector/health_report.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,8 @@ import (
2121
"net/url"
2222

2323
"github.com/prometheus/client_golang/prometheus"
24+
25+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2426
)
2527

2628
var (
@@ -166,7 +168,7 @@ type HealthReport struct {
166168
url *url.URL
167169
}
168170

169-
func NewHealthReport(logger *slog.Logger, url *url.URL, client *http.Client) (Collector, error) {
171+
func NewHealthReport(logger *slog.Logger, url *url.URL, client *http.Client, ci *clusterinfo.Retriever) (Collector, error) {
170172
return &HealthReport{
171173
logger: logger,
172174
client: client,

collector/health_report_test.go

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,9 +21,12 @@ import (
2121
"os"
2222
"strings"
2323
"testing"
24+
"time"
2425

2526
"github.com/prometheus/client_golang/prometheus/testutil"
2627
"github.com/prometheus/common/promslog"
28+
29+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2730
)
2831

2932
func TestHealthReport(t *testing.T) {
@@ -156,7 +159,9 @@ func TestHealthReport(t *testing.T) {
156159
t.Fatal(err)
157160
}
158161

159-
c, err := NewHealthReport(promslog.NewNopLogger(), u, http.DefaultClient)
162+
logger := promslog.NewNopLogger()
163+
ci := clusterinfo.New(logger, http.DefaultClient, u, time.Duration(300000000000))
164+
c, err := NewHealthReport(logger, u, http.DefaultClient, ci)
160165
if err != nil {
161166
t.Fatal(err)
162167
}

collector/ilm.go

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,8 @@ import (
2222
"net/url"
2323

2424
"github.com/prometheus/client_golang/prometheus"
25+
26+
"github.com/prometheus-community/elasticsearch_exporter/pkg/clusterinfo"
2527
)
2628

2729
var (
@@ -49,7 +51,7 @@ type ILM struct {
4951
u *url.URL
5052
}
5153

52-
func NewILM(logger *slog.Logger, u *url.URL, hc *http.Client) (Collector, error) {
54+
func NewILM(logger *slog.Logger, u *url.URL, hc *http.Client, ci *clusterinfo.Retriever) (Collector, error) {
5355
return &ILM{
5456
logger: logger,
5557
hc: hc,

0 commit comments

Comments
 (0)