2018-01-13 16:25:58 +00:00
|
|
|
|
|
|
|
|
|
|
|
from mgr_test_case import MgrTestCase
|
|
|
|
|
2018-03-12 13:35:11 +00:00
|
|
|
import json
|
2018-01-13 16:25:58 +00:00
|
|
|
import logging
|
|
|
|
import requests
|
|
|
|
|
|
|
|
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
|
|
|
|
|
|
|
|
class TestPrometheus(MgrTestCase):
|
|
|
|
MGRS_REQUIRED = 3
|
|
|
|
|
2018-02-28 22:11:34 +00:00
|
|
|
def setUp(self):
|
|
|
|
self.setup_mgrs()
|
|
|
|
|
2018-03-12 13:35:11 +00:00
|
|
|
def test_file_sd_command(self):
|
|
|
|
self._assign_ports("prometheus", "server_port")
|
|
|
|
self._load_module("prometheus")
|
|
|
|
|
|
|
|
result = json.loads(self.mgr_cluster.mon_manager.raw_cluster_cmd(
|
|
|
|
"prometheus", "file_sd_config"))
|
|
|
|
mgr_map = self.mgr_cluster.get_mgr_map()
|
|
|
|
self.assertEqual(len(result[0]['targets']), len(mgr_map['standbys']) + 1)
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-01-13 16:25:58 +00:00
|
|
|
def test_standby(self):
|
|
|
|
self._assign_ports("prometheus", "server_port")
|
|
|
|
self._load_module("prometheus")
|
|
|
|
|
|
|
|
original_active = self.mgr_cluster.get_active_id()
|
|
|
|
|
|
|
|
original_uri = self._get_uri("prometheus")
|
|
|
|
log.info("Originally running at {0}".format(original_uri))
|
|
|
|
|
|
|
|
self.mgr_cluster.mgr_fail(original_active)
|
|
|
|
|
|
|
|
failed_over_uri = self._get_uri("prometheus")
|
|
|
|
log.info("After failover running at {0}".format(failed_over_uri))
|
|
|
|
|
|
|
|
self.assertNotEqual(original_uri, failed_over_uri)
|
|
|
|
|
|
|
|
# The original active daemon should have come back up as a standby
|
|
|
|
# and serve some html under "/" and an empty answer under /metrics
|
|
|
|
r = requests.get(original_uri, allow_redirects=False)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
r = requests.get(original_uri + "metrics", allow_redirects=False)
|
|
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
self.assertEqual(r.headers["content-type"], "text/plain;charset=utf-8")
|
|
|
|
|
|
|
|
def test_urls(self):
|
|
|
|
self._assign_ports("prometheus", "server_port")
|
|
|
|
self._load_module("prometheus")
|
|
|
|
|
|
|
|
base_uri = self._get_uri("prometheus")
|
|
|
|
|
|
|
|
# This is a very simple smoke test to check that the module can
|
|
|
|
# give us a 200 response to requests. We're not testing that
|
|
|
|
# the content is correct or even renders!
|
|
|
|
|
|
|
|
urls = [
|
|
|
|
"/",
|
|
|
|
"/metrics"
|
|
|
|
]
|
|
|
|
|
|
|
|
failures = []
|
|
|
|
|
|
|
|
for url in urls:
|
|
|
|
r = requests.get(base_uri + url, allow_redirects=False)
|
|
|
|
if r.status_code != 200:
|
|
|
|
failures.append(url)
|
|
|
|
|
|
|
|
log.info("{0}: {1} ({2} bytes)".format(
|
|
|
|
url, r.status_code, len(r.content)
|
|
|
|
))
|
|
|
|
|
|
|
|
self.assertListEqual(failures, [])
|