zulip/zerver/webhooks/papertrail/tests.py

47 lines
1.7 KiB
Python

from zerver.lib.test_classes import WebhookTestCase
from typing import Text
class PapertrailHookTests(WebhookTestCase):
STREAM_NAME = 'papertrail'
URL_TEMPLATE = "/api/v1/external/papertrail?&api_key={api_key}"
FIXTURE_DIR_NAME = 'papertrail'
# Note: Include a test function per each distinct message condition your integration supports
def test_short_message(self):
# type: () -> None
expected_subject = u"logs"
expected_message = u'''**"Important stuff"** search found **2** matches - https://papertrailapp.com/searches/42
```
May 18 20:30:02 abc cron OR server1:
message body
May 18 20:30:02 server1 cron OR server1:
A short event
```'''
# use fixture named papertrail_logs
self.send_and_test_stream_message('short_post', expected_subject, expected_message,
content_type="application/x-www-form-urlencoded")
def test_long_message(self):
# type: () -> None
expected_subject = u"logs"
expected_message = u'''**"Important stuff"** search found **5** matches - https://papertrailapp.com/searches/42
```
May 18 20:30:02 abc cron OR server1:
message body 1
May 18 20:30:02 abc cron OR server1:
message body 2
May 18 20:30:02 abc cron OR server1:
message body 3
May 18 20:30:02 abc cron OR server1:
message body 4
```
[See more](https://papertrailapp.com/searches/42)'''
# use fixture named papertrail_logs
self.send_and_test_stream_message('long_post', expected_subject, expected_message,
content_type="application/x-www-form-urlencoded")
def get_body(self, fixture_name):
# type: (Text) -> Text
return self.fixture_data("papertrail", fixture_name, file_type="json")