From 77fcf692c553c43dace8ad6fa4b7aee247aa1437 Mon Sep 17 00:00:00 2001 From: Brett Buddin Date: Mon, 24 Aug 2020 10:08:14 -0400 Subject: [PATCH] fix(notification/rule): Include the edge of the boundary we are observing. (#19392) * fix(notification/rule): Include the edge of the boundary we are observing. * chore(changelog): Add 19392 to changelog. --- CHANGELOG.md | 1 + notification/rule/http_test.go | 8 ++++---- notification/rule/pagerduty_test.go | 6 +++--- notification/rule/rule.go | 9 +++++---- notification/rule/slack_test.go | 8 ++++---- notification/rule/telegram_test.go | 4 ++-- 6 files changed, 19 insertions(+), 17 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index acddaeed5fd..77c8eff898e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ ### Bug Fixes 1. [19331](https://github.com/influxdata/influxdb/pull/19331): Add description to auth influx command outputs. +1. [19392](https://github.com/influxdata/influxdb/pull/19392) Include the edge of the boundary we are observing. ## v2.0.0-beta.16 [2020-08-07] diff --git a/notification/rule/http_test.go b/notification/rule/http_test.go index f6a85a196ba..5607ba524b3 100644 --- a/notification/rule/http_test.go +++ b/notification/rule/http_test.go @@ -33,7 +33,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: endpoint(mapFn: (r) => { @@ -102,7 +102,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: endpoint(mapFn: (r) => { @@ -177,7 +177,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: endpoint(mapFn: (r) => { @@ -250,7 +250,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 5s))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 5s))) all_statuses |> monitor["notify"](data: notification, endpoint: endpoint(mapFn: (r) => { diff --git a/notification/rule/pagerduty_test.go b/notification/rule/pagerduty_test.go index 1515f7dae44..97d1cef34ed 100644 --- a/notification/rule/pagerduty_test.go +++ b/notification/rule/pagerduty_test.go @@ -83,7 +83,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: pagerduty_endpoint(mapFn: (r) => @@ -166,7 +166,7 @@ info_to_crit = statuses |> monitor["stateChanges"](fromLevel: "info", toLevel: "crit") all_statuses = info_to_crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: pagerduty_endpoint(mapFn: (r) => @@ -256,7 +256,7 @@ ok_to_warn = statuses all_statuses = union(tables: [crit, ok_to_warn]) |> sort(columns: ["_time"]) |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: pagerduty_endpoint(mapFn: (r) => diff --git a/notification/rule/rule.go b/notification/rule/rule.go index ec875b48360..7482f3f07a8 100644 --- a/notification/rule/rule.go +++ b/notification/rule/rule.go @@ -136,16 +136,17 @@ func (b *Base) generateLevelChecks() []ast.Statement { now := flux.Call(flux.Identifier("now"), flux.Object()) timeFilter := flux.Function( flux.FunctionParams("r"), - flux.GreaterThan( - flux.Member("r", "_time"), - flux.Call( + &ast.BinaryExpression{ + Operator: ast.GreaterThanEqualOperator, + Left: flux.Member("r", "_time"), + Right: flux.Call( flux.Member("experimental", "subDuration"), flux.Object( flux.Property("from", now), flux.Property("d", (*ast.DurationLiteral)(b.Every)), ), ), - ), + }, ) var pipe *ast.PipeExpression diff --git a/notification/rule/slack_test.go b/notification/rule/slack_test.go index 995f33c8b12..88d4698edfb 100644 --- a/notification/rule/slack_test.go +++ b/notification/rule/slack_test.go @@ -61,7 +61,7 @@ any = statuses (true)) all_statuses = any |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: slack_endpoint(mapFn: (r) => @@ -133,7 +133,7 @@ info_to_warn = statuses all_statuses = union(tables: [crit, info_to_warn]) |> sort(columns: ["_time"]) |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: slack_endpoint(mapFn: (r) => @@ -210,7 +210,7 @@ info_to_warn = statuses all_statuses = union(tables: [crit, info_to_warn]) |> sort(columns: ["_time"]) |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: slack_endpoint(mapFn: (r) => @@ -289,7 +289,7 @@ info_to_warn = statuses all_statuses = union(tables: [crit, info_to_warn]) |> sort(columns: ["_time"]) |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: slack_endpoint(mapFn: (r) => diff --git a/notification/rule/telegram_test.go b/notification/rule/telegram_test.go index 8dae3b0fa98..05643bb429d 100644 --- a/notification/rule/telegram_test.go +++ b/notification/rule/telegram_test.go @@ -125,7 +125,7 @@ crit = statuses (r["_level"] == "crit")) all_statuses = crit |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: telegram_endpoint(mapFn: (r) => @@ -197,7 +197,7 @@ any = statuses (true)) all_statuses = any |> filter(fn: (r) => - (r["_time"] > experimental["subDuration"](from: now(), d: 1h))) + (r["_time"] >= experimental["subDuration"](from: now(), d: 1h))) all_statuses |> monitor["notify"](data: notification, endpoint: telegram_endpoint(mapFn: (r) =>