From bcf445fe88d95f8a201a03de2cd0c36d691a6c8c Mon Sep 17 00:00:00 2001 From: Michael Okoko Date: Tue, 6 Jul 2021 01:32:59 +0100 Subject: [PATCH] Always return empty series set from WAL storage Signed-off-by: Michael Okoko --- pkg/rules/remotewrite/wal.go | 2 +- test/e2e/rule_test.go | 26 ++++++++++++++------------ 2 files changed, 15 insertions(+), 13 deletions(-) diff --git a/pkg/rules/remotewrite/wal.go b/pkg/rules/remotewrite/wal.go index 25b91435674..eaf08f99eb9 100644 --- a/pkg/rules/remotewrite/wal.go +++ b/pkg/rules/remotewrite/wal.go @@ -690,5 +690,5 @@ func (r *remoteWriteQueryable) Close() error { } func (r *remoteWriteQueryable) Select(sortSeries bool, hints *storage.SelectHints, matchers ...*labels.Matcher) storage.SeriesSet { - return nil + return storage.EmptySeriesSet() } diff --git a/test/e2e/rule_test.go b/test/e2e/rule_test.go index 24d8363fd03..c503a791e6b 100644 --- a/test/e2e/rule_test.go +++ b/test/e2e/rule_test.go @@ -99,6 +99,14 @@ groups: severity: page annotations: summary: "I always complain and I have been loaded via sighup signal." +` + testRuleRecordAbsentMetric = ` +groups: +- name: example_record_rules + interval: 1s + rules: + - record: test_absent_metric + expr: absent(nonexistent{job='thanos-receive'}) ` amTimeout = model.Duration(10 * time.Second) ) @@ -445,15 +453,6 @@ func TestRule(t *testing.T) { func TestRule_CanRemoteWriteData(t *testing.T) { t.Parallel() - testRuleRecordAbsentMetric := ` -groups: -- name: example_record_rules - interval: 1s - rules: - - record: test_absent_metric - expr: absent(nonexistent{job='thanos-receive'}) -` - s, err := e2e.NewScenario("e2e_test_rule_remote_write") testutil.Ok(t, err) t.Cleanup(e2ethanos.CleanScenario(t, s)) @@ -464,13 +463,16 @@ groups: rulesSubDir := "rules" rulesPath := filepath.Join(s.SharedDir(), rulesSubDir) testutil.Ok(t, os.MkdirAll(rulesPath, os.ModePerm)) - createRuleFile(t, filepath.Join(rulesPath, "rules-0.yaml"), testRuleRecordAbsentMetric) + + for i, rule := range []string{testRuleRecordAbsentMetric, testAlertRuleWarnOnPartialResponse} { + createRuleFile(t, filepath.Join(rulesPath, fmt.Sprintf("rules-%d.yaml", i)), rule) + } am, err := e2ethanos.NewAlertmanager(s.SharedDir(), "1") testutil.Ok(t, err) testutil.Ok(t, s.StartAndWaitReady(am)) - receiver, err := e2ethanos.NewReceiver(s.SharedDir(), s.NetworkName(), "1", 1) + receiver, err := e2ethanos.NewIngestingReceiver(s.SharedDir(), s.NetworkName()) testutil.Ok(t, err) testutil.Ok(t, s.StartAndWaitReady(receiver)) rwURL := mustURLParse(t, e2ethanos.RemoteWriteEndpoint(receiver.NetworkEndpoint(8081))) @@ -516,7 +518,7 @@ groups: { "__name__": "test_absent_metric", "job": "thanos-receive", - "receive": "1", + "receive": "e2e_test_rule_remote_write", "tenant_id": "default-tenant", }, })