forked from GithubBackups/healthchecks
Adding tests for POST /channels/
This commit is contained in:
parent
061fc4f6a9
commit
8355d7c13b
@ -65,9 +65,8 @@ class Check(models.Model):
|
|||||||
return "down"
|
return "down"
|
||||||
|
|
||||||
def assign_all_channels(self):
|
def assign_all_channels(self):
|
||||||
for channel in Channel.objects.filter(user=self.user):
|
channels = Channel.objects.filter(user=self.user)
|
||||||
channel.checks.add(self)
|
self.channel_set.add(*channels)
|
||||||
channel.save()
|
|
||||||
|
|
||||||
|
|
||||||
class Ping(models.Model):
|
class Ping(models.Model):
|
||||||
|
66
hc/front/tests/test_update_channel.py
Normal file
66
hc/front/tests/test_update_channel.py
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
from django.contrib.auth.models import User
|
||||||
|
from django.test import TestCase
|
||||||
|
|
||||||
|
from hc.api.models import Channel, Check
|
||||||
|
|
||||||
|
|
||||||
|
class UpdateChannelTestCase(TestCase):
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
self.alice = User(username="alice")
|
||||||
|
self.alice.set_password("password")
|
||||||
|
self.alice.save()
|
||||||
|
|
||||||
|
self.check = Check(user=self.alice)
|
||||||
|
self.check.save()
|
||||||
|
|
||||||
|
self.channel = Channel(user=self.alice, kind="email")
|
||||||
|
self.channel.email = "alice@example.org"
|
||||||
|
self.channel.save()
|
||||||
|
|
||||||
|
def test_it_works(self):
|
||||||
|
payload = {
|
||||||
|
"channel": self.channel.code,
|
||||||
|
"check-%s" % self.check.code: True
|
||||||
|
}
|
||||||
|
|
||||||
|
self.client.login(username="alice", password="password")
|
||||||
|
r = self.client.post("/channels/", data=payload)
|
||||||
|
assert r.status_code == 302
|
||||||
|
|
||||||
|
channel = Channel.objects.get(code=self.channel.code)
|
||||||
|
checks = channel.checks.all()
|
||||||
|
assert len(checks) == 1
|
||||||
|
assert checks[0].code == self.check.code
|
||||||
|
|
||||||
|
def test_it_checks_channel_user(self):
|
||||||
|
mallory = User(username="mallory")
|
||||||
|
mallory.set_password("password")
|
||||||
|
mallory.save()
|
||||||
|
|
||||||
|
payload = {"channel": self.channel.code}
|
||||||
|
|
||||||
|
self.client.login(username="mallory", password="password")
|
||||||
|
r = self.client.post("/channels/", data=payload)
|
||||||
|
|
||||||
|
# self.channel does not belong to mallory, this should fail--
|
||||||
|
assert r.status_code == 403
|
||||||
|
|
||||||
|
def test_it_checks_check_user(self):
|
||||||
|
mallory = User(username="mallory")
|
||||||
|
mallory.set_password("password")
|
||||||
|
mallory.save()
|
||||||
|
|
||||||
|
mc = Channel(user=mallory, kind="email")
|
||||||
|
mc.email = "mallory@example.org"
|
||||||
|
mc.save()
|
||||||
|
|
||||||
|
payload = {
|
||||||
|
"channel": mc.code,
|
||||||
|
"check-%s" % self.check.code: True
|
||||||
|
}
|
||||||
|
self.client.login(username="mallory", password="password")
|
||||||
|
r = self.client.post("/channels/", data=payload)
|
||||||
|
|
||||||
|
# mc belongs to mallorym but self.check does not--
|
||||||
|
assert r.status_code == 403
|
@ -179,21 +179,21 @@ def channels(request):
|
|||||||
if request.method == "POST":
|
if request.method == "POST":
|
||||||
code = request.POST["channel"]
|
code = request.POST["channel"]
|
||||||
channel = Channel.objects.get(code=code)
|
channel = Channel.objects.get(code=code)
|
||||||
assert channel.user == request.user
|
if channel.user != request.user:
|
||||||
|
return HttpResponseForbidden()
|
||||||
|
|
||||||
channel.checks = []
|
new_checks = []
|
||||||
print (request.POST)
|
|
||||||
for key in request.POST:
|
for key in request.POST:
|
||||||
if key.startswith("check-"):
|
if key.startswith("check-"):
|
||||||
code = key[6:]
|
code = key[6:]
|
||||||
check = Check.objects.get(code=code)
|
check = Check.objects.get(code=code)
|
||||||
assert check.user == request.user
|
if check.user != request.user:
|
||||||
channel.checks.add(check)
|
return HttpResponseForbidden()
|
||||||
|
new_checks.append(check)
|
||||||
|
|
||||||
channel.save()
|
channel.checks = new_checks
|
||||||
return redirect("hc-channels")
|
return redirect("hc-channels")
|
||||||
|
|
||||||
|
|
||||||
channels = Channel.objects.filter(user=request.user).order_by("created")
|
channels = Channel.objects.filter(user=request.user).order_by("created")
|
||||||
num_checks = Check.objects.filter(user=request.user).count()
|
num_checks = Check.objects.filter(user=request.user).count()
|
||||||
|
|
||||||
@ -216,7 +216,6 @@ def add_channel(request):
|
|||||||
|
|
||||||
checks = Check.objects.filter(user=request.user)
|
checks = Check.objects.filter(user=request.user)
|
||||||
channel.checks.add(*checks)
|
channel.checks.add(*checks)
|
||||||
channel.save()
|
|
||||||
|
|
||||||
return redirect("hc-channels")
|
return redirect("hc-channels")
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user