2010-04-24 07:08:52 +00:00
|
|
|
import sys
|
2008-12-23 18:25:24 +00:00
|
|
|
from unittest import TestCase
|
|
|
|
|
|
|
|
from django.contrib import admin
|
|
|
|
|
|
|
|
|
|
|
|
class Bug8245Test(TestCase):
|
|
|
|
"""
|
|
|
|
Test for bug #8245 - don't raise an AlreadyRegistered exception when using
|
|
|
|
autodiscover() and an admin.py module contains an error.
|
|
|
|
"""
|
2010-04-24 07:08:52 +00:00
|
|
|
if sys.version_info[1] >= 4:
|
|
|
|
# Due to a bug in Python 2.3, this test will fail. The actual
|
|
|
|
# feature works fine; it's just a testing problem. See #13362 for details.
|
|
|
|
def test_bug_8245(self):
|
|
|
|
# The first time autodiscover is called, we should get our real error.
|
|
|
|
try:
|
|
|
|
admin.autodiscover()
|
|
|
|
except Exception, e:
|
|
|
|
self.failUnlessEqual(str(e), "Bad admin module")
|
|
|
|
else:
|
|
|
|
self.fail(
|
|
|
|
'autodiscover should have raised a "Bad admin module" error.')
|
2008-12-23 18:25:24 +00:00
|
|
|
|
2010-04-24 07:08:52 +00:00
|
|
|
# Calling autodiscover again should raise the very same error it did
|
|
|
|
# the first time, not an AlreadyRegistered error.
|
|
|
|
try:
|
|
|
|
admin.autodiscover()
|
|
|
|
except Exception, e:
|
|
|
|
self.failUnlessEqual(str(e), "Bad admin module")
|
|
|
|
else:
|
|
|
|
self.fail(
|
|
|
|
'autodiscover should have raised a "Bad admin module" error.')
|