Skip to content

Commit

Permalink
e2e: rule: add test for reloading rules via /-/reload
Browse files Browse the repository at this point in the history
Add a test-case to the e2e tests for testing whether reloading rules via
/-/reload works.

Signed-off-by: Giedrius Statkevičius <[email protected]>
  • Loading branch information
GiedriusS authored and squat committed Apr 30, 2020
1 parent 144ad9f commit f8194a0
Showing 1 changed file with 53 additions and 6 deletions.
59 changes: 53 additions & 6 deletions test/e2e/rule_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,18 +59,44 @@ groups:
severity: page
annotations:
summary: "I always complain and allow partial response in query."
`
testAlertRuleAddedLaterWebHandler = `
groups:
- name: example
partial_response_strategy: "WARN"
rules:
- alert: TestAlert_HasBeenLoadedViaWebHandler
# It must be based on actual metric, otherwise call to StoreAPI would be not involved.
expr: absent(some_metric)
labels:
severity: page
annotations:
summary: "I always complain and I have been loaded via /-/reload."
`
)

func createRuleFile(t *testing.T, path, content string) {
t.Helper()
err := ioutil.WriteFile(path, []byte(content), 0666)
testutil.Ok(t, err)
}

func createRuleFiles(t *testing.T, dir string) {
t.Helper()

for i, rule := range []string{testAlertRuleAbortOnPartialResponse, testAlertRuleWarnOnPartialResponse} {
err := ioutil.WriteFile(filepath.Join(dir, fmt.Sprintf("rules-%d.yaml", i)), []byte(rule), 0666)
testutil.Ok(t, err)
createRuleFile(t, filepath.Join(dir, fmt.Sprintf("rules-%d.yaml", i)), rule)
}
}

func reloadRulesHTTP(t *testing.T, ctx context.Context, endpoint string) {
req, err := http.NewRequestWithContext(ctx, "POST", "http://"+endpoint+"/-/reload", ioutil.NopCloser(bytes.NewReader(nil)))
testutil.Ok(t, err)
resp, err := http.DefaultClient.Do(req)
testutil.Ok(t, err)
testutil.Equals(t, 200, resp.StatusCode)
}

func writeTargets(t *testing.T, path string, addrs ...string) {
t.Helper()

Expand Down Expand Up @@ -269,10 +295,14 @@ func TestRule(t *testing.T) {
testutil.Ok(t, err)
defer s.Close()

ctx, cancel := context.WithTimeout(context.Background(), 3*time.Minute)
defer cancel()

// Prepare work dirs.
rulesSubDir := filepath.Join("rules")
testutil.Ok(t, os.MkdirAll(filepath.Join(s.SharedDir(), rulesSubDir), os.ModePerm))
createRuleFiles(t, filepath.Join(s.SharedDir(), rulesSubDir))
rulesPath := filepath.Join(s.SharedDir(), rulesSubDir)
testutil.Ok(t, os.MkdirAll(rulesPath, os.ModePerm))
createRuleFiles(t, rulesPath)
amTargetsSubDir := filepath.Join("rules_am_targets")
testutil.Ok(t, os.MkdirAll(filepath.Join(s.SharedDir(), amTargetsSubDir), os.ModePerm))
queryTargetsSubDir := filepath.Join("rules_query_targets")
Expand Down Expand Up @@ -433,8 +463,13 @@ func TestRule(t *testing.T) {
testutil.Ok(t, r.WaitSumMetrics(e2e.Equals(1), "thanos_ruler_alertmanagers_dns_provider_results"))
})

ctx, cancel := context.WithTimeout(context.Background(), 3*time.Minute)
defer cancel()
t.Run("reload works", func(t *testing.T) {
// Add a new rule via /-/reload.
// TODO(GiedriusS): add a test for reloading via SIGHUP. Need to extend e2e framework to expose PIDs.

createRuleFile(t, fmt.Sprintf("%s/newrule.yaml", rulesPath), testAlertRuleAddedLaterWebHandler)
reloadRulesHTTP(t, ctx, r.HTTPEndpoint())
})

queryAndAssertSeries(t, ctx, q.HTTPEndpoint(), "ALERTS", promclient.QueryOptions{
Deduplicate: false,
Expand All @@ -446,6 +481,13 @@ func TestRule(t *testing.T) {
"alertstate": "firing",
"replica": "1",
},
{
"__name__": "ALERTS",
"severity": "page",
"alertname": "TestAlert_HasBeenLoadedViaWebHandler",
"alertstate": "firing",
"replica": "1",
},
{
"__name__": "ALERTS",
"severity": "page",
Expand All @@ -461,6 +503,11 @@ func TestRule(t *testing.T) {
"alertname": "TestAlert_AbortOnPartialResponse",
"replica": "1",
},
{
"severity": "page",
"alertname": "TestAlert_HasBeenLoadedViaWebHandler",
"replica": "1",
},
{
"severity": "page",
"alertname": "TestAlert_WarnOnPartialResponse",
Expand Down

0 comments on commit f8194a0

Please sign in to comment.