2016-12-06 00:41:14 +01:00
|
|
|
|
2017-11-16 00:43:10 +01:00
|
|
|
from zerver.lib.test_classes import WebhookTestCase
|
|
|
|
|
2016-12-06 00:41:14 +01:00
|
|
|
class PapertrailHookTests(WebhookTestCase):
|
|
|
|
STREAM_NAME = 'papertrail'
|
2018-03-16 22:53:50 +01:00
|
|
|
URL_TEMPLATE = "/api/v1/external/papertrail?&api_key={api_key}&stream={stream}"
|
2016-12-06 00:41:14 +01:00
|
|
|
FIXTURE_DIR_NAME = 'papertrail'
|
|
|
|
|
|
|
|
# Note: Include a test function per each distinct message condition your integration supports
|
2017-11-04 07:47:46 +01:00
|
|
|
def test_short_message(self) -> None:
|
2018-11-09 20:33:58 +01:00
|
|
|
expected_topic = u"logs"
|
2016-12-06 00:41:14 +01:00
|
|
|
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
|
2018-11-09 20:33:58 +01:00
|
|
|
self.send_and_test_stream_message('short_post', expected_topic, expected_message,
|
2016-12-06 00:41:14 +01:00
|
|
|
content_type="application/x-www-form-urlencoded")
|
|
|
|
|
2017-11-04 07:47:46 +01:00
|
|
|
def test_long_message(self) -> None:
|
2018-11-09 20:33:58 +01:00
|
|
|
expected_topic = u"logs"
|
2016-12-06 00:41:14 +01:00
|
|
|
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
|
2018-11-09 20:33:58 +01:00
|
|
|
self.send_and_test_stream_message('long_post', expected_topic, expected_message,
|
2016-12-06 00:41:14 +01:00
|
|
|
content_type="application/x-www-form-urlencoded")
|
|
|
|
|
2018-05-10 19:34:01 +02:00
|
|
|
def get_body(self, fixture_name: str) -> str:
|
2018-04-20 03:57:21 +02:00
|
|
|
return self.webhook_fixture_data("papertrail", fixture_name, file_type="json")
|