uptime-kuma-api/tests/test_monitor.py

60 lines
1.9 KiB
Python
Raw Normal View History

2022-08-02 23:47:56 +02:00
import unittest
from uptime_kuma_test_case import UptimeKumaTestCase
from uptime_kuma_api import UptimeKumaException
class TestMonitor(UptimeKumaTestCase):
def test_monitor(self):
expected_monitor = {
2022-08-03 11:56:02 +02:00
"type": "http",
2022-08-02 23:47:56 +02:00
"name": "monitor 1",
"url": "http://192.168.20.135"
}
# add monitor
r = self.api.add_monitor(
2022-08-03 11:56:02 +02:00
type=expected_monitor["type"],
2022-08-02 23:47:56 +02:00
name=expected_monitor["name"],
url=expected_monitor["url"]
)
self.assertEqual(r["msg"], "Added Successfully.")
2022-08-03 11:56:02 +02:00
monitor_id = r["monitorID"]
2022-08-02 23:47:56 +02:00
# get monitor
monitor = self.api.get_monitor(monitor_id)
self.compare(monitor, expected_monitor)
# get monitors
monitors = self.api.get_monitors()
monitor = self.find_by_id(monitors, monitor_id)
self.assertIsNotNone(monitor)
self.compare(monitor, expected_monitor)
# edit monitor
2022-08-03 11:56:02 +02:00
expected_monitor["type"] = "ping"
2022-08-02 23:47:56 +02:00
expected_monitor["name"] = "monitor 1 new"
expected_monitor["hostname"] = "127.0.0.1"
del expected_monitor["url"]
r = self.api.edit_monitor(monitor_id, **expected_monitor)
self.assertEqual(r["msg"], "Saved.")
monitor = self.api.get_monitor(monitor_id)
self.compare(monitor, expected_monitor)
# pause monitor
r = self.api.pause_monitor(monitor_id)
self.assertEqual(r["msg"], "Paused Successfully.")
# resume monitor
r = self.api.resume_monitor(monitor_id)
self.assertEqual(r["msg"], "Resumed Successfully.")
# delete monitor
r = self.api.delete_monitor(monitor_id)
self.assertEqual(r["msg"], "Deleted Successfully.")
with self.assertRaises(UptimeKumaException):
self.api.get_monitor(monitor_id)
if __name__ == '__main__':
unittest.main()