2022-09-07 13:03:10 +02:00
|
|
|
import unittest
|
2023-08-29 18:37:27 +02:00
|
|
|
from packaging.version import parse as parse_version
|
2022-09-07 13:03:10 +02:00
|
|
|
|
|
|
|
from uptime_kuma_api import DockerType, UptimeKumaException
|
|
|
|
from uptime_kuma_test_case import UptimeKumaTestCase
|
|
|
|
|
|
|
|
|
|
|
|
class TestDockerHost(UptimeKumaTestCase):
|
|
|
|
def test_docker_host(self):
|
2022-10-04 18:38:17 +02:00
|
|
|
# get empty list to make sure that future accesses will also work
|
|
|
|
self.api.get_docker_hosts()
|
|
|
|
|
2022-09-07 13:03:10 +02:00
|
|
|
expected_docker_host = {
|
|
|
|
"name": "name 1",
|
|
|
|
"dockerType": DockerType.SOCKET,
|
|
|
|
"dockerDaemon": "/var/run/docker.sock"
|
|
|
|
}
|
|
|
|
|
|
|
|
# test docker host
|
2023-08-29 18:37:27 +02:00
|
|
|
if parse_version(self.api.version) != parse_version("1.23.0"):
|
|
|
|
# test_docker_host does not work in 1.23.0 (https://github.com/louislam/uptime-kuma/issues/3605)
|
|
|
|
with self.assertRaisesRegex(UptimeKumaException, r'connect ENOENT /var/run/docker.sock'):
|
|
|
|
self.api.test_docker_host(**expected_docker_host)
|
2022-09-07 13:03:10 +02:00
|
|
|
|
|
|
|
# add docker host
|
|
|
|
r = self.api.add_docker_host(**expected_docker_host)
|
|
|
|
self.assertEqual(r["msg"], "Saved")
|
|
|
|
docker_host_id = r["id"]
|
|
|
|
|
|
|
|
# get docker host
|
|
|
|
docker_host = self.api.get_docker_host(docker_host_id)
|
|
|
|
self.compare(docker_host, expected_docker_host)
|
|
|
|
|
|
|
|
# get docker hosts
|
|
|
|
docker_hosts = self.api.get_docker_hosts()
|
2023-05-25 21:26:54 +02:00
|
|
|
self.assertTrue(type(docker_hosts[0]["dockerType"]) == DockerType)
|
2022-09-07 13:03:10 +02:00
|
|
|
docker_host = self.find_by_id(docker_hosts, docker_host_id)
|
|
|
|
self.assertIsNotNone(docker_host)
|
|
|
|
self.compare(docker_host, expected_docker_host)
|
|
|
|
|
|
|
|
# edit docker host
|
|
|
|
r = self.api.edit_docker_host(docker_host_id, name="name 2")
|
|
|
|
self.assertEqual(r["msg"], "Saved")
|
|
|
|
docker_host = self.api.get_docker_host(docker_host_id)
|
|
|
|
expected_docker_host["name"] = "name 2"
|
|
|
|
self.compare(docker_host, expected_docker_host)
|
|
|
|
|
|
|
|
# delete docker host
|
|
|
|
r = self.api.delete_docker_host(docker_host_id)
|
|
|
|
self.assertEqual(r["msg"], "Deleted")
|
|
|
|
with self.assertRaises(UptimeKumaException):
|
|
|
|
self.api.get_docker_host(docker_host_id)
|
|
|
|
|
2023-05-20 14:09:09 +02:00
|
|
|
def test_delete_not_existing_docker_host(self):
|
|
|
|
with self.assertRaises(UptimeKumaException):
|
|
|
|
self.api.delete_docker_host(42)
|
|
|
|
|
2022-09-07 13:03:10 +02:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|