mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-17 13:32:15 +00:00
829 lines
38 KiB
Python
829 lines
38 KiB
Python
# -*- coding: utf-8 -*-
|
|
import os
|
|
import re
|
|
from datetime import date, time, datetime, timedelta
|
|
|
|
import pytz
|
|
from django.conf import settings
|
|
from django.core import mail, signing
|
|
from django.db import transaction
|
|
from django.http import HttpResponseBadRequest
|
|
from django.test import LiveServerTestCase, TestCase
|
|
from django.test.client import Client
|
|
from django.urls import reverse
|
|
from reversion import revisions as reversion
|
|
from selenium import webdriver
|
|
from selenium.common.exceptions import StaleElementReferenceException
|
|
from selenium.webdriver.support import expected_conditions
|
|
from selenium.webdriver.common.keys import Keys
|
|
from selenium.webdriver.support.ui import WebDriverWait
|
|
|
|
from RIGS import models
|
|
|
|
from reversion import revisions as reversion
|
|
from django.urls import reverse
|
|
from django.core import mail, signing
|
|
from PyRIGS.tests.base import create_browser, animation_is_finished
|
|
from django.conf import settings
|
|
|
|
import sys
|
|
|
|
|
|
class EventTest(LiveServerTestCase):
|
|
def setUp(self):
|
|
self.profile = models.Profile(
|
|
username="EventTest", first_name="Event", last_name="Test", initials="ETU", is_superuser=True)
|
|
self.profile.set_password("EventTestPassword")
|
|
self.profile.save()
|
|
|
|
self.vatrate = models.VatRate.objects.create(start_at='2014-03-05', rate=0.20, comment='test1')
|
|
|
|
self.browser = create_browser()
|
|
self.browser.implicitly_wait(10) # Set implicit wait session wide
|
|
# self.browser.maximize_window()
|
|
|
|
os.environ['RECAPTCHA_TESTING'] = 'True'
|
|
|
|
def tearDown(self):
|
|
self.browser.quit()
|
|
os.environ['RECAPTCHA_TESTING'] = 'False'
|
|
|
|
def authenticate(self, n=None):
|
|
self.assertIn(
|
|
self.live_server_url + '/user/login/', self.browser.current_url)
|
|
if n:
|
|
self.assertIn('?next=%s' % n, self.browser.current_url)
|
|
username = self.browser.find_element_by_id('id_username')
|
|
password = self.browser.find_element_by_id('id_password')
|
|
submit = self.browser.find_element_by_css_selector(
|
|
'input[type=submit]')
|
|
|
|
username.send_keys("EventTest")
|
|
password.send_keys("EventTestPassword")
|
|
submit.click()
|
|
|
|
self.assertEqual(self.live_server_url + n, self.browser.current_url)
|
|
|
|
def testEventDuplicate(self):
|
|
client = models.Person.objects.create(name='Duplicate Test Person', email='duplicate@functional.test')
|
|
testEvent = models.Event.objects.create(name="TE E1", status=models.Event.PROVISIONAL,
|
|
start_date=date.today() + timedelta(days=6),
|
|
description="start future no end",
|
|
purchase_order='TESTPO',
|
|
person=client,
|
|
auth_request_by=self.profile,
|
|
auth_request_at=self.create_datetime(2015, 0o6, 0o4, 10, 00),
|
|
auth_request_to="some@email.address")
|
|
|
|
item1 = models.EventItem(
|
|
event=testEvent,
|
|
name="Test Item 1",
|
|
cost="10.00",
|
|
quantity="1",
|
|
order=1
|
|
).save()
|
|
item2 = models.EventItem(
|
|
event=testEvent,
|
|
name="Test Item 2",
|
|
description="Foo",
|
|
cost="9.72",
|
|
quantity="3",
|
|
order=2,
|
|
).save()
|
|
|
|
self.browser.get(self.live_server_url + '/event/' + str(testEvent.pk) + '/duplicate/')
|
|
self.authenticate('/event/' + str(testEvent.pk) + '/duplicate/')
|
|
|
|
wait = WebDriverWait(self.browser, 3) # setup WebDriverWait to use later (to wait for animations)
|
|
|
|
save = self.browser.find_element_by_xpath(
|
|
'(//button[@type="submit"])[3]')
|
|
form = self.browser.find_element_by_xpath('/html/body/div[2]/div[1]/form')
|
|
|
|
# Check the items are visible
|
|
table = self.browser.find_element_by_id('item-table') # ID number is known, see above
|
|
self.assertIn("Test Item 1", table.text)
|
|
self.assertIn("Test Item 2", table.text)
|
|
|
|
# Check the info message is visible
|
|
self.assertIn("Event data duplicated but not yet saved", self.browser.find_element_by_id('content').text)
|
|
|
|
# Add item
|
|
form.find_element_by_xpath('//button[contains(@class, "item-add")]').click()
|
|
modal = self.browser.find_element_by_id("itemModal")
|
|
wait.until(animation_is_finished())
|
|
# See modal has opened
|
|
self.assertTrue(modal.is_displayed())
|
|
modal.find_element_by_id("item_name").send_keys("Test Item 3")
|
|
modal.find_element_by_id("item_description").send_keys(
|
|
"This is an item description\nthat for reasons unknown spans two lines")
|
|
e = modal.find_element_by_id("item_quantity")
|
|
e.click()
|
|
e.send_keys(Keys.UP)
|
|
e.send_keys(Keys.UP)
|
|
e = modal.find_element_by_id("item_cost")
|
|
e.send_keys("23.95")
|
|
e.send_keys(Keys.ENTER) # enter submit
|
|
|
|
# Attempt to save
|
|
save.click()
|
|
|
|
newEvent = models.Event.objects.latest('pk')
|
|
|
|
self.assertEqual(newEvent.auth_request_to, None)
|
|
self.assertEqual(newEvent.auth_request_by, None)
|
|
self.assertEqual(newEvent.auth_request_at, None)
|
|
|
|
self.assertFalse(hasattr(newEvent, 'authorised'))
|
|
|
|
self.assertNotIn("N%05d" % testEvent.pk, self.browser.find_element_by_xpath('//h1').text)
|
|
self.assertNotIn("Event data duplicated but not yet saved",
|
|
self.browser.find_element_by_id('content').text) # Check info message not visible
|
|
|
|
# Check the new items are visible
|
|
table = self.browser.find_element_by_id('item-table') # ID number is known, see above
|
|
self.assertIn("Test Item 1", table.text)
|
|
self.assertIn("Test Item 2", table.text)
|
|
self.assertIn("Test Item 3", table.text)
|
|
|
|
infoPanel = self.browser.find_element_by_xpath('//div[contains(text(), "Event Info")]/..')
|
|
self.assertIn("N0000%d" % testEvent.pk,
|
|
infoPanel.find_element_by_xpath('//dt[text()="Based On"]/following-sibling::dd[1]').text)
|
|
# Check the PO hasn't carried through
|
|
self.assertNotIn("TESTPO", infoPanel.find_element_by_xpath('//dt[text()="PO"]/following-sibling::dd[1]').text)
|
|
|
|
self.assertIn("N%05d" % testEvent.pk,
|
|
infoPanel.find_element_by_xpath('//dt[text()="Based On"]/following-sibling::dd[1]').text)
|
|
|
|
self.browser.get(self.live_server_url + '/event/' + str(testEvent.pk)) # Go back to the old event
|
|
|
|
# Check that based-on hasn't crept into the old event
|
|
infoPanel = self.browser.find_element_by_xpath('//div[contains(text(), "Event Info")]/..')
|
|
self.assertNotIn("N0000%d" % testEvent.pk,
|
|
infoPanel.find_element_by_xpath('//dt[text()="Based On"]/following-sibling::dd[1]').text)
|
|
# Check the PO remains on the old event
|
|
self.assertIn("TESTPO", infoPanel.find_element_by_xpath('//dt[text()="PO"]/following-sibling::dd[1]').text)
|
|
|
|
self.assertNotIn("N%05d" % testEvent.pk,
|
|
infoPanel.find_element_by_xpath('//dt[text()="Based On"]/following-sibling::dd[1]').text)
|
|
|
|
# Check the items are as they were
|
|
table = self.browser.find_element_by_id('item-table') # ID number is known, see above
|
|
self.assertIn("Test Item 1", table.text)
|
|
self.assertIn("Test Item 2", table.text)
|
|
self.assertNotIn("Test Item 3", table.text)
|
|
|
|
def testDateValidation(self):
|
|
self.browser.get(self.live_server_url + '/event/create/')
|
|
# Gets redirected to login and back
|
|
self.authenticate('/event/create/')
|
|
|
|
wait = WebDriverWait(self.browser, 3) # setup WebDriverWait to use later (to wait for animations)
|
|
|
|
wait.until(animation_is_finished())
|
|
|
|
# Click Rig button
|
|
self.browser.find_element_by_xpath('//button[.="Rig"]').click()
|
|
|
|
form = self.browser.find_element_by_xpath('//*[@id="content"]/form')
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[3]')
|
|
|
|
# Set title
|
|
e = self.browser.find_element_by_id('id_name')
|
|
e.send_keys('Test Event Name')
|
|
|
|
# Set person
|
|
person = models.Person.objects.create(name='Date Validation Person', email='datevalidation@functional.test')
|
|
person_select = form.find_element_by_xpath(
|
|
'//button[@data-id="id_person"]')
|
|
person_select.send_keys(person.name)
|
|
person_dropped = form.find_element_by_xpath(
|
|
'//ul[contains(@class, "dropdown-menu")]//span[contains(text(), "%s")]' % person.name)
|
|
person_dropped.click()
|
|
|
|
# Both dates, no times, end before start
|
|
self.browser.execute_script("document.getElementById('id_start_date').value='3015-04-24'")
|
|
|
|
self.browser.execute_script("document.getElementById('id_end_date').value='3015-04-23'")
|
|
|
|
# Attempt to save - should fail
|
|
wait.until(animation_is_finished())
|
|
save.click()
|
|
|
|
error = self.browser.find_element_by_xpath('//div[contains(@class, "alert-danger")]')
|
|
self.assertTrue(error.is_displayed())
|
|
self.assertIn("can't finish before it has started", error.find_element_by_xpath('//dd[1]/ul/li').text)
|
|
|
|
# Same date, end time before start time
|
|
form = self.browser.find_element_by_xpath('/html/body/div[2]/div[1]/form')
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[3]')
|
|
|
|
self.browser.execute_script("document.getElementById('id_start_date').value='3015-04-24'")
|
|
self.browser.execute_script("document.getElementById('id_end_date').value='3015-04-23'")
|
|
|
|
form.find_element_by_id('id_start_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_start_time').send_keys('06:59')
|
|
|
|
form.find_element_by_id('id_end_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_end_time').send_keys('06:00')
|
|
|
|
# Attempt to save - should fail
|
|
save.click()
|
|
error = self.browser.find_element_by_xpath('//div[contains(@class, "alert-danger")]')
|
|
self.assertTrue(error.is_displayed())
|
|
self.assertIn("can't finish before it has started", error.find_element_by_xpath('//dd[1]/ul/li').text)
|
|
|
|
# Same date, end time before start time
|
|
form = self.browser.find_element_by_xpath('/html/body/div[2]/div[1]/form')
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[3]')
|
|
|
|
self.browser.execute_script("document.getElementById('id_start_date').value='3015-04-24'")
|
|
self.browser.execute_script("document.getElementById('id_end_date').value='3015-04-24'")
|
|
|
|
form.find_element_by_id('id_start_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_start_time').send_keys('06:59')
|
|
|
|
form.find_element_by_id('id_end_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_end_time').send_keys('06:00')
|
|
|
|
# No end date, end time before start time
|
|
form = self.browser.find_element_by_xpath('/html/body/div[2]/div[1]/form')
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[3]')
|
|
|
|
self.browser.execute_script("document.getElementById('id_start_date').value='3015-04-24'")
|
|
self.browser.execute_script("document.getElementById('id_end_date').value=''")
|
|
|
|
form.find_element_by_id('id_start_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_start_time').send_keys('06:59')
|
|
|
|
form.find_element_by_id('id_end_time').send_keys(Keys.DELETE)
|
|
form.find_element_by_id('id_end_time').send_keys('06:00')
|
|
|
|
# Attempt to save - should fail
|
|
save.click()
|
|
error = self.browser.find_element_by_xpath('//div[contains(@class, "alert-danger")]')
|
|
self.assertTrue(error.is_displayed())
|
|
self.assertIn("can't finish before it has started", error.find_element_by_xpath('//dd[1]/ul/li').text)
|
|
|
|
# 2 dates, end after start
|
|
form = self.browser.find_element_by_xpath('/html/body/div[2]/div[1]/form')
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[3]')
|
|
self.browser.execute_script("document.getElementById('id_start_date').value='3015-04-24'")
|
|
self.browser.execute_script("document.getElementById('id_end_date').value='3015-04-26'")
|
|
|
|
self.browser.execute_script("document.getElementById('id_start_time').value=''")
|
|
self.browser.execute_script("document.getElementById('id_end_time').value=''")
|
|
|
|
# Attempt to save - should succeed
|
|
save.click()
|
|
|
|
# See redirected to success page
|
|
successTitle = self.browser.find_element_by_xpath('//h1').text
|
|
event = models.Event.objects.get(name='Test Event Name')
|
|
|
|
self.assertIn("N%05d | Test Event Name" % event.pk, successTitle)
|
|
|
|
def testEventDetail(self):
|
|
with transaction.atomic(), reversion.create_revision():
|
|
person = models.Person(name="Event Detail Person", email="eventdetail@person.tests.rigs", phone="123 123")
|
|
person.save()
|
|
with transaction.atomic(), reversion.create_revision():
|
|
organisation = models.Organisation(name="Event Detail Organisation",
|
|
email="eventdetail@organisation.tests.rigs", phone="123 456").save()
|
|
with transaction.atomic(), reversion.create_revision():
|
|
venue = models.Venue(name="Event Detail Venue").save()
|
|
with transaction.atomic(), reversion.create_revision():
|
|
event = models.Event(
|
|
name="Detail Test",
|
|
description="This is an event to test the detail view",
|
|
notes="It is going to be aweful",
|
|
person=person,
|
|
organisation=organisation,
|
|
start_date='2015-06-04'
|
|
)
|
|
event.save()
|
|
with transaction.atomic(), reversion.create_revision():
|
|
item1 = models.EventItem(
|
|
event=event,
|
|
name="Detail Item 1",
|
|
cost="10.00",
|
|
quantity="1",
|
|
order=1
|
|
).save()
|
|
item2 = models.EventItem(
|
|
event=event,
|
|
name="Detail Item 2",
|
|
description="Foo",
|
|
cost="9.72",
|
|
quantity="3",
|
|
order=2,
|
|
).save()
|
|
|
|
self.browser.get(self.live_server_url + '/event/%d' % event.pk)
|
|
self.authenticate('/event/%d/' % event.pk)
|
|
self.assertIn("N%05d | %s" % (event.pk, event.name), self.browser.find_element_by_xpath('//h1').text)
|
|
|
|
personPanel = self.browser.find_element_by_xpath('//div[contains(text(), "Contact Details")]/..')
|
|
self.assertEqual(person.name,
|
|
personPanel.find_element_by_xpath('//dt[text()="Person"]/following-sibling::dd[1]').text)
|
|
self.assertEqual(person.email,
|
|
personPanel.find_element_by_xpath('//dt[text()="Email"]/following-sibling::dd[1]').text)
|
|
self.assertEqual(person.phone,
|
|
personPanel.find_element_by_xpath('//dt[text()="Phone Number"]/following-sibling::dd[1]').text)
|
|
|
|
organisationPanel = self.browser.find_element_by_xpath('//div[contains(text(), "Contact Details")]/..')
|
|
|
|
def testEventEdit(self):
|
|
person = models.Person.objects.create(name="Event Edit Person", email="eventdetail@person.tests.rigs",
|
|
phone="123 123")
|
|
organisation = models.Organisation.objects.create(name="Event Edit Organisation",
|
|
email="eventdetail@organisation.tests.rigs", phone="123 456")
|
|
venue = models.Venue.objects.create(name="Event Detail Venue")
|
|
|
|
eventData = {
|
|
'name': "Detail Test",
|
|
'description': "This is an event to test the detail view",
|
|
'notes': "It is going to be awful",
|
|
'person': person,
|
|
'organisation': organisation,
|
|
'venue': venue,
|
|
'mic': self.profile,
|
|
'start_date': date(2015, 0o6, 0o4),
|
|
'end_date': date(2015, 0o6, 0o5),
|
|
'start_time': time(10, 00),
|
|
'end_time': time(15, 00),
|
|
'meet_at': self.create_datetime(2015, 0o6, 0o4, 10, 00),
|
|
'access_at': self.create_datetime(2015, 0o6, 0o4, 10, 00),
|
|
'collector': 'A Person'
|
|
}
|
|
|
|
event = models.Event(**eventData)
|
|
event.save()
|
|
|
|
item1Data = {
|
|
'event': event,
|
|
'name': "Detail Item 1",
|
|
'cost': "10.00",
|
|
'quantity': "1",
|
|
'order': 1
|
|
}
|
|
|
|
models.EventItem(**item1Data).save()
|
|
|
|
self.browser.get(self.live_server_url + '/event/%d/edit/' % event.pk)
|
|
self.authenticate('/event/%d/edit/' % event.pk)
|
|
|
|
save = self.browser.find_element_by_xpath('(//button[@type="submit"])[1]')
|
|
save.click()
|
|
|
|
successTitle = self.browser.find_element_by_xpath('//h1').text
|
|
self.assertIn("N%05d | Detail Test" % event.pk, successTitle)
|
|
|
|
reloadedEvent = models.Event.objects.get(name='Detail Test')
|
|
reloadedItem = models.EventItem.objects.get(name='Detail Item 1')
|
|
|
|
# Check the event
|
|
for key, value in eventData.items():
|
|
self.assertEqual(str(getattr(reloadedEvent, key)), str(value))
|
|
|
|
# Check the item
|
|
for key, value in item1Data.items():
|
|
self.assertEqual(str(getattr(reloadedItem, key)), str(value))
|
|
|
|
def create_datetime(self, year, month, day, hour, min):
|
|
tz = pytz.timezone(settings.TIME_ZONE)
|
|
return tz.localize(datetime(year, month, day, hour, min)).astimezone(pytz.utc)
|
|
|
|
|
|
class IcalTest(LiveServerTestCase):
|
|
def setUp(self):
|
|
self.all_events = set(range(1, 18))
|
|
self.current_events = (1, 2, 3, 6, 7, 8, 10, 11, 12, 14, 15, 16, 18)
|
|
self.not_current_events = set(self.all_events) - set(self.current_events)
|
|
|
|
self.vatrate = models.VatRate.objects.create(start_at='2014-03-05', rate=0.20, comment='test1')
|
|
self.profile = models.Profile(
|
|
username="EventTest", first_name="Event", last_name="Test", initials="ETU", is_superuser=True)
|
|
self.profile.set_password("EventTestPassword")
|
|
self.profile.save()
|
|
|
|
# produce 7 normal events - 5 current - 1 last week - 1 two years ago - 2 provisional - 2 confirmed - 3 booked
|
|
models.Event.objects.create(name="TE E1", status=models.Event.PROVISIONAL,
|
|
start_date=date.today() + timedelta(days=6), description="start future no end")
|
|
models.Event.objects.create(name="TE E2", status=models.Event.PROVISIONAL, start_date=date.today(),
|
|
description="start today no end")
|
|
models.Event.objects.create(name="TE E3", status=models.Event.CONFIRMED, start_date=date.today(),
|
|
end_date=date.today(), description="start today with end today")
|
|
models.Event.objects.create(name="TE E4", status=models.Event.CONFIRMED,
|
|
start_date=date.today() - timedelta(weeks=104),
|
|
description="start past 2 years no end")
|
|
models.Event.objects.create(name="TE E5", status=models.Event.BOOKED,
|
|
start_date=date.today() - timedelta(days=7),
|
|
end_date=date.today() - timedelta(days=1),
|
|
description="start past 1 week with end past")
|
|
models.Event.objects.create(name="TE E6", status=models.Event.BOOKED,
|
|
start_date=date.today() - timedelta(days=2),
|
|
start_time=time(8, 00),
|
|
end_date=date.today() + timedelta(days=2),
|
|
end_time=time(23, 00), description="start past, end future")
|
|
models.Event.objects.create(name="TE E7", status=models.Event.BOOKED,
|
|
start_date=date.today() + timedelta(days=2),
|
|
end_date=date.today() + timedelta(days=2), description="start + end in future")
|
|
|
|
# 2 cancelled - 1 current
|
|
models.Event.objects.create(name="TE E8", start_date=date.today() + timedelta(days=2),
|
|
end_date=date.today() + timedelta(days=2), status=models.Event.CANCELLED,
|
|
description="cancelled in future")
|
|
models.Event.objects.create(name="TE E9", start_date=date.today() - timedelta(days=1),
|
|
end_date=date.today() + timedelta(days=2), status=models.Event.CANCELLED,
|
|
description="cancelled and started")
|
|
|
|
# 5 dry hire - 3 current - 1 cancelled
|
|
models.Event.objects.create(name="TE E10", start_date=date.today(), dry_hire=True, description="dryhire today")
|
|
models.Event.objects.create(name="TE E11", start_date=date.today(), dry_hire=True, checked_in_by=self.profile,
|
|
description="dryhire today, checked in")
|
|
models.Event.objects.create(name="TE E12", start_date=date.today() - timedelta(days=1), dry_hire=True,
|
|
status=models.Event.BOOKED, description="dryhire past")
|
|
models.Event.objects.create(name="TE E13", start_date=date.today() - timedelta(days=2), dry_hire=True,
|
|
checked_in_by=self.profile, description="dryhire past checked in")
|
|
models.Event.objects.create(name="TE E14", start_date=date.today(), dry_hire=True,
|
|
status=models.Event.CANCELLED, description="dryhire today cancelled")
|
|
|
|
# 4 non rig - 3 current
|
|
models.Event.objects.create(name="TE E15", start_date=date.today(), is_rig=False, description="non rig today")
|
|
models.Event.objects.create(name="TE E16", start_date=date.today() + timedelta(days=1), is_rig=False,
|
|
description="non rig tomorrow")
|
|
models.Event.objects.create(name="TE E17", start_date=date.today() - timedelta(days=1), is_rig=False,
|
|
description="non rig yesterday")
|
|
models.Event.objects.create(name="TE E18", start_date=date.today(), is_rig=False, status=models.Event.CANCELLED,
|
|
description="non rig today cancelled")
|
|
|
|
self.browser = create_browser()
|
|
self.browser.implicitly_wait(3) # Set implicit wait session wide
|
|
os.environ['RECAPTCHA_TESTING'] = 'True'
|
|
|
|
def tearDown(self):
|
|
self.browser.quit()
|
|
os.environ['RECAPTCHA_TESTING'] = 'False'
|
|
|
|
def authenticate(self, n=None):
|
|
self.assertIn(
|
|
self.live_server_url + '/user/login/', self.browser.current_url)
|
|
if n:
|
|
self.assertIn('?next=%s' % n, self.browser.current_url)
|
|
username = self.browser.find_element_by_id('id_username')
|
|
password = self.browser.find_element_by_id('id_password')
|
|
submit = self.browser.find_element_by_css_selector(
|
|
'input[type=submit]')
|
|
|
|
username.send_keys("EventTest")
|
|
password.send_keys("EventTestPassword")
|
|
submit.click()
|
|
|
|
self.assertEqual(self.live_server_url + n, self.browser.current_url)
|
|
|
|
def testApiKeyGeneration(self):
|
|
# Requests address
|
|
self.browser.get(self.live_server_url + '/user/')
|
|
# Gets redirected to login
|
|
self.authenticate('/user/')
|
|
|
|
# Completes and comes back to /user/
|
|
# Checks that no api key is displayed
|
|
self.assertEqual("No API Key Generated",
|
|
self.browser.find_element_by_xpath("//div[@id='content']/div/div/div[3]/dl[2]/dd").text)
|
|
self.assertEqual("No API Key Generated", self.browser.find_element_by_css_selector("pre").text)
|
|
|
|
# Now creates an API key, and check a URL is displayed one
|
|
self.browser.find_element_by_link_text("Generate API Key").click()
|
|
self.assertIn("rigs.ics", self.browser.find_element_by_id("cal-url").text)
|
|
self.assertNotIn("?", self.browser.find_element_by_id("cal-url").text)
|
|
|
|
# Lets change everything so it's not the default value
|
|
self.browser.find_element_by_xpath("//input[@value='rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='non-rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='dry-hire']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='cancelled']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='provisional']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='confirmed']").click()
|
|
|
|
# and then check the url is correct
|
|
self.assertIn(
|
|
"rigs.ics?rig=false&non-rig=false&dry-hire=false&cancelled=true&provisional=false&confirmed=false",
|
|
self.browser.find_element_by_id("cal-url").text)
|
|
|
|
# Awesome - all seems to work
|
|
|
|
def testICSFiles(self):
|
|
specialEvent = models.Event.objects.get(name="TE E6")
|
|
|
|
# Requests address
|
|
self.browser.get(self.live_server_url + '/user/')
|
|
# Gets redirected to login
|
|
self.authenticate('/user/')
|
|
|
|
# Now creates an API key, and check a URL is displayed one
|
|
self.browser.find_element_by_link_text("Generate API Key").click()
|
|
|
|
c = Client()
|
|
|
|
# Default settings - should have all non-cancelled events
|
|
# Get the ical file (can't do this in selanium because reasons)
|
|
icalUrl = self.browser.find_element_by_id("cal-url").text
|
|
response = c.get(icalUrl)
|
|
self.assertEqual(200, response.status_code)
|
|
|
|
# content = response.content.decode('utf-8')
|
|
|
|
# Check has entire file
|
|
self.assertContains(response, "BEGIN:VCALENDAR")
|
|
self.assertContains(response, "END:VCALENDAR")
|
|
|
|
expectedIn = [1, 2, 3, 5, 6, 7, 10, 11, 12, 13, 15, 16, 17]
|
|
for test in range(1, 18):
|
|
if test in expectedIn:
|
|
self.assertContains(response, "TE E" + str(test) + " ")
|
|
else:
|
|
self.assertNotContains(response, "TE E" + str(test) + " ")
|
|
|
|
# Check that times have been included correctly
|
|
self.assertContains(response,
|
|
specialEvent.start_date.strftime('%Y%m%d') + 'T' + specialEvent.start_time.strftime(
|
|
'%H%M%S'))
|
|
self.assertContains(response,
|
|
specialEvent.end_date.strftime('%Y%m%d') + 'T' + specialEvent.end_time.strftime('%H%M%S'))
|
|
|
|
# Only dry hires
|
|
self.browser.find_element_by_xpath("//input[@value='rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='non-rig']").click()
|
|
|
|
icalUrl = self.browser.find_element_by_id("cal-url").text
|
|
response = c.get(icalUrl)
|
|
self.assertEqual(200, response.status_code)
|
|
|
|
expectedIn = [10, 11, 12, 13]
|
|
for test in range(1, 18):
|
|
if test in expectedIn:
|
|
self.assertContains(response, "TE E" + str(test) + " ")
|
|
else:
|
|
self.assertNotContains(response, "TE E" + str(test) + " ")
|
|
|
|
# Only provisional rigs
|
|
self.browser.find_element_by_xpath("//input[@value='rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='dry-hire']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='confirmed']").click()
|
|
|
|
icalUrl = self.browser.find_element_by_id("cal-url").text
|
|
response = c.get(icalUrl)
|
|
self.assertEqual(200, response.status_code)
|
|
|
|
expectedIn = [1, 2]
|
|
for test in range(1, 18):
|
|
if test in expectedIn:
|
|
self.assertContains(response, "TE E" + str(test) + " ")
|
|
else:
|
|
self.assertNotContains(response, "TE E" + str(test) + " ")
|
|
|
|
# Only cancelled non-rigs
|
|
self.browser.find_element_by_xpath("//input[@value='rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='non-rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='provisional']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='cancelled']").click()
|
|
|
|
icalUrl = self.browser.find_element_by_id("cal-url").text
|
|
response = c.get(icalUrl)
|
|
self.assertEqual(200, response.status_code)
|
|
|
|
expectedIn = [18]
|
|
for test in range(1, 18):
|
|
if test in expectedIn:
|
|
self.assertContains(response, "TE E" + str(test) + " ")
|
|
else:
|
|
self.assertNotContains(response, "TE E" + str(test) + " ")
|
|
|
|
# Nothing selected
|
|
self.browser.find_element_by_xpath("//input[@value='non-rig']").click()
|
|
self.browser.find_element_by_xpath("//input[@value='cancelled']").click()
|
|
|
|
icalUrl = self.browser.find_element_by_id("cal-url").text
|
|
response = c.get(icalUrl)
|
|
self.assertEqual(200, response.status_code)
|
|
|
|
expectedIn = []
|
|
for test in range(1, 18):
|
|
if test in expectedIn:
|
|
self.assertContains(response, "TE E" + str(test) + " ")
|
|
else:
|
|
self.assertNotContains(response, "TE E" + str(test) + " ")
|
|
|
|
# Wow - that was a lot of tests
|
|
|
|
|
|
class ClientEventAuthorisationTest(TestCase):
|
|
auth_data = {
|
|
'name': 'Test ABC',
|
|
'po': '1234ABCZXY',
|
|
'account_code': 'ABC TEST 12345',
|
|
'uni_id': 1234567890,
|
|
'tos': True
|
|
}
|
|
|
|
def setUp(self):
|
|
self.profile = models.Profile.objects.get_or_create(
|
|
first_name='Test',
|
|
last_name='TEC User',
|
|
username='eventauthtest',
|
|
email='teccie@functional.test',
|
|
is_superuser=True # lazily grant all permissions
|
|
)[0]
|
|
self.vatrate = models.VatRate.objects.create(start_at='2014-03-05', rate=0.20, comment='test1')
|
|
venue = models.Venue.objects.create(name='Authorisation Test Venue')
|
|
client = models.Person.objects.create(name='Authorisation Test Person', email='authorisation@functional.test')
|
|
organisation = models.Organisation.objects.create(name='Authorisation Test Organisation', union_account=False)
|
|
self.event = models.Event.objects.create(
|
|
name='Authorisation Test',
|
|
start_date=date.today(),
|
|
venue=venue,
|
|
person=client,
|
|
organisation=organisation,
|
|
)
|
|
self.hmac = signing.dumps({'pk': self.event.pk, 'email': 'authemail@function.test',
|
|
'sent_by': self.profile.pk})
|
|
self.url = reverse('event_authorise', kwargs={'pk': self.event.pk, 'hmac': self.hmac})
|
|
|
|
def test_requires_valid_hmac(self):
|
|
bad_hmac = self.hmac[:-1]
|
|
url = reverse('event_authorise', kwargs={'pk': self.event.pk, 'hmac': bad_hmac})
|
|
response = self.client.get(url)
|
|
self.assertIsInstance(response, HttpResponseBadRequest)
|
|
# TODO: Add some form of sensbile user facing error
|
|
# self.assertIn(response.content, "new URL") # check there is some level of sane instruction
|
|
|
|
response = self.client.get(self.url)
|
|
self.assertContains(response, self.event.organisation.name)
|
|
|
|
def test_generic_validation(self):
|
|
response = self.client.get(self.url)
|
|
self.assertContains(response, "Terms of Hire")
|
|
|
|
response = self.client.post(self.url)
|
|
self.assertContains(response, "This field is required.", 5)
|
|
|
|
data = self.auth_data
|
|
data['amount'] = self.event.total + 1
|
|
|
|
response = self.client.post(self.url, data)
|
|
self.assertContains(response, "The amount authorised must equal the total for the event")
|
|
self.assertNotContains(response, "This field is required.")
|
|
|
|
data['amount'] = self.event.total
|
|
response = self.client.post(self.url, data)
|
|
self.assertContains(response, "Your event has been authorised")
|
|
|
|
self.event.refresh_from_db()
|
|
self.assertTrue(self.event.authorised)
|
|
self.assertEqual(self.event.authorisation.email, "authemail@function.test")
|
|
|
|
def test_internal_validation(self):
|
|
self.event.organisation.union_account = True
|
|
self.event.organisation.save()
|
|
|
|
response = self.client.get(self.url)
|
|
self.assertContains(response, "Account code")
|
|
self.assertContains(response, "University ID")
|
|
|
|
response = self.client.post(self.url)
|
|
self.assertContains(response, "This field is required.", 5)
|
|
|
|
data = self.auth_data
|
|
response = self.client.post(self.url, data)
|
|
self.assertContains(response, "Your event has been authorised.")
|
|
|
|
def test_duplicate_warning(self):
|
|
auth = models.EventAuthorisation.objects.create(event=self.event, name='Test ABC', email='dupe@functional.test',
|
|
amount=self.event.total, sent_by=self.profile)
|
|
response = self.client.get(self.url)
|
|
self.assertContains(response, 'This event has already been authorised.')
|
|
|
|
auth.amount += 1
|
|
auth.save()
|
|
|
|
response = self.client.get(self.url)
|
|
self.assertContains(response, 'amount has changed')
|
|
|
|
def test_email_sent(self):
|
|
mail.outbox = []
|
|
|
|
data = self.auth_data
|
|
data['amount'] = self.event.total
|
|
|
|
response = self.client.post(self.url, data)
|
|
self.assertContains(response, "Your event has been authorised.")
|
|
self.assertEqual(len(mail.outbox), 2)
|
|
|
|
self.assertEqual(mail.outbox[0].to, ['authemail@function.test'])
|
|
self.assertEqual(mail.outbox[1].to, [settings.AUTHORISATION_NOTIFICATION_ADDRESS])
|
|
|
|
|
|
class TECEventAuthorisationTest(TestCase):
|
|
@classmethod
|
|
def setUpTestData(cls):
|
|
cls.profile = models.Profile.objects.get_or_create(
|
|
first_name='Test',
|
|
last_name='TEC User',
|
|
username='eventauthtest',
|
|
email='teccie@nottinghamtec.co.uk',
|
|
is_superuser=True # lazily grant all permissions
|
|
)[0]
|
|
cls.profile.set_password('eventauthtest123')
|
|
cls.profile.save()
|
|
|
|
def setUp(self):
|
|
self.vatrate = models.VatRate.objects.create(start_at='2014-03-05', rate=0.20, comment='test1')
|
|
venue = models.Venue.objects.create(name='Authorisation Test Venue')
|
|
client = models.Person.objects.create(name='Authorisation Test Person', email='authorisation@functional.test')
|
|
organisation = models.Organisation.objects.create(name='Authorisation Test Organisation', union_account=False)
|
|
self.event = models.Event.objects.create(
|
|
name='Authorisation Test',
|
|
start_date=date.today(),
|
|
venue=venue,
|
|
person=client,
|
|
organisation=organisation,
|
|
)
|
|
self.url = reverse('event_authorise_request', kwargs={'pk': self.event.pk})
|
|
|
|
def test_email_check(self):
|
|
self.profile.email = 'teccie@someotherdomain.com'
|
|
self.profile.save()
|
|
|
|
self.assertTrue(self.client.login(username=self.profile.username, password='eventauthtest123'))
|
|
|
|
response = self.client.post(self.url)
|
|
|
|
self.assertContains(response, 'must have an @nottinghamtec.co.uk email address')
|
|
|
|
def test_request_send(self):
|
|
self.assertTrue(self.client.login(username=self.profile.username, password='eventauthtest123'))
|
|
response = self.client.post(self.url)
|
|
self.assertContains(response, 'This field is required.')
|
|
|
|
mail.outbox = []
|
|
|
|
response = self.client.post(self.url, {'email': 'client@functional.test'})
|
|
self.assertEqual(response.status_code, 302)
|
|
self.assertEqual(len(mail.outbox), 1)
|
|
email = mail.outbox[0]
|
|
self.assertIn('client@functional.test', email.to)
|
|
self.assertIn('/event/%d/' % (self.event.pk), email.body)
|
|
|
|
# Check sent by details are populated
|
|
self.event.refresh_from_db()
|
|
self.assertEqual(self.event.auth_request_by, self.profile)
|
|
self.assertEqual(self.event.auth_request_to, 'client@functional.test')
|
|
self.assertIsNotNone(self.event.auth_request_at)
|
|
|
|
class SearchTest(LiveServerTestCase):
|
|
def setUp(self):
|
|
self.profile = models.Profile(
|
|
username="SearchTest", first_name="Search", last_name="Test", initials="STU", is_superuser=True)
|
|
self.profile.set_password("SearchTestPassword")
|
|
self.profile.save()
|
|
|
|
self.vatrate = models.VatRate.objects.create(start_at='2014-03-05', rate=0.20, comment='test1')
|
|
|
|
self.browser = create_browser()
|
|
self.browser.implicitly_wait(10) # Set implicit wait session wide
|
|
|
|
os.environ['RECAPTCHA_TESTING'] = 'True'
|
|
|
|
models.Event.objects.create(name="Right Event", status=models.Event.PROVISIONAL,
|
|
start_date=date.today(),
|
|
description="This event is searched for endlessly over and over")
|
|
models.Event.objects.create(name="Wrong Event", status=models.Event.PROVISIONAL, start_date=date.today(),
|
|
description="This one should never be found.")
|
|
|
|
def tearDown(self):
|
|
self.browser.quit()
|
|
os.environ['RECAPTCHA_TESTING'] = 'False'
|
|
|
|
def test_search(self):
|
|
self.browser.get(self.live_server_url)
|
|
username = self.browser.find_element_by_id('id_username')
|
|
password = self.browser.find_element_by_id('id_password')
|
|
submit = self.browser.find_element_by_css_selector(
|
|
'input[type=submit]')
|
|
|
|
username.send_keys("SearchTest")
|
|
password.send_keys("SearchTestPassword")
|
|
submit.click()
|
|
|
|
form = self.browser.find_element_by_id('searchForm')
|
|
search_box = form.find_element_by_id('id_search_input')
|
|
search_box.send_keys('Right')
|
|
search_box.send_keys(Keys.ENTER)
|
|
|
|
event_name = self.browser.find_element_by_xpath(
|
|
'//*[@id="content"]/div[1]/div[4]/div/div/table/tbody/tr[1]/td[3]/h4').text
|
|
self.assertIn('Right', event_name)
|
|
self.assertNotIn('Wrong', event_name)
|