Fix map tests, add files tests
This commit is contained in:
parent
d84aa0f3b9
commit
f4a74e6fd0
@ -1,3 +1,65 @@
|
||||
from django.contrib.auth.models import User
|
||||
from django.http import QueryDict
|
||||
from django.test import TestCase
|
||||
from django.utils.translation import activate
|
||||
from django.urls import reverse
|
||||
|
||||
# Create your tests here.
|
||||
from override_storage import override_storage
|
||||
|
||||
from .models import File
|
||||
|
||||
|
||||
@override_storage()
|
||||
class FileTests(TestCase):
|
||||
|
||||
test_user = 'testuser1'
|
||||
test_pass = '12345'
|
||||
|
||||
def setUp(self):
|
||||
test_user1 = User.objects.create_user(username=self.test_user, password=self.test_pass)
|
||||
test_user1.save()
|
||||
|
||||
activate('en-gb')
|
||||
|
||||
self.file = File.objects.create(user=test_user1)
|
||||
|
||||
def login(self):
|
||||
return self.client.login(username=self.test_user, password=self.test_pass)
|
||||
|
||||
def test_post_not_logged_in(self):
|
||||
url = reverse('files:upload')
|
||||
|
||||
next_url = QueryDict.fromkeys(['next',], url)
|
||||
login_url = reverse('auth_login') + '?' + next_url.urlencode()
|
||||
|
||||
response = self.client.post(url, follow=True)
|
||||
self.assertRedirects(response, login_url)
|
||||
|
||||
def test_delete_not_logged_in(self):
|
||||
url = reverse('files:delete', kwargs={'pk': self.file.pk})
|
||||
|
||||
next_url = QueryDict.fromkeys(['next',], url)
|
||||
login_url = reverse('auth_login') + '?' + next_url.urlencode()
|
||||
|
||||
response = self.client.post(url, follow=True)
|
||||
self.assertRedirects(response, login_url)
|
||||
|
||||
def test_post_and_delete(self):
|
||||
login = self.login()
|
||||
|
||||
with open('apps/map/static/map/ojuso-logo-white.png', 'rb') as fp:
|
||||
response = self.client.post(reverse('files:upload'), {
|
||||
'file': fp
|
||||
})
|
||||
|
||||
data = response.json()
|
||||
|
||||
self.assertEqual(data['is_valid'], True)
|
||||
|
||||
response = self.client.post(reverse('files:delete', kwargs={
|
||||
'pk': data['id']
|
||||
}))
|
||||
|
||||
data = response.json()
|
||||
|
||||
self.assertEqual(data['success'], True)
|
||||
|
@ -1,10 +1,10 @@
|
||||
from django.test import TestCase
|
||||
|
||||
from .models import CaseStudy
|
||||
|
||||
from django.contrib.auth.models import User
|
||||
from django.http import QueryDict
|
||||
from django.test import TestCase
|
||||
from django.utils.translation import activate
|
||||
from django.urls import reverse
|
||||
from .models import CaseStudyDraft
|
||||
|
||||
from .models import CaseStudy, CaseStudyDraft
|
||||
|
||||
|
||||
class CaseStudyDraftAPITests(TestCase):
|
||||
@ -16,20 +16,26 @@ class CaseStudyDraftAPITests(TestCase):
|
||||
test_user1 = User.objects.create_user(username=self.test_user, password=self.test_pass)
|
||||
test_user1.save()
|
||||
|
||||
activate('en-gb')
|
||||
|
||||
next_url = QueryDict.fromkeys(['next',], reverse('drafts'))
|
||||
|
||||
self.login_url = reverse('auth_login') + '?' + next_url.urlencode()
|
||||
|
||||
def login(self):
|
||||
return self.client.login(username=self.test_user, password=self.test_pass)
|
||||
|
||||
def test_get_not_logged_in(self):
|
||||
response = self.client.get(reverse('drafts'))
|
||||
self.assertEqual(response.status_code, 403)
|
||||
response = self.client.get(reverse('drafts'), follow=True)
|
||||
self.assertRedirects(response, self.login_url)
|
||||
|
||||
def test_put_not_logged_in(self):
|
||||
response = self.client.put(reverse('drafts'))
|
||||
self.assertEqual(response.status_code, 403)
|
||||
response = self.client.put(reverse('drafts'), follow=True)
|
||||
self.assertRedirects(response, self.login_url)
|
||||
|
||||
def test_delete_not_logged_in(self):
|
||||
response = self.client.delete(reverse('drafts'))
|
||||
self.assertEqual(response.status_code, 403)
|
||||
response = self.client.delete(reverse('drafts'), follow=True)
|
||||
self.assertRedirects(response, self.login_url)
|
||||
|
||||
def test_get_and_put(self):
|
||||
login = self.login()
|
||||
@ -97,26 +103,18 @@ class CaseStudyTests(TestCase):
|
||||
case_study = CaseStudy(generation_technology='OTHR', generation_technology_other='Warp drive')
|
||||
self.assertEqual(case_study.get_renewable_generation_detail(), "Warp drive")
|
||||
|
||||
# These tests are commented out because they are not working, but the code
|
||||
# in production is. When running as a test, get_negative_case_reasons_no_other()
|
||||
# is returning a list of coded options, like
|
||||
# ['V', 'O', 'L', 'R', ',', 'A', 'L', 'A', 'B']
|
||||
# instead of a list of text like
|
||||
# ['Violation of land rights', 'Abusive labour practices']
|
||||
# I am too much of a Django newbie to know why. – Anna
|
||||
def test_get_negative_case_reasons_no_other_1(self):
|
||||
"""Test with case having no 'other' entry"""
|
||||
case_study = CaseStudy(negative_case_reasons=['VOLR','ALAB'])
|
||||
self.assertEqual(case_study.get_negative_case_reasons_no_other(),
|
||||
[ 'Violation of land rights'
|
||||
, 'Abusive labour practices'
|
||||
])
|
||||
|
||||
# def test_get_negative_case_reasons_no_other_1(self):
|
||||
# """Test with case having no 'other' entry"""
|
||||
# case_study = CaseStudy(negative_case_reasons='VOLR,ALAB')
|
||||
# self.assertEqual(case_study.get_negative_case_reasons_no_other(),
|
||||
# [ 'Violation of land rights'
|
||||
# , 'Abusive labour practices'
|
||||
# ])
|
||||
#
|
||||
# def test_get_negative_case_reasons_no_other_2(self):
|
||||
# """Test with case having an 'other' entry"""
|
||||
# case_study = CaseStudy(negative_case_reasons='VOLR,ALAB,OTHR')
|
||||
# self.assertEqual(case_study.get_negative_case_reasons_no_other(),
|
||||
# [ 'Violation of land rights'
|
||||
# , 'Abusive labour practices'
|
||||
# ])
|
||||
def test_get_negative_case_reasons_no_other_2(self):
|
||||
"""Test with case having an 'other' entry"""
|
||||
case_study = CaseStudy(negative_case_reasons=['VOLR','ALAB','OTHR'])
|
||||
self.assertEqual(case_study.get_negative_case_reasons_no_other(),
|
||||
[ 'Violation of land rights'
|
||||
, 'Abusive labour practices'
|
||||
])
|
||||
|
Loading…
Reference in New Issue
Block a user