2020-04-15 06:06:49 +02:00
|
|
|
from zerver.lib.test_classes import WebhookTestCase
|
|
|
|
|
|
|
|
|
|
|
|
class GrafanaHookTests(WebhookTestCase):
|
2021-02-12 08:20:45 +01:00
|
|
|
STREAM_NAME = "grafana"
|
2020-04-15 06:06:49 +02:00
|
|
|
URL_TEMPLATE = "/api/v1/external/grafana?&api_key={api_key}&stream={stream}"
|
2021-06-26 09:18:33 +02:00
|
|
|
WEBHOOK_DIR_NAME = "grafana"
|
2020-04-15 06:06:49 +02:00
|
|
|
|
|
|
|
# Note: Include a test function per each distinct message condition your integration supports
|
|
|
|
def test_alert(self) -> None:
|
|
|
|
expected_topic = "[Alerting] Test notification"
|
|
|
|
expected_message = """
|
2021-05-24 23:25:33 +02:00
|
|
|
:alert: **ALERTING**
|
|
|
|
|
2020-04-15 06:06:49 +02:00
|
|
|
[Test rule](http://localhost:3000/)
|
|
|
|
|
|
|
|
Someone is testing the alert notification within grafana.
|
|
|
|
|
|
|
|
**High value:** 100
|
|
|
|
**Higher Value:** 200
|
|
|
|
|
|
|
|
[Click to view visualization](https://grafana.com/assets/img/blog/mixed_styles.png)
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
2020-08-23 15:49:24 +02:00
|
|
|
self.check_webhook(
|
|
|
|
"alert",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
2020-04-15 06:06:49 +02:00
|
|
|
|
|
|
|
def test_no_data_alert(self) -> None:
|
|
|
|
expected_topic = "[Alerting] No Data alert"
|
|
|
|
expected_message = """
|
2021-05-24 23:25:33 +02:00
|
|
|
:alert: **ALERTING**
|
|
|
|
|
2020-04-15 06:06:49 +02:00
|
|
|
[No Data alert](http://localhost:3000/d/GG2qhR3Wz/alerttest?fullscreen&edit&tab=alert&panelId=6&orgId=1)
|
|
|
|
|
|
|
|
The panel has no data.
|
|
|
|
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
2020-08-23 15:49:24 +02:00
|
|
|
self.check_webhook(
|
|
|
|
"no_data_alert",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
2020-04-15 06:06:49 +02:00
|
|
|
|
|
|
|
def test_no_message_alert(self) -> None:
|
|
|
|
expected_topic = "[Alerting] No Message alert"
|
|
|
|
expected_message = """
|
2021-05-24 23:25:33 +02:00
|
|
|
:alert: **ALERTING**
|
|
|
|
|
2020-04-15 06:06:49 +02:00
|
|
|
[No Message alert](http://localhost:3000/d/GG2qhR3Wz/alerttest?fullscreen&edit&tab=alert&panelId=8&orgId=1)
|
|
|
|
|
|
|
|
**A-series:** 21.573108436586445
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
2020-08-23 15:49:24 +02:00
|
|
|
self.check_webhook(
|
|
|
|
"no_message_alert",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
2021-05-24 23:25:33 +02:00
|
|
|
|
|
|
|
# Note: Include a test function per each distinct message condition your integration supports
|
|
|
|
def test_alert_ok(self) -> None:
|
|
|
|
expected_topic = "[Ok] Test notification"
|
|
|
|
expected_message = """
|
|
|
|
:squared_ok: **OK**
|
|
|
|
|
|
|
|
[Test rule](http://localhost:3000/)
|
|
|
|
|
|
|
|
Someone is testing the alert notification within grafana.
|
|
|
|
|
|
|
|
**High value:** 0
|
|
|
|
|
|
|
|
[Click to view visualization](https://grafana.com/assets/img/blog/mixed_styles.png)
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
|
|
|
self.check_webhook(
|
|
|
|
"alert_ok",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Note: Include a test function per each distinct message condition your integration supports
|
|
|
|
def test_alert_paused(self) -> None:
|
|
|
|
expected_topic = "[Paused] Test notification"
|
|
|
|
expected_message = """
|
|
|
|
:info: **PAUSED**
|
|
|
|
|
|
|
|
[Test rule](http://localhost:3000/)
|
|
|
|
|
|
|
|
Someone is testing the alert notification within grafana.
|
|
|
|
|
|
|
|
|
|
|
|
[Click to view visualization](https://grafana.com/assets/img/blog/mixed_styles.png)
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
|
|
|
self.check_webhook(
|
|
|
|
"alert_paused",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
|
|
|
|
|
|
|
# Note: Include a test function per each distinct message condition your integration supports
|
|
|
|
def test_alert_pending(self) -> None:
|
|
|
|
expected_topic = "[Pending] Test notification"
|
|
|
|
expected_message = """
|
|
|
|
:info: **PENDING**
|
|
|
|
|
|
|
|
[Test rule](http://localhost:3000/)
|
|
|
|
|
|
|
|
Someone is testing the alert notification within grafana.
|
|
|
|
|
|
|
|
**High value:** 100
|
|
|
|
**Higher Value:** 200
|
|
|
|
|
|
|
|
[Click to view visualization](https://grafana.com/assets/img/blog/mixed_styles.png)
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
# use fixture named helloworld_hello
|
|
|
|
self.check_webhook(
|
|
|
|
"alert_pending",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
2022-09-03 12:01:08 +02:00
|
|
|
|
|
|
|
def test_alert_new(self) -> None:
|
|
|
|
expected_topic = "[RESOLVED:1]"
|
|
|
|
expected_message = """
|
|
|
|
:checkbox: **RESOLVED**
|
|
|
|
|
|
|
|
Webhook test message.
|
|
|
|
|
|
|
|
---
|
|
|
|
**Alert 1**: TestAlert.
|
|
|
|
|
|
|
|
This alert was fired at <time:2022-08-31T05:54:04.52289368Z>.
|
|
|
|
|
|
|
|
This alert was resolved at <time:2022-08-31T10:30:00.52288431Z>.
|
|
|
|
|
|
|
|
Labels:
|
|
|
|
- alertname: TestAlert
|
|
|
|
- instance: Grafana
|
|
|
|
|
|
|
|
Annotations:
|
|
|
|
- summary: Notification test
|
|
|
|
|
|
|
|
1 alert(s) truncated.
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
self.check_webhook(
|
|
|
|
"alert_new",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|
|
|
|
|
|
|
|
def test_alert_new_multiple(self) -> None:
|
|
|
|
expected_topic = "[FIRING:2]"
|
|
|
|
expected_message = """
|
|
|
|
:alert: **FIRING**
|
|
|
|
|
|
|
|
Webhook test message.
|
|
|
|
|
|
|
|
---
|
|
|
|
**Alert 1**: High memory usage.
|
|
|
|
|
|
|
|
This alert was fired at <time:2021-10-12T09:51:03.157076+02:00>.
|
|
|
|
Labels:
|
|
|
|
- alertname: High memory usage
|
|
|
|
- team: blue
|
|
|
|
- zone: us-1
|
|
|
|
|
|
|
|
Annotations:
|
|
|
|
- description: The system has high memory usage
|
|
|
|
- runbook_url: https://myrunbook.com/runbook/1234
|
|
|
|
- summary: This alert was triggered for zone us-1
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
**Alert 2**: High CPU usage.
|
|
|
|
|
|
|
|
This alert was fired at <time:2021-10-12T09:56:03.157076+02:00>.
|
|
|
|
Labels:
|
|
|
|
- alertname: High CPU usage
|
|
|
|
- team: blue
|
|
|
|
- zone: eu-1
|
|
|
|
|
|
|
|
Annotations:
|
|
|
|
- description: The system has high CPU usage
|
|
|
|
- runbook_url: https://myrunbook.com/runbook/1234
|
|
|
|
- summary: This alert was triggered for zone eu-1
|
|
|
|
""".strip()
|
|
|
|
|
|
|
|
self.check_webhook(
|
|
|
|
"alert_new_multiple",
|
|
|
|
expected_topic,
|
|
|
|
expected_message,
|
|
|
|
content_type="application/x-www-form-urlencoded",
|
|
|
|
)
|