forked from DGNum/uptime-kuma-api
84d4009d6a
BREAKING CHANGE: Types of return values changed to enum values: - monitor: `type` (str -> MonitorType), `authMethod` (str -> AuthMethod) - notification: `type` (str -> NotificationType) - docker host: `dockerType` (str -> DockerType) - status page: `style` (str -> IncidentStyle) - maintenance: `strategy` (str -> MaintenanceStrategy) - proxy: `protocol` (str -> ProxyProtocol)
100 lines
3.4 KiB
Python
100 lines
3.4 KiB
Python
import unittest
|
|
|
|
from uptime_kuma_api import UptimeKumaException, IncidentStyle
|
|
from uptime_kuma_test_case import UptimeKumaTestCase
|
|
|
|
|
|
class TestStatusPage(UptimeKumaTestCase):
|
|
def test_status_page(self):
|
|
# get empty list to make sure that future accesses will also work
|
|
self.api.get_status_pages()
|
|
|
|
monitor_id = self.add_monitor()
|
|
|
|
slug = "slug1"
|
|
expected_status_page = {
|
|
"slug": slug,
|
|
"title": "status page 1",
|
|
"description": "description 1",
|
|
"theme": "light",
|
|
"published": True,
|
|
"showTags": False,
|
|
"domainNameList": [],
|
|
"customCSS": "",
|
|
"footerText": None,
|
|
"showPoweredBy": False,
|
|
"icon": "/icon.svg",
|
|
"publicGroupList": [
|
|
{
|
|
'name': 'Services',
|
|
'weight': 1,
|
|
'monitorList': [
|
|
{
|
|
"id": monitor_id
|
|
}
|
|
]
|
|
}
|
|
],
|
|
"googleAnalyticsId": ""
|
|
}
|
|
|
|
# add status page
|
|
r = self.api.add_status_page(slug, expected_status_page["title"])
|
|
self.assertEqual(r["msg"], "OK!")
|
|
|
|
# save status page
|
|
self.api.save_status_page(**expected_status_page)
|
|
|
|
# get status page
|
|
status_page = self.api.get_status_page(slug)
|
|
self.compare(status_page, expected_status_page)
|
|
|
|
# get status pages
|
|
status_pages = self.api.get_status_pages()
|
|
status_page = self.find_by_id(status_pages, slug, "slug")
|
|
self.assertIsNotNone(status_page)
|
|
# publicGroupList and incident is not available in status pages
|
|
expected_status_page_config = {i: expected_status_page[i] for i in expected_status_page if i != "publicGroupList"}
|
|
self.compare(status_page, expected_status_page_config)
|
|
|
|
# edit status page
|
|
expected_status_page["title"] = "status page 1 new"
|
|
expected_status_page["theme"] = "dark"
|
|
self.api.save_status_page(**expected_status_page)
|
|
status_page = self.api.get_status_page(slug)
|
|
self.compare(status_page, expected_status_page)
|
|
|
|
# pin incident
|
|
incident_expected = {
|
|
"title": "title 1",
|
|
"content": "content 1",
|
|
"style": IncidentStyle.DANGER
|
|
}
|
|
incident = self.api.post_incident(slug, **incident_expected)
|
|
self.assertTrue(type(incident["style"]) == IncidentStyle)
|
|
self.compare(incident, incident_expected)
|
|
status_page = self.api.get_status_page(slug)
|
|
self.compare(status_page["incident"], incident)
|
|
self.assertTrue(type(status_page["incident"]["style"]) == IncidentStyle)
|
|
|
|
# unpin incident
|
|
self.api.unpin_incident(slug)
|
|
status_page = self.api.get_status_page(slug)
|
|
self.assertIsNone(status_page["incident"])
|
|
|
|
# delete status page
|
|
self.api.delete_status_page(slug)
|
|
with self.assertRaises(UptimeKumaException):
|
|
self.api.get_status_page(slug)
|
|
|
|
status_pages = self.api.get_status_pages()
|
|
status_page = self.find_by_id(status_pages, slug, "slug")
|
|
self.assertIsNone(status_page)
|
|
|
|
def test_delete_not_existing_status_page(self):
|
|
with self.assertRaises(UptimeKumaException):
|
|
self.api.delete_status_page("slug42")
|
|
|
|
|
|
if __name__ == '__main__':
|
|
unittest.main()
|