[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:
Tim Graham 2016-06-28 11:21:26 -04:00
parent 9c48e17480
commit 567cfc1601
30 changed files with 205 additions and 447 deletions

View File

@ -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)

View File

@ -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(), '')

View File

@ -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"""

View File

@ -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])

View File

@ -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):

View File

@ -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.

View File

@ -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):

View File

@ -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):

View File

@ -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):
""" """

View File

@ -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):

View File

@ -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."

View File

@ -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."

View File

@ -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')

View File

@ -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.

View File

@ -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))

View File

@ -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):

View File

@ -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})

View File

@ -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):
""" """

View File

@ -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):

View File

@ -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):
""" """

View File

@ -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()

View File

@ -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'})

View File

@ -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)

View File

@ -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"

View File

@ -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"

View File

@ -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)

View File

@ -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)

View File

@ -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)

View File

@ -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.')

View File

@ -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"
) )