[1.10.x] Replaced use of TestCase.fail() with assertRaises().
Also removed try/except/fail antipattern that hides exceptions.
Backport of c9ae09addf
from master
This commit is contained in:
parent
9c48e17480
commit
567cfc1601
|
@ -1224,10 +1224,7 @@ class CustomModelAdminTest(AdminViewBasicTestCase):
|
||||||
self.assertContains(response, 'Hello from a custom logout template')
|
self.assertContains(response, 'Hello from a custom logout template')
|
||||||
|
|
||||||
def test_custom_admin_site_index_view_and_template(self):
|
def test_custom_admin_site_index_view_and_template(self):
|
||||||
try:
|
response = self.client.get(reverse('admin2:index'))
|
||||||
response = self.client.get(reverse('admin2:index'))
|
|
||||||
except TypeError:
|
|
||||||
self.fail('AdminSite.index_template should accept a list of template paths')
|
|
||||||
self.assertIsInstance(response, TemplateResponse)
|
self.assertIsInstance(response, TemplateResponse)
|
||||||
self.assertTemplateUsed(response, 'custom_admin/index.html')
|
self.assertTemplateUsed(response, 'custom_admin/index.html')
|
||||||
self.assertContains(response, 'Hello from a custom index template *bar*')
|
self.assertContains(response, 'Hello from a custom index template *bar*')
|
||||||
|
@ -1264,12 +1261,7 @@ class CustomModelAdminTest(AdminViewBasicTestCase):
|
||||||
def test_pwd_change_custom_template(self):
|
def test_pwd_change_custom_template(self):
|
||||||
self.client.force_login(self.superuser)
|
self.client.force_login(self.superuser)
|
||||||
su = User.objects.get(username='super')
|
su = User.objects.get(username='super')
|
||||||
try:
|
response = self.client.get(reverse('admin4:auth_user_password_change', args=(su.pk,)))
|
||||||
response = self.client.get(
|
|
||||||
reverse('admin4:auth_user_password_change', args=(su.pk,))
|
|
||||||
)
|
|
||||||
except TypeError:
|
|
||||||
self.fail('ModelAdmin.change_user_password_template should accept a list of template paths')
|
|
||||||
self.assertEqual(response.status_code, 200)
|
self.assertEqual(response.status_code, 200)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -224,10 +224,7 @@ class SilencingCheckTests(SimpleTestCase):
|
||||||
def test_silenced_error(self):
|
def test_silenced_error(self):
|
||||||
out = StringIO()
|
out = StringIO()
|
||||||
err = StringIO()
|
err = StringIO()
|
||||||
try:
|
call_command('check', stdout=out, stderr=err)
|
||||||
call_command('check', stdout=out, stderr=err)
|
|
||||||
except CommandError:
|
|
||||||
self.fail("The mycheck.E001 check should be silenced.")
|
|
||||||
self.assertEqual(out.getvalue(), 'System check identified no issues (1 silenced).\n')
|
self.assertEqual(out.getvalue(), 'System check identified no issues (1 silenced).\n')
|
||||||
self.assertEqual(err.getvalue(), '')
|
self.assertEqual(err.getvalue(), '')
|
||||||
|
|
||||||
|
@ -236,11 +233,7 @@ class SilencingCheckTests(SimpleTestCase):
|
||||||
def test_silenced_warning(self):
|
def test_silenced_warning(self):
|
||||||
out = StringIO()
|
out = StringIO()
|
||||||
err = StringIO()
|
err = StringIO()
|
||||||
try:
|
call_command('check', stdout=out, stderr=err)
|
||||||
call_command('check', stdout=out, stderr=err)
|
|
||||||
except CommandError:
|
|
||||||
self.fail("The mycheck.E001 check should be silenced.")
|
|
||||||
|
|
||||||
self.assertEqual(out.getvalue(), 'System check identified no issues (1 silenced).\n')
|
self.assertEqual(out.getvalue(), 'System check identified no issues (1 silenced).\n')
|
||||||
self.assertEqual(err.getvalue(), '')
|
self.assertEqual(err.getvalue(), '')
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@ import hashlib
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
|
import sys
|
||||||
import tempfile as sys_tempfile
|
import tempfile as sys_tempfile
|
||||||
import unittest
|
import unittest
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
@ -564,16 +565,14 @@ class DirectoryCreationTests(SimpleTestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
self.obj = FileModel()
|
self.obj = FileModel()
|
||||||
|
|
||||||
|
@unittest.skipIf(sys.platform == 'win32', "Python on Windows doesn't have working os.chmod().")
|
||||||
def test_readonly_root(self):
|
def test_readonly_root(self):
|
||||||
"""Permission errors are not swallowed"""
|
"""Permission errors are not swallowed"""
|
||||||
os.chmod(MEDIA_ROOT, 0o500)
|
os.chmod(MEDIA_ROOT, 0o500)
|
||||||
self.addCleanup(os.chmod, MEDIA_ROOT, 0o700)
|
self.addCleanup(os.chmod, MEDIA_ROOT, 0o700)
|
||||||
try:
|
with self.assertRaises(OSError) as cm:
|
||||||
self.obj.testfile.save('foo.txt', SimpleUploadedFile('foo.txt', b'x'), save=False)
|
self.obj.testfile.save('foo.txt', SimpleUploadedFile('foo.txt', b'x'), save=False)
|
||||||
except OSError as err:
|
self.assertEqual(cm.exception.errno, errno.EACCES)
|
||||||
self.assertEqual(err.errno, errno.EACCES)
|
|
||||||
except Exception:
|
|
||||||
self.fail("OSError [Errno %s] not raised." % errno.EACCES)
|
|
||||||
|
|
||||||
def test_not_a_directory(self):
|
def test_not_a_directory(self):
|
||||||
"""The correct IOError is raised when the upload directory name exists but isn't a directory"""
|
"""The correct IOError is raised when the upload directory name exists but isn't a directory"""
|
||||||
|
|
|
@ -11,7 +11,6 @@ import warnings
|
||||||
import django
|
import django
|
||||||
from django.core import management, serializers
|
from django.core import management, serializers
|
||||||
from django.core.exceptions import ImproperlyConfigured
|
from django.core.exceptions import ImproperlyConfigured
|
||||||
from django.core.management.base import CommandError
|
|
||||||
from django.core.serializers.base import DeserializationError
|
from django.core.serializers.base import DeserializationError
|
||||||
from django.db import IntegrityError, transaction
|
from django.db import IntegrityError, transaction
|
||||||
from django.db.models import signals
|
from django.db.models import signals
|
||||||
|
@ -838,15 +837,9 @@ class M2MNaturalKeyFixtureTests(TestCase):
|
||||||
A, B, C, AtoB, BtoC, CtoA = (M2MComplexCircular1A, M2MComplexCircular1B,
|
A, B, C, AtoB, BtoC, CtoA = (M2MComplexCircular1A, M2MComplexCircular1B,
|
||||||
M2MComplexCircular1C, M2MCircular1ThroughAB,
|
M2MComplexCircular1C, M2MCircular1ThroughAB,
|
||||||
M2MCircular1ThroughBC, M2MCircular1ThroughCA)
|
M2MCircular1ThroughBC, M2MCircular1ThroughCA)
|
||||||
try:
|
sorted_deps = serializers.sort_dependencies(
|
||||||
sorted_deps = serializers.sort_dependencies(
|
[('fixtures_regress', [A, B, C, AtoB, BtoC, CtoA])]
|
||||||
[('fixtures_regress', [A, B, C, AtoB, BtoC, CtoA])]
|
)
|
||||||
)
|
|
||||||
except CommandError:
|
|
||||||
self.fail("Serialization dependency solving algorithm isn't "
|
|
||||||
"capable of handling circular M2M setups with "
|
|
||||||
"intermediate models.")
|
|
||||||
|
|
||||||
# The dependency sorting should not result in an error, and the
|
# The dependency sorting should not result in an error, and the
|
||||||
# through model should have dependencies to the other models and as
|
# through model should have dependencies to the other models and as
|
||||||
# such come last in the list.
|
# such come last in the list.
|
||||||
|
@ -858,17 +851,9 @@ class M2MNaturalKeyFixtureTests(TestCase):
|
||||||
Circular M2M relations with explicit through models should be serializable
|
Circular M2M relations with explicit through models should be serializable
|
||||||
This test tests the circularity with explicit natural_key.dependencies
|
This test tests the circularity with explicit natural_key.dependencies
|
||||||
"""
|
"""
|
||||||
try:
|
sorted_deps = serializers.sort_dependencies([
|
||||||
sorted_deps = serializers.sort_dependencies([
|
('fixtures_regress', [M2MComplexCircular2A, M2MComplexCircular2B, M2MCircular2ThroughAB])
|
||||||
('fixtures_regress', [
|
])
|
||||||
M2MComplexCircular2A,
|
|
||||||
M2MComplexCircular2B,
|
|
||||||
M2MCircular2ThroughAB])
|
|
||||||
])
|
|
||||||
except CommandError:
|
|
||||||
self.fail("Serialization dependency solving algorithm isn't "
|
|
||||||
"capable of handling circular M2M setups with "
|
|
||||||
"intermediate models plus natural key dependency hints.")
|
|
||||||
self.assertEqual(sorted_deps[:2], [M2MComplexCircular2A, M2MComplexCircular2B])
|
self.assertEqual(sorted_deps[:2], [M2MComplexCircular2A, M2MComplexCircular2B])
|
||||||
self.assertEqual(sorted_deps[2:], [M2MCircular2ThroughAB])
|
self.assertEqual(sorted_deps[2:], [M2MCircular2ThroughAB])
|
||||||
|
|
||||||
|
|
|
@ -16,11 +16,9 @@ from django.utils.safestring import mark_safe
|
||||||
|
|
||||||
class AssertFormErrorsMixin(object):
|
class AssertFormErrorsMixin(object):
|
||||||
def assertFormErrors(self, expected, the_callable, *args, **kwargs):
|
def assertFormErrors(self, expected, the_callable, *args, **kwargs):
|
||||||
try:
|
with self.assertRaises(ValidationError) as cm:
|
||||||
the_callable(*args, **kwargs)
|
the_callable(*args, **kwargs)
|
||||||
self.fail("Testing the 'clean' method on %s failed to raise a ValidationError.")
|
self.assertEqual(cm.exception.messages, expected)
|
||||||
except ValidationError as e:
|
|
||||||
self.assertEqual(e.messages, expected)
|
|
||||||
|
|
||||||
|
|
||||||
class FormsErrorMessagesTestCase(SimpleTestCase, AssertFormErrorsMixin):
|
class FormsErrorMessagesTestCase(SimpleTestCase, AssertFormErrorsMixin):
|
||||||
|
|
|
@ -173,11 +173,9 @@ class FormsTestCase(SimpleTestCase):
|
||||||
self.assertFalse(p.is_bound)
|
self.assertFalse(p.is_bound)
|
||||||
self.assertEqual(p.errors, {})
|
self.assertEqual(p.errors, {})
|
||||||
self.assertFalse(p.is_valid())
|
self.assertFalse(p.is_valid())
|
||||||
try:
|
with self.assertRaises(AttributeError):
|
||||||
p.cleaned_data
|
p.cleaned_data
|
||||||
self.fail('Attempts to access cleaned_data when validation fails should fail.')
|
|
||||||
except AttributeError:
|
|
||||||
pass
|
|
||||||
self.assertHTMLEqual(
|
self.assertHTMLEqual(
|
||||||
str(p),
|
str(p),
|
||||||
"""<tr><th><label for="id_first_name">First name:</label></th><td>
|
"""<tr><th><label for="id_first_name">First name:</label></th><td>
|
||||||
|
@ -2168,11 +2166,9 @@ Password: <input type="password" name="password" required />
|
||||||
self.assertEqual(p.errors['last_name'], ['This field is required.'])
|
self.assertEqual(p.errors['last_name'], ['This field is required.'])
|
||||||
self.assertEqual(p.errors['birthday'], ['This field is required.'])
|
self.assertEqual(p.errors['birthday'], ['This field is required.'])
|
||||||
self.assertEqual(p['first_name'].errors, ['This field is required.'])
|
self.assertEqual(p['first_name'].errors, ['This field is required.'])
|
||||||
try:
|
# Accessing a nonexistent field.
|
||||||
|
with self.assertRaises(KeyError):
|
||||||
p['person1-first_name'].errors
|
p['person1-first_name'].errors
|
||||||
self.fail('Attempts to access non-existent fields should fail.')
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# In this example, the data doesn't have a prefix, but the form requires it, so
|
# In this example, the data doesn't have a prefix, but the form requires it, so
|
||||||
# the form doesn't "see" the fields.
|
# the form doesn't "see" the fields.
|
||||||
|
|
|
@ -1012,11 +1012,8 @@ class FormsFormsetTestCase(SimpleTestCase):
|
||||||
|
|
||||||
# confirm indexing of formset
|
# confirm indexing of formset
|
||||||
self.assertEqual(formset[0], forms[0])
|
self.assertEqual(formset[0], forms[0])
|
||||||
try:
|
with self.assertRaises(IndexError):
|
||||||
formset[3]
|
formset[3]
|
||||||
self.fail('Requesting an invalid formset index should raise an exception')
|
|
||||||
except IndexError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# Formsets can override the default iteration order
|
# Formsets can override the default iteration order
|
||||||
class BaseReverseFormSet(BaseFormSet):
|
class BaseReverseFormSet(BaseFormSet):
|
||||||
|
|
|
@ -115,16 +115,12 @@ class GenericRelationTests(TestCase):
|
||||||
note.save()
|
note.save()
|
||||||
|
|
||||||
def test_target_model_len_zero(self):
|
def test_target_model_len_zero(self):
|
||||||
"""Test for #13085 -- __len__() returns 0"""
|
"""
|
||||||
|
Saving a model with a GenericForeignKey to a model instance whose
|
||||||
|
__len__ method returns 0 (Team.__len__() here) shouldn't fail (#13085).
|
||||||
|
"""
|
||||||
team1 = Team.objects.create(name='Backend devs')
|
team1 = Team.objects.create(name='Backend devs')
|
||||||
try:
|
note = Note(note='Deserve a bonus', content_object=team1)
|
||||||
note = Note(note='Deserve a bonus', content_object=team1)
|
|
||||||
except Exception as e:
|
|
||||||
if (issubclass(type(e), Exception) and
|
|
||||||
str(e) == 'Impossible arguments to GFK.get_content_type!'):
|
|
||||||
self.fail("Saving model with GenericForeignKey to model instance whose "
|
|
||||||
"__len__ method returns 0 shouldn't fail.")
|
|
||||||
raise e
|
|
||||||
note.save()
|
note.save()
|
||||||
|
|
||||||
def test_target_model_nonzero_false(self):
|
def test_target_model_nonzero_false(self):
|
||||||
|
|
|
@ -78,21 +78,15 @@ class ViewTest(unittest.TestCase):
|
||||||
"""
|
"""
|
||||||
Test that a view can't be accidentally instantiated before deployment
|
Test that a view can't be accidentally instantiated before deployment
|
||||||
"""
|
"""
|
||||||
try:
|
with self.assertRaises(AttributeError):
|
||||||
SimpleView(key='value').as_view()
|
SimpleView(key='value').as_view()
|
||||||
self.fail('Should not be able to instantiate a view')
|
|
||||||
except AttributeError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def test_no_init_args(self):
|
def test_no_init_args(self):
|
||||||
"""
|
"""
|
||||||
Test that a view can't be accidentally instantiated before deployment
|
Test that a view can't be accidentally instantiated before deployment
|
||||||
"""
|
"""
|
||||||
try:
|
with self.assertRaises(TypeError):
|
||||||
SimpleView.as_view('value')
|
SimpleView.as_view('value')
|
||||||
self.fail('Should not be able to use non-keyword arguments instantiating a view')
|
|
||||||
except TypeError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def test_pathological_http_method(self):
|
def test_pathological_http_method(self):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -193,13 +193,10 @@ class GetOrCreateTestsWithManualPKs(TestCase):
|
||||||
|
|
||||||
def test_get_or_create_empty(self):
|
def test_get_or_create_empty(self):
|
||||||
"""
|
"""
|
||||||
Regression test for #16137: get_or_create does not require kwargs.
|
If all the attributes on a model have defaults, get_or_create() doesn't
|
||||||
|
require any arguments.
|
||||||
"""
|
"""
|
||||||
try:
|
DefaultPerson.objects.get_or_create()
|
||||||
DefaultPerson.objects.get_or_create()
|
|
||||||
except AssertionError:
|
|
||||||
self.fail("If all the attributes on a model have defaults, we "
|
|
||||||
"shouldn't need to pass any arguments.")
|
|
||||||
|
|
||||||
|
|
||||||
class GetOrCreateTransactionTests(TransactionTestCase):
|
class GetOrCreateTransactionTests(TransactionTestCase):
|
||||||
|
|
|
@ -80,12 +80,8 @@ class DataSourceTest(unittest.TestCase):
|
||||||
self.assertEqual(source.driver, str(ds.driver))
|
self.assertEqual(source.driver, str(ds.driver))
|
||||||
|
|
||||||
# Making sure indexing works
|
# Making sure indexing works
|
||||||
try:
|
with self.assertRaises(OGRIndexError):
|
||||||
ds[len(ds)]
|
ds[len(ds)]
|
||||||
except OGRIndexError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
self.fail('Expected an IndexError!')
|
|
||||||
|
|
||||||
def test02_invalid_shp(self):
|
def test02_invalid_shp(self):
|
||||||
"Testing invalid SHP files for the Data Source."
|
"Testing invalid SHP files for the Data Source."
|
||||||
|
|
|
@ -39,10 +39,8 @@ class EnvelopeTest(unittest.TestCase):
|
||||||
Envelope('foo')
|
Envelope('foo')
|
||||||
with self.assertRaises(GDALException):
|
with self.assertRaises(GDALException):
|
||||||
Envelope((1, 1, 0, 0))
|
Envelope((1, 1, 0, 0))
|
||||||
try:
|
# Shouldn't raise an exception for min_x == max_x or min_y == max_y
|
||||||
Envelope(0, 0, 0, 0)
|
Envelope(0, 0, 0, 0)
|
||||||
except GDALException:
|
|
||||||
self.fail("shouldn't raise an exception for min_x == max_x or min_y == max_y")
|
|
||||||
|
|
||||||
def test02_properties(self):
|
def test02_properties(self):
|
||||||
"Testing Envelope properties."
|
"Testing Envelope properties."
|
||||||
|
|
|
@ -26,10 +26,7 @@ class GeoJSONSerializerTests(TestCase):
|
||||||
|
|
||||||
def test_serialization_base(self):
|
def test_serialization_base(self):
|
||||||
geojson = serializers.serialize('geojson', City.objects.all().order_by('name'))
|
geojson = serializers.serialize('geojson', City.objects.all().order_by('name'))
|
||||||
try:
|
geodata = json.loads(geojson)
|
||||||
geodata = json.loads(geojson)
|
|
||||||
except Exception:
|
|
||||||
self.fail("Serialized output is not valid JSON")
|
|
||||||
self.assertEqual(len(geodata['features']), len(City.objects.all()))
|
self.assertEqual(len(geodata['features']), len(City.objects.all()))
|
||||||
self.assertEqual(geodata['features'][0]['geometry']['type'], 'Point')
|
self.assertEqual(geodata['features'][0]['geometry']['type'], 'Point')
|
||||||
self.assertEqual(geodata['features'][0]['properties']['name'], 'Chicago')
|
self.assertEqual(geodata['features'][0]['properties']['name'], 'Chicago')
|
||||||
|
|
|
@ -48,12 +48,8 @@ class GeoModelTest(TestCase):
|
||||||
# Making sure TypeError is thrown when trying to set with an
|
# Making sure TypeError is thrown when trying to set with an
|
||||||
# incompatible type.
|
# incompatible type.
|
||||||
for bad in [5, 2.0, LineString((0, 0), (1, 1))]:
|
for bad in [5, 2.0, LineString((0, 0), (1, 1))]:
|
||||||
try:
|
with self.assertRaisesMessage(TypeError, 'Cannot set'):
|
||||||
nullcity.point = bad
|
nullcity.point = bad
|
||||||
except TypeError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
self.fail('Should throw a TypeError')
|
|
||||||
|
|
||||||
# Now setting with a compatible GEOS Geometry, saving, and ensuring
|
# Now setting with a compatible GEOS Geometry, saving, and ensuring
|
||||||
# the save took, notice no SRID is explicitly set.
|
# the save took, notice no SRID is explicitly set.
|
||||||
|
|
|
@ -526,11 +526,8 @@ class TranslationThreadSafetyTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_bug14894_translation_activate_thread_safety(self):
|
def test_bug14894_translation_activate_thread_safety(self):
|
||||||
translation_count = len(trans_real._translations)
|
translation_count = len(trans_real._translations)
|
||||||
try:
|
# May raise RuntimeError if translation.activate() isn't thread-safe.
|
||||||
translation.activate('pl')
|
translation.activate('pl')
|
||||||
except RuntimeError:
|
|
||||||
self.fail('translation.activate() is not thread-safe')
|
|
||||||
|
|
||||||
# make sure sideeffect_str actually added a new translation
|
# make sure sideeffect_str actually added a new translation
|
||||||
self.assertLess(translation_count, len(trans_real._translations))
|
self.assertLess(translation_count, len(trans_real._translations))
|
||||||
|
|
||||||
|
|
|
@ -289,7 +289,7 @@ class ModelFormBaseTest(TestCase):
|
||||||
['name', 'slug', 'url', 'some_extra_field'])
|
['name', 'slug', 'url', 'some_extra_field'])
|
||||||
|
|
||||||
def test_extra_field_model_form(self):
|
def test_extra_field_model_form(self):
|
||||||
try:
|
with self.assertRaisesMessage(FieldError, 'no-field'):
|
||||||
class ExtraPersonForm(forms.ModelForm):
|
class ExtraPersonForm(forms.ModelForm):
|
||||||
""" ModelForm with an extra field """
|
""" ModelForm with an extra field """
|
||||||
age = forms.IntegerField()
|
age = forms.IntegerField()
|
||||||
|
@ -297,24 +297,15 @@ class ModelFormBaseTest(TestCase):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Person
|
model = Person
|
||||||
fields = ('name', 'no-field')
|
fields = ('name', 'no-field')
|
||||||
except FieldError as e:
|
|
||||||
# Make sure the exception contains some reference to the
|
|
||||||
# field responsible for the problem.
|
|
||||||
self.assertIn('no-field', e.args[0])
|
|
||||||
else:
|
|
||||||
self.fail('Invalid "no-field" field not caught')
|
|
||||||
|
|
||||||
def test_extra_declared_field_model_form(self):
|
def test_extra_declared_field_model_form(self):
|
||||||
try:
|
class ExtraPersonForm(forms.ModelForm):
|
||||||
class ExtraPersonForm(forms.ModelForm):
|
""" ModelForm with an extra field """
|
||||||
""" ModelForm with an extra field """
|
age = forms.IntegerField()
|
||||||
age = forms.IntegerField()
|
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Person
|
model = Person
|
||||||
fields = ('name', 'age')
|
fields = ('name', 'age')
|
||||||
except FieldError:
|
|
||||||
self.fail('Declarative field raised FieldError incorrectly')
|
|
||||||
|
|
||||||
def test_extra_field_modelform_factory(self):
|
def test_extra_field_modelform_factory(self):
|
||||||
with self.assertRaises(FieldError):
|
with self.assertRaises(FieldError):
|
||||||
|
|
|
@ -1104,10 +1104,7 @@ class RouterTestCase(TestCase):
|
||||||
mark = Person.objects.using('other').create(name="Mark Pilgrim")
|
mark = Person.objects.using('other').create(name="Mark Pilgrim")
|
||||||
|
|
||||||
# Set a foreign key with an object from a different database
|
# Set a foreign key with an object from a different database
|
||||||
try:
|
dive.editor = marty
|
||||||
dive.editor = marty
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments of original objects haven't changed...
|
# Database assignments of original objects haven't changed...
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1120,20 +1117,14 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(dive._state.db, 'default')
|
self.assertEqual(dive._state.db, 'default')
|
||||||
|
|
||||||
# ...and the source database now has a copy of any object saved
|
# ...and the source database now has a copy of any object saved
|
||||||
try:
|
Book.objects.using('default').get(title='Dive into Python').delete()
|
||||||
Book.objects.using('default').get(title='Dive into Python').delete()
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('Source database should have a copy of saved object')
|
|
||||||
|
|
||||||
# This isn't a real primary/replica database, so restore the original from other
|
# This isn't a real primary/replica database, so restore the original from other
|
||||||
dive = Book.objects.using('other').get(title='Dive into Python')
|
dive = Book.objects.using('other').get(title='Dive into Python')
|
||||||
self.assertEqual(dive._state.db, 'other')
|
self.assertEqual(dive._state.db, 'other')
|
||||||
|
|
||||||
# Set a foreign key set with an object from a different database
|
# Set a foreign key set with an object from a different database
|
||||||
try:
|
marty.edited.set([pro, dive], bulk=False)
|
||||||
marty.edited.set([pro, dive], bulk=False)
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Assignment implies a save, so database assignments of original objects have changed...
|
# Assignment implies a save, so database assignments of original objects have changed...
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1142,20 +1133,14 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(mark._state.db, 'other')
|
self.assertEqual(mark._state.db, 'other')
|
||||||
|
|
||||||
# ...and the source database now has a copy of any object saved
|
# ...and the source database now has a copy of any object saved
|
||||||
try:
|
Book.objects.using('default').get(title='Dive into Python').delete()
|
||||||
Book.objects.using('default').get(title='Dive into Python').delete()
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('Source database should have a copy of saved object')
|
|
||||||
|
|
||||||
# This isn't a real primary/replica database, so restore the original from other
|
# This isn't a real primary/replica database, so restore the original from other
|
||||||
dive = Book.objects.using('other').get(title='Dive into Python')
|
dive = Book.objects.using('other').get(title='Dive into Python')
|
||||||
self.assertEqual(dive._state.db, 'other')
|
self.assertEqual(dive._state.db, 'other')
|
||||||
|
|
||||||
# Add to a foreign key set with an object from a different database
|
# Add to a foreign key set with an object from a different database
|
||||||
try:
|
marty.edited.add(dive, bulk=False)
|
||||||
marty.edited.add(dive, bulk=False)
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Add implies a save, so database assignments of original objects have changed...
|
# Add implies a save, so database assignments of original objects have changed...
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1164,10 +1149,7 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(mark._state.db, 'other')
|
self.assertEqual(mark._state.db, 'other')
|
||||||
|
|
||||||
# ...and the source database now has a copy of any object saved
|
# ...and the source database now has a copy of any object saved
|
||||||
try:
|
Book.objects.using('default').get(title='Dive into Python').delete()
|
||||||
Book.objects.using('default').get(title='Dive into Python').delete()
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('Source database should have a copy of saved object')
|
|
||||||
|
|
||||||
# This isn't a real primary/replica database, so restore the original from other
|
# This isn't a real primary/replica database, so restore the original from other
|
||||||
dive = Book.objects.using('other').get(title='Dive into Python')
|
dive = Book.objects.using('other').get(title='Dive into Python')
|
||||||
|
@ -1250,10 +1232,7 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(Person.objects.using('other').count(), 2)
|
self.assertEqual(Person.objects.using('other').count(), 2)
|
||||||
|
|
||||||
# Set a m2m set with an object from a different database
|
# Set a m2m set with an object from a different database
|
||||||
try:
|
marty.book_set.set([pro, dive])
|
||||||
marty.book_set.set([pro, dive])
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments don't change
|
# Database assignments don't change
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1269,10 +1248,7 @@ class RouterTestCase(TestCase):
|
||||||
Book.authors.through.objects.using('default').delete()
|
Book.authors.through.objects.using('default').delete()
|
||||||
|
|
||||||
# Add to an m2m with an object from a different database
|
# Add to an m2m with an object from a different database
|
||||||
try:
|
marty.book_set.add(dive)
|
||||||
marty.book_set.add(dive)
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments don't change
|
# Database assignments don't change
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1288,10 +1264,7 @@ class RouterTestCase(TestCase):
|
||||||
Book.authors.through.objects.using('default').delete()
|
Book.authors.through.objects.using('default').delete()
|
||||||
|
|
||||||
# Set a reverse m2m with an object from a different database
|
# Set a reverse m2m with an object from a different database
|
||||||
try:
|
dive.authors.set([mark, marty])
|
||||||
dive.authors.set([mark, marty])
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments don't change
|
# Database assignments don't change
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1310,10 +1283,7 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(Book.authors.through.objects.using('other').count(), 0)
|
self.assertEqual(Book.authors.through.objects.using('other').count(), 0)
|
||||||
|
|
||||||
# Add to a reverse m2m with an object from a different database
|
# Add to a reverse m2m with an object from a different database
|
||||||
try:
|
dive.authors.add(marty)
|
||||||
dive.authors.add(marty)
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments don't change
|
# Database assignments don't change
|
||||||
self.assertEqual(marty._state.db, 'default')
|
self.assertEqual(marty._state.db, 'default')
|
||||||
|
@ -1348,10 +1318,7 @@ class RouterTestCase(TestCase):
|
||||||
|
|
||||||
# Set a one-to-one relation with an object from a different database
|
# Set a one-to-one relation with an object from a different database
|
||||||
alice_profile = UserProfile.objects.create(user=alice, flavor='chocolate')
|
alice_profile = UserProfile.objects.create(user=alice, flavor='chocolate')
|
||||||
try:
|
bob.userprofile = alice_profile
|
||||||
bob.userprofile = alice_profile
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments of original objects haven't changed...
|
# Database assignments of original objects haven't changed...
|
||||||
self.assertEqual(alice._state.db, 'default')
|
self.assertEqual(alice._state.db, 'default')
|
||||||
|
@ -1379,10 +1346,7 @@ class RouterTestCase(TestCase):
|
||||||
'other').create(source="Python Weekly", content_object=dive)
|
'other').create(source="Python Weekly", content_object=dive)
|
||||||
|
|
||||||
# Set a generic foreign key with an object from a different database
|
# Set a generic foreign key with an object from a different database
|
||||||
try:
|
review1.content_object = dive
|
||||||
review1.content_object = dive
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments of original objects haven't changed...
|
# Database assignments of original objects haven't changed...
|
||||||
self.assertEqual(pro._state.db, 'default')
|
self.assertEqual(pro._state.db, 'default')
|
||||||
|
@ -1396,20 +1360,14 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(dive._state.db, 'default')
|
self.assertEqual(dive._state.db, 'default')
|
||||||
|
|
||||||
# ...and the source database now has a copy of any object saved
|
# ...and the source database now has a copy of any object saved
|
||||||
try:
|
Book.objects.using('default').get(title='Dive into Python').delete()
|
||||||
Book.objects.using('default').get(title='Dive into Python').delete()
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('Source database should have a copy of saved object')
|
|
||||||
|
|
||||||
# This isn't a real primary/replica database, so restore the original from other
|
# This isn't a real primary/replica database, so restore the original from other
|
||||||
dive = Book.objects.using('other').get(title='Dive into Python')
|
dive = Book.objects.using('other').get(title='Dive into Python')
|
||||||
self.assertEqual(dive._state.db, 'other')
|
self.assertEqual(dive._state.db, 'other')
|
||||||
|
|
||||||
# Add to a generic foreign key set with an object from a different database
|
# Add to a generic foreign key set with an object from a different database
|
||||||
try:
|
dive.reviews.add(review1)
|
||||||
dive.reviews.add(review1)
|
|
||||||
except ValueError:
|
|
||||||
self.fail("Assignment across primary/replica databases with a common source should be ok")
|
|
||||||
|
|
||||||
# Database assignments of original objects haven't changed...
|
# Database assignments of original objects haven't changed...
|
||||||
self.assertEqual(pro._state.db, 'default')
|
self.assertEqual(pro._state.db, 'default')
|
||||||
|
@ -1422,10 +1380,7 @@ class RouterTestCase(TestCase):
|
||||||
self.assertEqual(dive._state.db, 'default')
|
self.assertEqual(dive._state.db, 'default')
|
||||||
|
|
||||||
# ...and the source database now has a copy of any object saved
|
# ...and the source database now has a copy of any object saved
|
||||||
try:
|
Book.objects.using('default').get(title='Dive into Python').delete()
|
||||||
Book.objects.using('default').get(title='Dive into Python').delete()
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('Source database should have a copy of saved object')
|
|
||||||
|
|
||||||
# BUT! if you assign a FK object when the base object hasn't
|
# BUT! if you assign a FK object when the base object hasn't
|
||||||
# been saved yet, you implicitly assign the database for the
|
# been saved yet, you implicitly assign the database for the
|
||||||
|
@ -1590,20 +1545,14 @@ class FixtureTestCase(TestCase):
|
||||||
def test_fixture_loading(self):
|
def test_fixture_loading(self):
|
||||||
"Multi-db fixtures are loaded correctly"
|
"Multi-db fixtures are loaded correctly"
|
||||||
# Check that "Pro Django" exists on the default database, but not on other database
|
# Check that "Pro Django" exists on the default database, but not on other database
|
||||||
try:
|
Book.objects.get(title="Pro Django")
|
||||||
Book.objects.get(title="Pro Django")
|
Book.objects.using('default').get(title="Pro Django")
|
||||||
Book.objects.using('default').get(title="Pro Django")
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('"Pro Django" should exist on default database')
|
|
||||||
|
|
||||||
with self.assertRaises(Book.DoesNotExist):
|
with self.assertRaises(Book.DoesNotExist):
|
||||||
Book.objects.using('other').get(title="Pro Django")
|
Book.objects.using('other').get(title="Pro Django")
|
||||||
|
|
||||||
# Check that "Dive into Python" exists on the default database, but not on other database
|
# Check that "Dive into Python" exists on the default database, but not on other database
|
||||||
try:
|
Book.objects.using('other').get(title="Dive into Python")
|
||||||
Book.objects.using('other').get(title="Dive into Python")
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('"Dive into Python" should exist on other database')
|
|
||||||
|
|
||||||
with self.assertRaises(Book.DoesNotExist):
|
with self.assertRaises(Book.DoesNotExist):
|
||||||
Book.objects.get(title="Dive into Python")
|
Book.objects.get(title="Dive into Python")
|
||||||
|
@ -1611,12 +1560,9 @@ class FixtureTestCase(TestCase):
|
||||||
Book.objects.using('default').get(title="Dive into Python")
|
Book.objects.using('default').get(title="Dive into Python")
|
||||||
|
|
||||||
# Check that "Definitive Guide" exists on the both databases
|
# Check that "Definitive Guide" exists on the both databases
|
||||||
try:
|
Book.objects.get(title="The Definitive Guide to Django")
|
||||||
Book.objects.get(title="The Definitive Guide to Django")
|
Book.objects.using('default').get(title="The Definitive Guide to Django")
|
||||||
Book.objects.using('default').get(title="The Definitive Guide to Django")
|
Book.objects.using('other').get(title="The Definitive Guide to Django")
|
||||||
Book.objects.using('other').get(title="The Definitive Guide to Django")
|
|
||||||
except Book.DoesNotExist:
|
|
||||||
self.fail('"The Definitive Guide to Django" should exist on both databases')
|
|
||||||
|
|
||||||
@override_settings(DATABASE_ROUTERS=[AntiPetRouter()])
|
@override_settings(DATABASE_ROUTERS=[AntiPetRouter()])
|
||||||
def test_pseudo_empty_fixtures(self):
|
def test_pseudo_empty_fixtures(self):
|
||||||
|
@ -1895,210 +1841,194 @@ class RouteForWriteTestCase(TestCase):
|
||||||
def test_fk_delete(self):
|
def test_fk_delete(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
pet = Pet.objects.create(name='fido', owner=owner)
|
pet = Pet.objects.create(name='fido', owner=owner)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
pet.owner.delete()
|
pet.owner.delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Person)
|
||||||
self.assertEqual(e.model, Person)
|
self.assertEqual(e.hints, {'instance': owner})
|
||||||
self.assertEqual(e.hints, {'instance': owner})
|
|
||||||
|
|
||||||
def test_reverse_fk_delete(self):
|
def test_reverse_fk_delete(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
to_del_qs = owner.pet_set.all()
|
to_del_qs = owner.pet_set.all()
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
to_del_qs.delete()
|
to_del_qs.delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Pet)
|
||||||
self.assertEqual(e.model, Pet)
|
self.assertEqual(e.hints, {'instance': owner})
|
||||||
self.assertEqual(e.hints, {'instance': owner})
|
|
||||||
|
|
||||||
def test_reverse_fk_get_or_create(self):
|
def test_reverse_fk_get_or_create(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
owner.pet_set.get_or_create(name='fido')
|
owner.pet_set.get_or_create(name='fido')
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Pet)
|
||||||
self.assertEqual(e.model, Pet)
|
self.assertEqual(e.hints, {'instance': owner})
|
||||||
self.assertEqual(e.hints, {'instance': owner})
|
|
||||||
|
|
||||||
def test_reverse_fk_update(self):
|
def test_reverse_fk_update(self):
|
||||||
owner = Person.objects.create(name='Someone')
|
owner = Person.objects.create(name='Someone')
|
||||||
Pet.objects.create(name='fido', owner=owner)
|
Pet.objects.create(name='fido', owner=owner)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
owner.pet_set.update(name='max')
|
owner.pet_set.update(name='max')
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Pet)
|
||||||
self.assertEqual(e.model, Pet)
|
self.assertEqual(e.hints, {'instance': owner})
|
||||||
self.assertEqual(e.hints, {'instance': owner})
|
|
||||||
|
|
||||||
def test_m2m_add(self):
|
def test_m2m_add(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_m2m_clear(self):
|
def test_m2m_clear(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.clear()
|
book.authors.clear()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_m2m_delete(self):
|
def test_m2m_delete(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.all().delete()
|
book.authors.all().delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Person)
|
||||||
self.assertEqual(e.model, Person)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_m2m_get_or_create(self):
|
def test_m2m_get_or_create(self):
|
||||||
Person.objects.create(name='Someone')
|
Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.get_or_create(name='Someone else')
|
book.authors.get_or_create(name='Someone else')
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book)
|
||||||
self.assertEqual(e.model, Book)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_m2m_remove(self):
|
def test_m2m_remove(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.remove(auth)
|
book.authors.remove(auth)
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_m2m_update(self):
|
def test_m2m_update(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
book.authors.all().update(name='Different')
|
book.authors.all().update(name='Different')
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Person)
|
||||||
self.assertEqual(e.model, Person)
|
self.assertEqual(e.hints, {'instance': book})
|
||||||
self.assertEqual(e.hints, {'instance': book})
|
|
||||||
|
|
||||||
def test_reverse_m2m_add(self):
|
def test_reverse_m2m_add(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.add(book)
|
auth.book_set.add(book)
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
||||||
def test_reverse_m2m_clear(self):
|
def test_reverse_m2m_clear(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.clear()
|
auth.book_set.clear()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
||||||
def test_reverse_m2m_delete(self):
|
def test_reverse_m2m_delete(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.all().delete()
|
auth.book_set.all().delete()
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book)
|
||||||
self.assertEqual(e.model, Book)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
||||||
def test_reverse_m2m_get_or_create(self):
|
def test_reverse_m2m_get_or_create(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
Book.objects.create(title="Pro Django",
|
Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.get_or_create(title="New Book", published=datetime.datetime.now())
|
auth.book_set.get_or_create(title="New Book", published=datetime.datetime.now())
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Person)
|
||||||
self.assertEqual(e.model, Person)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
||||||
def test_reverse_m2m_remove(self):
|
def test_reverse_m2m_remove(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.remove(book)
|
auth.book_set.remove(book)
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book.authors.through)
|
||||||
self.assertEqual(e.model, Book.authors.through)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
||||||
def test_reverse_m2m_update(self):
|
def test_reverse_m2m_update(self):
|
||||||
auth = Person.objects.create(name='Someone')
|
auth = Person.objects.create(name='Someone')
|
||||||
book = Book.objects.create(title="Pro Django",
|
book = Book.objects.create(title="Pro Django",
|
||||||
published=datetime.date(2008, 12, 16))
|
published=datetime.date(2008, 12, 16))
|
||||||
book.authors.add(auth)
|
book.authors.add(auth)
|
||||||
try:
|
with self.assertRaises(RouterUsed) as cm:
|
||||||
with self.override_router():
|
with self.override_router():
|
||||||
auth.book_set.all().update(title='Different')
|
auth.book_set.all().update(title='Different')
|
||||||
self.fail('db_for_write() not invoked on router')
|
e = cm.exception
|
||||||
except RouterUsed as e:
|
self.assertEqual(e.mode, RouterUsed.WRITE)
|
||||||
self.assertEqual(e.mode, RouterUsed.WRITE)
|
self.assertEqual(e.model, Book)
|
||||||
self.assertEqual(e.model, Book)
|
self.assertEqual(e.hints, {'instance': auth})
|
||||||
self.assertEqual(e.hints, {'instance': auth})
|
|
||||||
|
|
|
@ -188,10 +188,7 @@ class ProxyModelTests(TestCase):
|
||||||
|
|
||||||
def test_permissions_created(self):
|
def test_permissions_created(self):
|
||||||
from django.contrib.auth.models import Permission
|
from django.contrib.auth.models import Permission
|
||||||
try:
|
Permission.objects.get(name="May display users information")
|
||||||
Permission.objects.get(name="May display users information")
|
|
||||||
except Permission.DoesNotExist:
|
|
||||||
self.fail("The permission 'May display users information' has not been created")
|
|
||||||
|
|
||||||
def test_proxy_model_signals(self):
|
def test_proxy_model_signals(self):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -2621,14 +2621,10 @@ class UnionTests(unittest.TestCase):
|
||||||
|
|
||||||
class DefaultValuesInsertTest(TestCase):
|
class DefaultValuesInsertTest(TestCase):
|
||||||
def test_no_extra_params(self):
|
def test_no_extra_params(self):
|
||||||
# Ticket #17056 -- affects Oracle
|
"""
|
||||||
try:
|
Can create an instance of a model with only the PK field (#17056)."
|
||||||
DumbCategory.objects.create()
|
"""
|
||||||
except TypeError:
|
DumbCategory.objects.create()
|
||||||
self.fail(
|
|
||||||
"Creation of an instance of a model with only the PK field "
|
|
||||||
"shouldn't error out after bulk insert refactoring (#17056)"
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class ExcludeTests(TestCase):
|
class ExcludeTests(TestCase):
|
||||||
|
|
|
@ -221,11 +221,8 @@ class RawQueryTests(TestCase):
|
||||||
|
|
||||||
def test_missing_fields_without_PK(self):
|
def test_missing_fields_without_PK(self):
|
||||||
query = "SELECT first_name, dob FROM raw_query_author"
|
query = "SELECT first_name, dob FROM raw_query_author"
|
||||||
try:
|
with self.assertRaisesMessage(InvalidQuery, 'Raw query must include the primary key'):
|
||||||
list(Author.objects.raw(query))
|
list(Author.objects.raw(query))
|
||||||
self.fail('Query without primary key should fail')
|
|
||||||
except InvalidQuery:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def test_annotations(self):
|
def test_annotations(self):
|
||||||
query = (
|
query = (
|
||||||
|
@ -290,10 +287,7 @@ class RawQueryTests(TestCase):
|
||||||
self.assertNumQueries(1, list, Author.objects.raw("SELECT * FROM raw_query_author"))
|
self.assertNumQueries(1, list, Author.objects.raw("SELECT * FROM raw_query_author"))
|
||||||
|
|
||||||
def test_subquery_in_raw_sql(self):
|
def test_subquery_in_raw_sql(self):
|
||||||
try:
|
list(Book.objects.raw('SELECT id FROM (SELECT * FROM raw_query_book WHERE paperback IS NOT NULL) sq'))
|
||||||
list(Book.objects.raw('SELECT id FROM (SELECT * FROM raw_query_book WHERE paperback IS NOT NULL) sq'))
|
|
||||||
except InvalidQuery:
|
|
||||||
self.fail("Using a subquery in a RawQuerySet raised InvalidQuery")
|
|
||||||
|
|
||||||
def test_db_column_name_is_used_in_raw_query(self):
|
def test_db_column_name_is_used_in_raw_query(self):
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -198,13 +198,7 @@ class SessionTestsMixin(object):
|
||||||
# removed the key) results in a new key being generated.
|
# removed the key) results in a new key being generated.
|
||||||
try:
|
try:
|
||||||
session = self.backend('1')
|
session = self.backend('1')
|
||||||
try:
|
session.save()
|
||||||
session.save()
|
|
||||||
except AttributeError:
|
|
||||||
self.fail(
|
|
||||||
"The session object did not save properly. "
|
|
||||||
"Middleware may be saving cache items without namespaces."
|
|
||||||
)
|
|
||||||
self.assertNotEqual(session.session_key, '1')
|
self.assertNotEqual(session.session_key, '1')
|
||||||
self.assertIsNone(session.get('cat'))
|
self.assertIsNone(session.get('cat'))
|
||||||
session.delete()
|
session.delete()
|
||||||
|
|
|
@ -127,10 +127,7 @@ class ClassDecoratedTestCase(ClassDecoratedTestCaseSuper):
|
||||||
Overriding a method on a super class and then calling that method on
|
Overriding a method on a super class and then calling that method on
|
||||||
the super class should not trigger infinite recursion. See #17011.
|
the super class should not trigger infinite recursion. See #17011.
|
||||||
"""
|
"""
|
||||||
try:
|
super(ClassDecoratedTestCase, self).test_max_recursion_error()
|
||||||
super(ClassDecoratedTestCase, self).test_max_recursion_error()
|
|
||||||
except RuntimeError:
|
|
||||||
self.fail()
|
|
||||||
|
|
||||||
|
|
||||||
@modify_settings(ITEMS={'append': 'mother'})
|
@modify_settings(ITEMS={'append': 'mother'})
|
||||||
|
|
|
@ -44,9 +44,5 @@ class SwappableModelTests(TestCase):
|
||||||
@override_settings(TEST_ARTICLE_MODEL='swappable_models.article')
|
@override_settings(TEST_ARTICLE_MODEL='swappable_models.article')
|
||||||
def test_case_insensitive(self):
|
def test_case_insensitive(self):
|
||||||
"Model names are case insensitive. Check that model swapping honors this."
|
"Model names are case insensitive. Check that model swapping honors this."
|
||||||
try:
|
Article.objects.all()
|
||||||
Article.objects.all()
|
|
||||||
except AttributeError:
|
|
||||||
self.fail('Swappable model names should be case insensitive.')
|
|
||||||
|
|
||||||
self.assertIsNone(Article._meta.swapped)
|
self.assertIsNone(Article._meta.swapped)
|
||||||
|
|
|
@ -598,14 +598,10 @@ class ClientTest(TestCase):
|
||||||
def test_session_modifying_view(self):
|
def test_session_modifying_view(self):
|
||||||
"Request a page that modifies the session"
|
"Request a page that modifies the session"
|
||||||
# Session value isn't set initially
|
# Session value isn't set initially
|
||||||
try:
|
with self.assertRaises(KeyError):
|
||||||
self.client.session['tobacconist']
|
self.client.session['tobacconist']
|
||||||
self.fail("Shouldn't have a session value")
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
self.client.post('/session_view/')
|
self.client.post('/session_view/')
|
||||||
|
|
||||||
# Check that the session was modified
|
# Check that the session was modified
|
||||||
self.assertEqual(self.client.session['tobacconist'], 'hovercraft')
|
self.assertEqual(self.client.session['tobacconist'], 'hovercraft')
|
||||||
|
|
||||||
|
@ -629,13 +625,6 @@ class ClientTest(TestCase):
|
||||||
with self.assertRaises(KeyError):
|
with self.assertRaises(KeyError):
|
||||||
self.client.get("/broken_view/")
|
self.client.get("/broken_view/")
|
||||||
|
|
||||||
# Try the same assertion, a different way
|
|
||||||
try:
|
|
||||||
self.client.get('/broken_view/')
|
|
||||||
self.fail('Should raise an error')
|
|
||||||
except KeyError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def test_mail_sending(self):
|
def test_mail_sending(self):
|
||||||
"Test that mail is redirected to a dummy outbox during test setup"
|
"Test that mail is redirected to a dummy outbox during test setup"
|
||||||
|
|
||||||
|
|
|
@ -867,21 +867,15 @@ class ExceptionTests(TestDataMixin, TestCase):
|
||||||
|
|
||||||
login = self.client.login(username='testclient', password='password')
|
login = self.client.login(username='testclient', password='password')
|
||||||
self.assertTrue(login, 'Could not log in')
|
self.assertTrue(login, 'Could not log in')
|
||||||
try:
|
with self.assertRaises(CustomTestException):
|
||||||
self.client.get("/staff_only/")
|
self.client.get("/staff_only/")
|
||||||
self.fail("General users should not be able to visit this page")
|
|
||||||
except CustomTestException:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# At this point, an exception has been raised, and should be cleared.
|
# At this point, an exception has been raised, and should be cleared.
|
||||||
|
|
||||||
# This next operation should be successful; if it isn't we have a problem.
|
# This next operation should be successful; if it isn't we have a problem.
|
||||||
login = self.client.login(username='staff', password='password')
|
login = self.client.login(username='staff', password='password')
|
||||||
self.assertTrue(login, 'Could not log in')
|
self.assertTrue(login, 'Could not log in')
|
||||||
try:
|
self.client.get("/staff_only/")
|
||||||
self.client.get("/staff_only/")
|
|
||||||
except CustomTestException:
|
|
||||||
self.fail("Staff should be able to visit this page")
|
|
||||||
|
|
||||||
|
|
||||||
@override_settings(ROOT_URLCONF='test_client_regress.urls')
|
@override_settings(ROOT_URLCONF='test_client_regress.urls')
|
||||||
|
@ -893,12 +887,8 @@ class TemplateExceptionTests(SimpleTestCase):
|
||||||
}])
|
}])
|
||||||
def test_bad_404_template(self):
|
def test_bad_404_template(self):
|
||||||
"Errors found when rendering 404 error templates are re-raised"
|
"Errors found when rendering 404 error templates are re-raised"
|
||||||
try:
|
with self.assertRaises(TemplateSyntaxError):
|
||||||
self.client.get("/no_such_view/")
|
self.client.get("/no_such_view/")
|
||||||
except TemplateSyntaxError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
self.fail("Should get error about syntax error in template")
|
|
||||||
|
|
||||||
|
|
||||||
# We need two different tests to check URLconf substitution - one to check
|
# We need two different tests to check URLconf substitution - one to check
|
||||||
|
@ -937,11 +927,8 @@ class ContextTests(TestDataMixin, TestCase):
|
||||||
self.assertEqual(response.context['get-foo'], 'whiz')
|
self.assertEqual(response.context['get-foo'], 'whiz')
|
||||||
self.assertEqual(response.context['data'], 'sausage')
|
self.assertEqual(response.context['data'], 'sausage')
|
||||||
|
|
||||||
try:
|
with self.assertRaisesMessage(KeyError, 'does-not-exist'):
|
||||||
response.context['does-not-exist']
|
response.context['does-not-exist']
|
||||||
self.fail('Should not be able to retrieve non-existent key')
|
|
||||||
except KeyError as e:
|
|
||||||
self.assertEqual(e.args[0], 'does-not-exist')
|
|
||||||
|
|
||||||
def test_inherited_context(self):
|
def test_inherited_context(self):
|
||||||
"Context variables can be retrieved from a list of contexts"
|
"Context variables can be retrieved from a list of contexts"
|
||||||
|
|
|
@ -240,12 +240,8 @@ class DummyBackendTest(unittest.TestCase):
|
||||||
tested_connections = db.ConnectionHandler({})
|
tested_connections = db.ConnectionHandler({})
|
||||||
with mock.patch('django.test.runner.connections', new=tested_connections):
|
with mock.patch('django.test.runner.connections', new=tested_connections):
|
||||||
runner_instance = DiscoverRunner(verbosity=0)
|
runner_instance = DiscoverRunner(verbosity=0)
|
||||||
try:
|
old_config = runner_instance.setup_databases()
|
||||||
old_config = runner_instance.setup_databases()
|
runner_instance.teardown_databases(old_config)
|
||||||
runner_instance.teardown_databases(old_config)
|
|
||||||
except Exception as e:
|
|
||||||
self.fail("setup_databases/teardown_databases unexpectedly raised "
|
|
||||||
"an error: %s" % e)
|
|
||||||
|
|
||||||
|
|
||||||
class AliasedDefaultTestSetupTest(unittest.TestCase):
|
class AliasedDefaultTestSetupTest(unittest.TestCase):
|
||||||
|
@ -263,12 +259,8 @@ class AliasedDefaultTestSetupTest(unittest.TestCase):
|
||||||
})
|
})
|
||||||
with mock.patch('django.test.runner.connections', new=tested_connections):
|
with mock.patch('django.test.runner.connections', new=tested_connections):
|
||||||
runner_instance = DiscoverRunner(verbosity=0)
|
runner_instance = DiscoverRunner(verbosity=0)
|
||||||
try:
|
old_config = runner_instance.setup_databases()
|
||||||
old_config = runner_instance.setup_databases()
|
runner_instance.teardown_databases(old_config)
|
||||||
runner_instance.teardown_databases(old_config)
|
|
||||||
except Exception as e:
|
|
||||||
self.fail("setup_databases/teardown_databases unexpectedly raised "
|
|
||||||
"an error: %s" % e)
|
|
||||||
|
|
||||||
|
|
||||||
class SetupDatabasesTests(unittest.TestCase):
|
class SetupDatabasesTests(unittest.TestCase):
|
||||||
|
@ -366,7 +358,4 @@ class EmptyDefaultDatabaseTest(unittest.TestCase):
|
||||||
testcases.connections = db.ConnectionHandler({'default': {}})
|
testcases.connections = db.ConnectionHandler({'default': {}})
|
||||||
connection = testcases.connections[db.utils.DEFAULT_DB_ALIAS]
|
connection = testcases.connections[db.utils.DEFAULT_DB_ALIAS]
|
||||||
self.assertEqual(connection.settings_dict['ENGINE'], 'django.db.backends.dummy')
|
self.assertEqual(connection.settings_dict['ENGINE'], 'django.db.backends.dummy')
|
||||||
try:
|
connections_support_transactions()
|
||||||
connections_support_transactions()
|
|
||||||
except Exception as e:
|
|
||||||
self.fail("connections_support_transactions() unexpectedly raised an error: %s" % e)
|
|
||||||
|
|
|
@ -5,7 +5,6 @@ Unit tests for reverse URL lookups.
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import sys
|
import sys
|
||||||
import unittest
|
|
||||||
|
|
||||||
from admin_scripts.tests import AdminScriptTestCase
|
from admin_scripts.tests import AdminScriptTestCase
|
||||||
|
|
||||||
|
@ -313,16 +312,9 @@ class URLPatternReverse(SimpleTestCase):
|
||||||
|
|
||||||
def test_patterns_reported(self):
|
def test_patterns_reported(self):
|
||||||
# Regression for #17076
|
# Regression for #17076
|
||||||
try:
|
with self.assertRaisesMessage(NoReverseMatch, r"1 pattern(s) tried: ['people/(?P<name>\\w+)/$']"):
|
||||||
# this url exists, but requires an argument
|
# this url exists, but requires an argument
|
||||||
reverse("people", args=[])
|
reverse("people", args=[])
|
||||||
except NoReverseMatch as e:
|
|
||||||
pattern_description = r"1 pattern(s) tried: ['people/(?P<name>\\w+)/$']"
|
|
||||||
self.assertIn(pattern_description, str(e))
|
|
||||||
else:
|
|
||||||
# we can't use .assertRaises, since we want to inspect the
|
|
||||||
# exception
|
|
||||||
self.fail("Expected a NoReverseMatch, but none occurred.")
|
|
||||||
|
|
||||||
@override_script_prefix('/script:name/')
|
@override_script_prefix('/script:name/')
|
||||||
def test_script_name_escaping(self):
|
def test_script_name_escaping(self):
|
||||||
|
@ -339,7 +331,7 @@ class URLPatternReverse(SimpleTestCase):
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class ResolverTests(unittest.TestCase):
|
class ResolverTests(SimpleTestCase):
|
||||||
@ignore_warnings(category=RemovedInDjango20Warning)
|
@ignore_warnings(category=RemovedInDjango20Warning)
|
||||||
def test_resolver_repr(self):
|
def test_resolver_repr(self):
|
||||||
"""
|
"""
|
||||||
|
@ -359,10 +351,7 @@ class ResolverTests(unittest.TestCase):
|
||||||
urls = 'urlpatterns_reverse.named_urls'
|
urls = 'urlpatterns_reverse.named_urls'
|
||||||
proxy_url = reverse_lazy('named-url1', urlconf=urls)
|
proxy_url = reverse_lazy('named-url1', urlconf=urls)
|
||||||
resolver = get_resolver(urls)
|
resolver = get_resolver(urls)
|
||||||
try:
|
resolver.resolve(proxy_url)
|
||||||
resolver.resolve(proxy_url)
|
|
||||||
except TypeError:
|
|
||||||
self.fail('Failed to coerce lazy object to text')
|
|
||||||
|
|
||||||
def test_resolver_reverse(self):
|
def test_resolver_reverse(self):
|
||||||
resolver = get_resolver('urlpatterns_reverse.named_urls')
|
resolver = get_resolver('urlpatterns_reverse.named_urls')
|
||||||
|
@ -407,32 +396,31 @@ class ResolverTests(unittest.TestCase):
|
||||||
[{'type': RegexURLResolver}, {'type': RegexURLPattern, 'name': None}],
|
[{'type': RegexURLResolver}, {'type': RegexURLPattern, 'name': None}],
|
||||||
[{'type': RegexURLResolver}, {'type': RegexURLResolver}],
|
[{'type': RegexURLResolver}, {'type': RegexURLResolver}],
|
||||||
]
|
]
|
||||||
try:
|
with self.assertRaisesMessage(Resolver404, b'tried' if six.PY2 else 'tried') as cm:
|
||||||
resolve('/included/non-existent-url', urlconf=urls)
|
resolve('/included/non-existent-url', urlconf=urls)
|
||||||
self.fail('resolve did not raise a 404')
|
e = cm.exception
|
||||||
except Resolver404 as e:
|
# make sure we at least matched the root ('/') url resolver:
|
||||||
# make sure we at least matched the root ('/') url resolver:
|
self.assertIn('tried', e.args[0])
|
||||||
self.assertIn('tried', e.args[0])
|
tried = e.args[0]['tried']
|
||||||
tried = e.args[0]['tried']
|
self.assertEqual(
|
||||||
self.assertEqual(
|
len(e.args[0]['tried']),
|
||||||
len(e.args[0]['tried']),
|
len(url_types_names),
|
||||||
len(url_types_names),
|
'Wrong number of tried URLs returned. Expected %s, got %s.' % (
|
||||||
'Wrong number of tried URLs returned. Expected %s, got %s.' % (
|
len(url_types_names), len(e.args[0]['tried'])
|
||||||
len(url_types_names), len(e.args[0]['tried'])
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
for tried, expected in zip(e.args[0]['tried'], url_types_names):
|
)
|
||||||
for t, e in zip(tried, expected):
|
for tried, expected in zip(e.args[0]['tried'], url_types_names):
|
||||||
self.assertIsInstance(t, e['type']), str('%s is not an instance of %s') % (t, e['type'])
|
for t, e in zip(tried, expected):
|
||||||
if 'name' in e:
|
self.assertIsInstance(t, e['type']), str('%s is not an instance of %s') % (t, e['type'])
|
||||||
if not e['name']:
|
if 'name' in e:
|
||||||
self.assertIsNone(t.name, 'Expected no URL name but found %s.' % t.name)
|
if not e['name']:
|
||||||
else:
|
self.assertIsNone(t.name, 'Expected no URL name but found %s.' % t.name)
|
||||||
self.assertEqual(
|
else:
|
||||||
t.name,
|
self.assertEqual(
|
||||||
e['name'],
|
t.name,
|
||||||
'Wrong URL name. Expected "%s", got "%s".' % (e['name'], t.name)
|
e['name'],
|
||||||
)
|
'Wrong URL name. Expected "%s", got "%s".' % (e['name'], t.name)
|
||||||
|
)
|
||||||
|
|
||||||
def test_namespaced_view_detail(self):
|
def test_namespaced_view_detail(self):
|
||||||
resolver = get_resolver('urlpatterns_reverse.nested_urls')
|
resolver = get_resolver('urlpatterns_reverse.nested_urls')
|
||||||
|
@ -918,17 +906,11 @@ class DefaultErrorHandlerTests(SimpleTestCase):
|
||||||
|
|
||||||
def test_default_handler(self):
|
def test_default_handler(self):
|
||||||
"If the urls.py doesn't specify handlers, the defaults are used"
|
"If the urls.py doesn't specify handlers, the defaults are used"
|
||||||
try:
|
response = self.client.get('/test/')
|
||||||
response = self.client.get('/test/')
|
self.assertEqual(response.status_code, 404)
|
||||||
self.assertEqual(response.status_code, 404)
|
|
||||||
except AttributeError:
|
|
||||||
self.fail("Shouldn't get an AttributeError due to undefined 404 handler")
|
|
||||||
|
|
||||||
try:
|
with self.assertRaisesMessage(ValueError, "I don't think I'm getting good"):
|
||||||
with self.assertRaises(ValueError):
|
self.client.get('/bad_view/')
|
||||||
self.client.get('/bad_view/')
|
|
||||||
except AttributeError:
|
|
||||||
self.fail("Shouldn't get an AttributeError due to undefined 500 handler")
|
|
||||||
|
|
||||||
|
|
||||||
@override_settings(ROOT_URLCONF=None)
|
@override_settings(ROOT_URLCONF=None)
|
||||||
|
|
|
@ -144,27 +144,22 @@ class PerformUniqueChecksTest(TestCase):
|
||||||
self.assertEqual(cm.exception.message_dict, {'posted': ['This field cannot be null.']})
|
self.assertEqual(cm.exception.message_dict, {'posted': ['This field cannot be null.']})
|
||||||
|
|
||||||
def test_unique_for_date_with_nullable_date(self):
|
def test_unique_for_date_with_nullable_date(self):
|
||||||
|
"""
|
||||||
|
unique_for_date/year/month checks shouldn't trigger when the
|
||||||
|
associated DateField is None.
|
||||||
|
"""
|
||||||
FlexibleDatePost.objects.create(
|
FlexibleDatePost.objects.create(
|
||||||
title="Django 1.0 is released", slug="Django 1.0",
|
title="Django 1.0 is released", slug="Django 1.0",
|
||||||
subtitle="Finally", posted=datetime.date(2008, 9, 3),
|
subtitle="Finally", posted=datetime.date(2008, 9, 3),
|
||||||
)
|
)
|
||||||
p = FlexibleDatePost(title="Django 1.0 is released")
|
p = FlexibleDatePost(title="Django 1.0 is released")
|
||||||
try:
|
p.full_clean()
|
||||||
p.full_clean()
|
|
||||||
except ValidationError:
|
|
||||||
self.fail("unique_for_date checks shouldn't trigger when the associated DateField is None.")
|
|
||||||
|
|
||||||
p = FlexibleDatePost(slug="Django 1.0")
|
p = FlexibleDatePost(slug="Django 1.0")
|
||||||
try:
|
p.full_clean()
|
||||||
p.full_clean()
|
|
||||||
except ValidationError:
|
|
||||||
self.fail("unique_for_year checks shouldn't trigger when the associated DateField is None.")
|
|
||||||
|
|
||||||
p = FlexibleDatePost(subtitle="Finally")
|
p = FlexibleDatePost(subtitle="Finally")
|
||||||
try:
|
p.full_clean()
|
||||||
p.full_clean()
|
|
||||||
except ValidationError:
|
|
||||||
self.fail("unique_for_month checks shouldn't trigger when the associated DateField is None.")
|
|
||||||
|
|
||||||
def test_unique_errors(self):
|
def test_unique_errors(self):
|
||||||
UniqueErrorsModel.objects.create(name='Some Name', no=10)
|
UniqueErrorsModel.objects.create(name='Some Name', no=10)
|
||||||
|
|
|
@ -308,12 +308,8 @@ class TestSimpleValidators(SimpleTestCase):
|
||||||
self.assertEqual(repr(v), str_prefix("ValidationError({%(_)s'first': [%(_)s'First Problem']})"))
|
self.assertEqual(repr(v), str_prefix("ValidationError({%(_)s'first': [%(_)s'First Problem']})"))
|
||||||
|
|
||||||
def test_regex_validator_flags(self):
|
def test_regex_validator_flags(self):
|
||||||
try:
|
with self.assertRaises(TypeError):
|
||||||
RegexValidator(re.compile('a'), flags=re.IGNORECASE)
|
RegexValidator(re.compile('a'), flags=re.IGNORECASE)
|
||||||
except TypeError:
|
|
||||||
pass
|
|
||||||
else:
|
|
||||||
self.fail("TypeError not raised when flags and pre-compiled regex in RegexValidator")
|
|
||||||
|
|
||||||
def test_max_length_validator_message(self):
|
def test_max_length_validator_message(self):
|
||||||
v = MaxLengthValidator(16, message='"%(value)s" has more than %(limit_value)d characters.')
|
v = MaxLengthValidator(16, message='"%(value)s" has more than %(limit_value)d characters.')
|
||||||
|
|
|
@ -442,15 +442,9 @@ class ExceptionReporterTests(SimpleTestCase):
|
||||||
except BrokenEvaluation:
|
except BrokenEvaluation:
|
||||||
exc_type, exc_value, tb = sys.exc_info()
|
exc_type, exc_value, tb = sys.exc_info()
|
||||||
|
|
||||||
reporter = ExceptionReporter(request, exc_type, exc_value, tb)
|
|
||||||
try:
|
|
||||||
html = reporter.get_traceback_html()
|
|
||||||
except BrokenEvaluation:
|
|
||||||
self.fail("Broken evaluation in traceback is not caught.")
|
|
||||||
|
|
||||||
self.assertIn(
|
self.assertIn(
|
||||||
"BrokenEvaluation",
|
"BrokenEvaluation",
|
||||||
html,
|
ExceptionReporter(request, exc_type, exc_value, tb).get_traceback_html(),
|
||||||
"Evaluation exception reason not mentioned in traceback"
|
"Evaluation exception reason not mentioned in traceback"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue