summaryrefslogtreecommitdiffstats
path: root/core/TESTS/tests_caves.py
diff options
context:
space:
mode:
Diffstat (limited to 'core/TESTS/tests_caves.py')
-rw-r--r--core/TESTS/tests_caves.py150
1 files changed, 136 insertions, 14 deletions
diff --git a/core/TESTS/tests_caves.py b/core/TESTS/tests_caves.py
index 2e05ce9..841691c 100644
--- a/core/TESTS/tests_caves.py
+++ b/core/TESTS/tests_caves.py
@@ -4,36 +4,137 @@ Modified for Expo April 2021.
import unittest
import re
-from django.test import TestCase, SimpleTestCase, TransactionTestCase, Client
-from troggle.core.models.caves import Cave
+from django.test import TestCase, SimpleTestCase, Client
+from troggle.core.models.troggle import Expedition, Person, PersonExpedition
+from troggle.core.models.caves import Cave, Area
-
-class FixturePageTests(TestCase):
- # The fixtures have a password hash which is compatible with plain-text password 'secretword'
- fixtures = ['auth_users', 'expo_areas', 'expo_caves']
+class FixtureTests(TestCase):
+ '''These just hit the database.
+ They do not exercise the GET and url functions
+ '''
+ fixtures = ['auth_users', 'expo_areas', 'expo_caves', 'expo_exped']
ph = r'and leads in 800m of tortuous going to'
def setUp(self):
- from django.contrib.auth.models import User
- self.user = User.objects.get(username='expotest')
-
+ pass
+
def tearDown(self):
pass
+
+ def test_fix_person_loaded(self):
+ p = Person.objects.get(fullname='Michael Sargent')
+ self.assertEqual(str(p.first_name), "Michael")
- def test_fix_cave_loaded(self):
+ def test_fix_person_loaded(self):
+ pe = PersonExpedition.objects.get(pk='681')
+ self.assertEqual(str(pe.person.fullname), 'Michael Sargent')
+ self.assertEqual(str(pe.expedition.year), '2019')
+
+ def test_fix_area_loaded(self):
+ a = Area.objects.get(short_name='1623')
+ self.assertEqual(str(a.short_name), "1623")
+
+ def test_fix_cave_loaded115(self):
c = Cave.objects.get(kataster_number='115')
self.assertEqual(str(c.description_file), "1623/115.htm")
self.assertEqual(str(c.url), "1623/115.htm")
self.assertEqual(str(c.filename), "1623-115.html")
+ # c.area is a 'ManyRelatedManager' object and not iterable
+ #self.assertEqual(str(c.[0].short_name), "1623")
+
ph = self.ph
phmatch = re.search(ph, c.underground_description)
self.assertIsNotNone(phmatch, "In fixture-loaded cave, failed to find expected text: '" + ph +"'")
- def test_fix_cave_url(self):
+ def test_fix_cave_loaded284(self):
+ c = Cave.objects.get(kataster_number='284')
+ self.assertEqual(str(c.description_file), "")
+ self.assertEqual(str(c.url), "1623/284/284.html")
+ self.assertEqual(str(c.filename), "1623-284.html")
+
+ ph = r'at a depth of 72m, there are large round blocks'
+ phmatch = re.search(ph, c.notes)
+ self.assertIsNotNone(phmatch, "In fixture-loaded cave, failed to find expected text: '" + ph +"'")
+
+
+class FixturePageTests(TestCase):
+ '''Currently nothing that runs troggle works - all do 404. Must be something in a template rendering crash?
+ ordinary pages are OK, and expopages and expofiles are OK, even though they come through troggle.
+ '''
+ # The fixtures have a password hash which is compatible with plain-text password 'secretword'
+ fixtures = ['auth_users', 'expo_areas', 'expo_caves', 'expo_exped']
+ ph = r'and leads in 800m of tortuous going to'
+
+ @classmethod
+ def setUpTestData(cls):
+ pass
+
+
+ def setUp(self):
+ from django.contrib.auth.models import User
+ self.user = User.objects.get(username='expotest')
+
+ # Every test needs a client.
+ self.client = Client()
+
+ def tearDown(self):
+ pass
+
+
+ def test_fix_expedition(self):
+ response = self.client.get('/expedition/2019')
+ self.assertEqual(response.status_code, 200)
+
+ ph = r'Michael Sargent'
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ with open('exped-op.html', 'w') as f:
+ f.write(content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'")
+
+
+ def test_fix_personexped(self):
+ response = self.client.get('/personexpedition/MichaelSargent/2019')
+ self.assertEqual(response.status_code, 200)
+
+ ph = r'Table of all trips and surveys aligned by date'
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ with open('persexped-op.html', 'w') as f:
+ f.write(content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'")
+
+ def test_fix_person(self):
+ response = self.client.get('/person/MichaelSargent')
+ self.assertEqual(response.status_code, 200)
+
+ ph = r'second-generation expo caver '
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ with open('person-op.html', 'w') as f:
+ f.write(content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'")
+
+
+ def test_fix_cave_url115(self):
ph = self.ph
- response = self.client.get('1623/115.htm')
- #self.assertEqual(response.status_code, 200)
+ response = self.client.get('/1623/115.htm')
+ self.assertEqual(response.status_code, 200)
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'")
+
+
+ def test_fix_cave_url284(self):
+ response = self.client.get('/1623/284/284.html')
+ self.assertEqual(response.status_code, 200)
+
+ ph = r'at a depth of 72m, there are large round blocks'
content = response.content.decode()
phmatch = re.search(ph, content)
@@ -41,4 +142,25 @@ class FixturePageTests(TestCase):
f.write(content)
self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'")
- \ No newline at end of file
+ def test_fix_cave_bare_url115(self):
+ '''Expect to get Page Not Found and status 200'''
+ ph = self.ph
+ ph = 'Probably a mistake.'
+ response = self.client.get('/1623/115')
+ self.assertEqual(response.status_code, 200)
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'") # 200 & Page Not Found
+
+
+ def test_fix_cave_slug115(self):
+ '''Expect to get Page Not Found and status 200'''
+ ph = self.ph
+ ph = 'Probably a mistake.'
+ response = self.client.get('/1623-115')
+ self.assertEqual(response.status_code, 200)
+
+ content = response.content.decode()
+ phmatch = re.search(ph, content)
+ self.assertIsNotNone(phmatch, "Failed to find expected text: '" + ph +"'") # 200 & Page Not Found