2022-08-02 23:47:56 +02:00
|
|
|
import unittest
|
2022-08-03 12:35:48 +02:00
|
|
|
|
2022-09-17 12:24:08 +02:00
|
|
|
from uptime_kuma_api import UptimeKumaException, MonitorType, AuthMethod
|
2022-08-03 12:35:48 +02:00
|
|
|
from uptime_kuma_test_case import UptimeKumaTestCase
|
2022-08-02 23:47:56 +02:00
|
|
|
|
|
|
|
|
|
|
|
class TestMonitor(UptimeKumaTestCase):
|
|
|
|
def test_monitor(self):
|
2022-10-04 18:38:17 +02:00
|
|
|
# get empty list to make sure that future accesses will also work
|
|
|
|
self.api.get_monitors()
|
|
|
|
|
2022-09-17 12:24:08 +02:00
|
|
|
notification_id_1 = self.add_notification()
|
|
|
|
notification_id_2 = self.add_notification()
|
|
|
|
|
2022-08-02 23:47:56 +02:00
|
|
|
expected_monitor = {
|
2022-08-26 14:03:17 +02:00
|
|
|
"type": MonitorType.HTTP,
|
2022-08-02 23:47:56 +02:00
|
|
|
"name": "monitor 1",
|
2022-09-17 12:24:08 +02:00
|
|
|
"interval": 60,
|
|
|
|
"retryInterval": 60,
|
|
|
|
"maxretries": 0,
|
|
|
|
"notificationIDList": [notification_id_1, notification_id_2],
|
|
|
|
"upsideDown": False,
|
2023-05-20 12:43:57 +02:00
|
|
|
"url": "http://127.0.0.1",
|
|
|
|
"resendInterval": 0
|
2022-08-02 23:47:56 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# add monitor
|
2022-08-26 14:03:17 +02:00
|
|
|
r = self.api.add_monitor(**expected_monitor)
|
2022-08-02 23:47:56 +02:00
|
|
|
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-09-18 19:46:20 +02:00
|
|
|
expected_monitor["type"] = MonitorType.PING
|
2022-08-02 23:47:56 +02:00
|
|
|
expected_monitor["name"] = "monitor 1 new"
|
2022-08-26 14:03:17 +02:00
|
|
|
expected_monitor["hostname"] = "127.0.0.10"
|
2022-08-02 23:47:56 +02:00
|
|
|
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.")
|
|
|
|
|
2022-08-05 14:35:17 +02:00
|
|
|
# get monitor beats
|
|
|
|
self.api.get_monitor_beats(monitor_id, 6)
|
|
|
|
|
2022-08-02 23:47:56 +02:00
|
|
|
# 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)
|
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
def do_test_monitor_type(self, expected_monitor):
|
|
|
|
r = self.api.add_monitor(**expected_monitor)
|
|
|
|
self.assertEqual(r["msg"], "Added Successfully.")
|
|
|
|
monitor_id = r["monitorID"]
|
|
|
|
|
2022-09-17 12:24:08 +02:00
|
|
|
monitor = self.api.get_monitor(monitor_id)
|
|
|
|
self.compare(monitor, expected_monitor)
|
|
|
|
|
2022-10-04 18:38:17 +02:00
|
|
|
expected_monitor.update({
|
|
|
|
"name": "monitor 2"
|
|
|
|
})
|
2022-09-17 12:24:08 +02:00
|
|
|
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)
|
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
monitor = self.api.get_monitor(monitor_id)
|
|
|
|
self.compare(monitor, expected_monitor)
|
2022-09-12 20:47:45 +02:00
|
|
|
return monitor
|
2022-08-26 14:03:17 +02:00
|
|
|
|
|
|
|
def test_monitor_type_http(self):
|
2022-09-17 12:24:08 +02:00
|
|
|
proxy_id = self.add_proxy()
|
|
|
|
|
2022-09-07 13:03:10 +02:00
|
|
|
json_data = '{"key": "value"}'
|
2022-08-26 14:03:17 +02:00
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.HTTP,
|
|
|
|
"name": "monitor 1",
|
2022-09-07 13:03:10 +02:00
|
|
|
"url": "http://127.0.0.1",
|
2022-09-17 12:24:08 +02:00
|
|
|
"expiryNotification": False,
|
|
|
|
"ignoreTls": False,
|
|
|
|
"maxredirects": 10,
|
|
|
|
"accepted_statuscodes": ["200-299"],
|
|
|
|
"proxyId": proxy_id,
|
|
|
|
"method": "GET",
|
2022-09-07 13:03:10 +02:00
|
|
|
"body": json_data,
|
2022-09-17 12:24:08 +02:00
|
|
|
"headers": json_data,
|
|
|
|
"authMethod": AuthMethod.NONE
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
def test_monitor_auth_method(self):
|
|
|
|
for auth_method in [AuthMethod.HTTP_BASIC, AuthMethod.NTLM]:
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.HTTP,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"url": "http://127.0.0.1",
|
|
|
|
"authMethod": auth_method,
|
|
|
|
"basic_auth_user": "auth user",
|
|
|
|
"basic_auth_pass": "auth pass",
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.HTTP,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"url": "http://127.0.0.1",
|
|
|
|
"authMethod": AuthMethod.NTLM,
|
|
|
|
"authDomain": "auth domain",
|
|
|
|
"authWorkstation": "auth workstation",
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2023-05-20 12:43:57 +02:00
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.HTTP,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"url": "http://127.0.0.1",
|
|
|
|
"authMethod": AuthMethod.MTLS,
|
|
|
|
"tlsCert": "cert",
|
|
|
|
"tlsKey": "key",
|
|
|
|
"tlsCa": "ca",
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
2023-03-20 15:14:39 +01:00
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
def test_monitor_type_port(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.PORT,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"hostname": "127.0.0.1",
|
|
|
|
"port": 8888
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
def test_monitor_type_ping(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.PING,
|
|
|
|
"name": "monitor 1",
|
2023-05-20 12:43:57 +02:00
|
|
|
"hostname": "127.0.0.1",
|
|
|
|
"packetSize": 56
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
def test_monitor_type_keyword(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.KEYWORD,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"url": "http://127.0.0.1",
|
|
|
|
"keyword": "healthy"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-12-29 00:22:53 +01:00
|
|
|
def test_monitor_type_grpc_keyword(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.GRPC_KEYWORD,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"grpcUrl": "127.0.0.1",
|
|
|
|
"keyword": "healthy",
|
|
|
|
"grpcServiceName": "health",
|
|
|
|
"grpcMethod": "check",
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
def test_monitor_type_dns(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.DNS,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"hostname": "127.0.0.1",
|
|
|
|
"port": 8888,
|
2022-09-17 12:24:08 +02:00
|
|
|
"dns_resolve_server": "1.1.1.1",
|
|
|
|
"dns_resolve_type": "A"
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-12-29 00:22:53 +01:00
|
|
|
def test_monitor_type_docker(self):
|
|
|
|
docker_host_id = self.add_docker_host()
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.DOCKER,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"docker_container": "test",
|
|
|
|
"docker_host": docker_host_id
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
def test_monitor_type_push(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.PUSH,
|
2022-09-07 13:03:10 +02:00
|
|
|
"name": "monitor 1"
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
2022-09-12 20:47:45 +02:00
|
|
|
monitor = self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
# https://github.com/lucasheld/ansible-uptime-kuma/issues/5
|
|
|
|
self.assertIsNotNone(monitor["pushToken"])
|
2022-08-26 14:03:17 +02:00
|
|
|
|
|
|
|
def test_monitor_type_steam(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.STEAM,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"hostname": "127.0.0.1",
|
2022-09-07 13:03:10 +02:00
|
|
|
"port": 8888
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2023-02-13 22:51:21 +01:00
|
|
|
def test_monitor_type_gamedig(self):
|
|
|
|
game_list = self.api.get_game_list()
|
|
|
|
game = game_list[0]["keys"][0]
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.GAMEDIG,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"hostname": "127.0.0.1",
|
|
|
|
"port": 8888,
|
|
|
|
"game": game
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-08-26 14:03:17 +02:00
|
|
|
def test_monitor_type_mqtt(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.MQTT,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"hostname": "127.0.0.1",
|
|
|
|
"port": 8888,
|
2022-09-17 12:24:08 +02:00
|
|
|
"mqttUsername": "mqtt username",
|
|
|
|
"mqttPassword": "mqtt password",
|
|
|
|
"mqttTopic": "mqtt topic",
|
|
|
|
"mqttSuccessMessage": "mqtt success message"
|
2022-08-26 14:03:17 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
|
|
|
def test_monitor_type_sqlserver(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.SQLSERVER,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"databaseConnectionString": "Server=127.0.0.1,8888;Database=test;User Id=1;Password=secret123;Encrypt=true;"
|
|
|
|
"TrustServerCertificate=Yes;Connection Timeout=5",
|
|
|
|
"databaseQuery": "select getdate()"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-09-07 13:03:10 +02:00
|
|
|
def test_monitor_type_postgres(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.POSTGRES,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"databaseConnectionString": "postgres://username:password@host:port/database",
|
|
|
|
"databaseQuery": "select getdate()"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-12-29 00:22:53 +01:00
|
|
|
def test_monitor_type_mysql(self):
|
2022-09-07 13:03:10 +02:00
|
|
|
expected_monitor = {
|
2022-12-29 00:22:53 +01:00
|
|
|
"type": MonitorType.MYSQL,
|
2022-09-07 13:03:10 +02:00
|
|
|
"name": "monitor 1",
|
2022-12-29 00:22:53 +01:00
|
|
|
"databaseConnectionString": "mysql://username:password@host:port/database",
|
|
|
|
"databaseQuery": "select getdate()"
|
2022-09-07 13:03:10 +02:00
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2023-02-13 22:51:21 +01:00
|
|
|
def test_monitor_type_mongodb(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.MONGODB,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"databaseConnectionString": "mongodb://username:password@host:port/database"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2022-09-07 13:03:10 +02:00
|
|
|
def test_monitor_type_radius(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.RADIUS,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"radiusUsername": "123",
|
|
|
|
"radiusPassword": "456",
|
|
|
|
"radiusSecret": "789",
|
|
|
|
"radiusCalledStationId": "1",
|
|
|
|
"radiusCallingStationId": "2"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2023-02-13 22:51:21 +01:00
|
|
|
def test_monitor_type_redis(self):
|
|
|
|
expected_monitor = {
|
|
|
|
"type": MonitorType.REDIS,
|
|
|
|
"name": "monitor 1",
|
|
|
|
"databaseConnectionString": "redis://user:password@host:port"
|
|
|
|
}
|
|
|
|
self.do_test_monitor_type(expected_monitor)
|
|
|
|
|
2023-05-20 14:09:09 +02:00
|
|
|
def test_delete_not_existing_monitor(self):
|
|
|
|
with self.assertRaises(UptimeKumaException):
|
|
|
|
self.api.delete_monitor(42)
|
|
|
|
|
2022-08-02 23:47:56 +02:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|