from datetime import timedelta as td
|
|
|
|
from hc.api.models import Check
|
|
from hc.test import BaseTestCase
|
|
|
|
|
|
class GetBadgesTestCase(BaseTestCase):
|
|
def setUp(self):
|
|
super().setUp()
|
|
|
|
self.a1 = Check(project=self.project, name="Alice 1")
|
|
self.a1.timeout = td(seconds=3600)
|
|
self.a1.grace = td(seconds=900)
|
|
self.a1.n_pings = 0
|
|
self.a1.status = "new"
|
|
self.a1.tags = "foo bar"
|
|
self.a1.save()
|
|
|
|
self.url = "/api/v1/badges/"
|
|
|
|
def get(self, api_key="X" * 32, qs=""):
|
|
return self.client.get(self.url + qs, HTTP_X_API_KEY=api_key)
|
|
|
|
def test_it_works(self):
|
|
|
|
r = self.get()
|
|
self.assertEqual(r.status_code, 200)
|
|
self.assertEqual(r["Access-Control-Allow-Origin"], "*")
|
|
|
|
doc = r.json()
|
|
self.assertTrue("foo" in doc["badges"])
|
|
self.assertTrue("svg" in doc["badges"]["foo"])
|
|
|
|
def test_readonly_key_is_allowed(self):
|
|
self.project.api_key_readonly = "R" * 32
|
|
self.project.save()
|
|
|
|
r = self.get(api_key=self.project.api_key_readonly)
|
|
self.assertEqual(r.status_code, 200)
|
|
|
|
def test_it_rejects_post(self):
|
|
r = self.csrf_client.post(self.url, HTTP_X_API_KEY="X" * 32)
|
|
self.assertEqual(r.status_code, 405)
|
|
|
|
def test_it_handles_missing_api_key(self):
|
|
r = self.client.get(self.url)
|
|
self.assertContains(r, "missing api key", status_code=401)
|