summaryrefslogtreecommitdiff
path: root/parts/django/tests/regressiontests/utils/datastructures.py
diff options
context:
space:
mode:
authorNishanth Amuluru2011-01-08 11:20:57 +0530
committerNishanth Amuluru2011-01-08 11:20:57 +0530
commit65411d01d448ff0cd4abd14eee14cf60b5f8fc20 (patch)
treeb4c404363c4c63a61d6e2f8bd26c5b057c1fb09d /parts/django/tests/regressiontests/utils/datastructures.py
parent2e35094d43b4cc6974172e1febf76abb50f086ec (diff)
downloadpytask-65411d01d448ff0cd4abd14eee14cf60b5f8fc20.tar.gz
pytask-65411d01d448ff0cd4abd14eee14cf60b5f8fc20.tar.bz2
pytask-65411d01d448ff0cd4abd14eee14cf60b5f8fc20.zip
Added buildout stuff and made changes accordingly
--HG-- rename : profile/management/__init__.py => eggs/djangorecipe-0.20-py2.6.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/djangorecipe-0.20-py2.6.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => eggs/infrae.subversion-1.4.5-py2.6.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/infrae.subversion-1.4.5-py2.6.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => eggs/mercurial-1.7.3-py2.6-linux-x86_64.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/mercurial-1.7.3-py2.6-linux-x86_64.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => eggs/py-1.4.0-py2.6.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/py-1.4.0-py2.6.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => eggs/zc.buildout-1.5.2-py2.6.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/zc.buildout-1.5.2-py2.6.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => eggs/zc.recipe.egg-1.3.2-py2.6.egg/EGG-INFO/dependency_links.txt rename : profile/management/__init__.py => eggs/zc.recipe.egg-1.3.2-py2.6.egg/EGG-INFO/not-zip-safe rename : profile/management/__init__.py => parts/django/Django.egg-info/dependency_links.txt rename : taskapp/models.py => parts/django/django/conf/app_template/models.py rename : taskapp/tests.py => parts/django/django/conf/app_template/tests.py rename : taskapp/views.py => parts/django/django/conf/app_template/views.py rename : taskapp/views.py => parts/django/django/contrib/gis/tests/geo3d/views.py rename : profile/management/__init__.py => parts/django/tests/modeltests/delete/__init__.py rename : profile/management/__init__.py => parts/django/tests/modeltests/files/__init__.py rename : profile/management/__init__.py => parts/django/tests/modeltests/invalid_models/__init__.py rename : profile/management/__init__.py => parts/django/tests/modeltests/m2m_signals/__init__.py rename : profile/management/__init__.py => parts/django/tests/modeltests/model_package/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/bash_completion/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/bash_completion/management/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/bash_completion/management/commands/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/bash_completion/models.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/delete_regress/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/file_storage/__init__.py rename : profile/management/__init__.py => parts/django/tests/regressiontests/max_lengths/__init__.py rename : profile/forms.py => pytask/profile/forms.py rename : profile/management/__init__.py => pytask/profile/management/__init__.py rename : profile/management/commands/seed_db.py => pytask/profile/management/commands/seed_db.py rename : profile/models.py => pytask/profile/models.py rename : profile/templatetags/user_tags.py => pytask/profile/templatetags/user_tags.py rename : taskapp/tests.py => pytask/profile/tests.py rename : profile/urls.py => pytask/profile/urls.py rename : profile/utils.py => pytask/profile/utils.py rename : profile/views.py => pytask/profile/views.py rename : static/css/base.css => pytask/static/css/base.css rename : taskapp/tests.py => pytask/taskapp/tests.py rename : taskapp/views.py => pytask/taskapp/views.py rename : templates/base.html => pytask/templates/base.html rename : templates/profile/browse_notifications.html => pytask/templates/profile/browse_notifications.html rename : templates/profile/edit.html => pytask/templates/profile/edit.html rename : templates/profile/view.html => pytask/templates/profile/view.html rename : templates/profile/view_notification.html => pytask/templates/profile/view_notification.html rename : templates/registration/activate.html => pytask/templates/registration/activate.html rename : templates/registration/activation_email.txt => pytask/templates/registration/activation_email.txt rename : templates/registration/activation_email_subject.txt => pytask/templates/registration/activation_email_subject.txt rename : templates/registration/logged_out.html => pytask/templates/registration/logged_out.html rename : templates/registration/login.html => pytask/templates/registration/login.html rename : templates/registration/logout.html => pytask/templates/registration/logout.html rename : templates/registration/password_change_done.html => pytask/templates/registration/password_change_done.html rename : templates/registration/password_change_form.html => pytask/templates/registration/password_change_form.html rename : templates/registration/password_reset_complete.html => pytask/templates/registration/password_reset_complete.html rename : templates/registration/password_reset_confirm.html => pytask/templates/registration/password_reset_confirm.html rename : templates/registration/password_reset_done.html => pytask/templates/registration/password_reset_done.html rename : templates/registration/password_reset_email.html => pytask/templates/registration/password_reset_email.html rename : templates/registration/password_reset_form.html => pytask/templates/registration/password_reset_form.html rename : templates/registration/registration_complete.html => pytask/templates/registration/registration_complete.html rename : templates/registration/registration_form.html => pytask/templates/registration/registration_form.html rename : utils.py => pytask/utils.py
Diffstat (limited to 'parts/django/tests/regressiontests/utils/datastructures.py')
-rw-r--r--parts/django/tests/regressiontests/utils/datastructures.py256
1 files changed, 256 insertions, 0 deletions
diff --git a/parts/django/tests/regressiontests/utils/datastructures.py b/parts/django/tests/regressiontests/utils/datastructures.py
new file mode 100644
index 0000000..a41281c
--- /dev/null
+++ b/parts/django/tests/regressiontests/utils/datastructures.py
@@ -0,0 +1,256 @@
+"""
+Tests for stuff in django.utils.datastructures.
+"""
+import pickle
+import unittest
+
+from django.utils.datastructures import *
+
+
+class DatastructuresTestCase(unittest.TestCase):
+ def assertRaisesErrorWithMessage(self, error, message, callable,
+ *args, **kwargs):
+ self.assertRaises(error, callable, *args, **kwargs)
+ try:
+ callable(*args, **kwargs)
+ except error, e:
+ self.assertEqual(message, str(e))
+
+
+class SortedDictTests(DatastructuresTestCase):
+ def setUp(self):
+ self.d1 = SortedDict()
+ self.d1[7] = 'seven'
+ self.d1[1] = 'one'
+ self.d1[9] = 'nine'
+
+ self.d2 = SortedDict()
+ self.d2[1] = 'one'
+ self.d2[9] = 'nine'
+ self.d2[0] = 'nil'
+ self.d2[7] = 'seven'
+
+ def test_basic_methods(self):
+ self.assertEquals(self.d1.keys(), [7, 1, 9])
+ self.assertEquals(self.d1.values(), ['seven', 'one', 'nine'])
+ self.assertEquals(self.d1.items(), [(7, 'seven'), (1, 'one'), (9, 'nine')])
+
+ def test_overwrite_ordering(self):
+ """ Overwriting an item keeps it's place. """
+ self.d1[1] = 'ONE'
+ self.assertEquals(self.d1.values(), ['seven', 'ONE', 'nine'])
+
+ def test_append_items(self):
+ """ New items go to the end. """
+ self.d1[0] = 'nil'
+ self.assertEquals(self.d1.keys(), [7, 1, 9, 0])
+
+ def test_delete_and_insert(self):
+ """
+ Deleting an item, then inserting the same key again will place it
+ at the end.
+ """
+ del self.d2[7]
+ self.assertEquals(self.d2.keys(), [1, 9, 0])
+ self.d2[7] = 'lucky number 7'
+ self.assertEquals(self.d2.keys(), [1, 9, 0, 7])
+
+ def test_change_keys(self):
+ """
+ Changing the keys won't do anything, it's only a copy of the
+ keys dict.
+ """
+ k = self.d2.keys()
+ k.remove(9)
+ self.assertEquals(self.d2.keys(), [1, 9, 0, 7])
+
+ def test_init_keys(self):
+ """
+ Initialising a SortedDict with two keys will just take the first one.
+
+ A real dict will actually take the second value so we will too, but
+ we'll keep the ordering from the first key found.
+ """
+ tuples = ((2, 'two'), (1, 'one'), (2, 'second-two'))
+ d = SortedDict(tuples)
+
+ self.assertEquals(d.keys(), [2, 1])
+
+ real_dict = dict(tuples)
+ self.assertEquals(sorted(real_dict.values()), ['one', 'second-two'])
+
+ # Here the order of SortedDict values *is* what we are testing
+ self.assertEquals(d.values(), ['second-two', 'one'])
+
+ def test_overwrite(self):
+ self.d1[1] = 'not one'
+ self.assertEqual(self.d1[1], 'not one')
+ self.assertEqual(self.d1.keys(), self.d1.copy().keys())
+
+ def test_append(self):
+ self.d1[13] = 'thirteen'
+ self.assertEquals(
+ repr(self.d1),
+ "{7: 'seven', 1: 'one', 9: 'nine', 13: 'thirteen'}"
+ )
+
+ def test_pop(self):
+ self.assertEquals(self.d1.pop(1, 'missing'), 'one')
+ self.assertEquals(self.d1.pop(1, 'missing'), 'missing')
+
+ # We don't know which item will be popped in popitem(), so we'll
+ # just check that the number of keys has decreased.
+ l = len(self.d1)
+ self.d1.popitem()
+ self.assertEquals(l - len(self.d1), 1)
+
+ def test_dict_equality(self):
+ d = SortedDict((i, i) for i in xrange(3))
+ self.assertEquals(d, {0: 0, 1: 1, 2: 2})
+
+ def test_tuple_init(self):
+ d = SortedDict(((1, "one"), (0, "zero"), (2, "two")))
+ self.assertEquals(repr(d), "{1: 'one', 0: 'zero', 2: 'two'}")
+
+ def test_pickle(self):
+ self.assertEquals(
+ pickle.loads(pickle.dumps(self.d1, 2)),
+ {7: 'seven', 1: 'one', 9: 'nine'}
+ )
+
+ def test_clear(self):
+ self.d1.clear()
+ self.assertEquals(self.d1, {})
+ self.assertEquals(self.d1.keyOrder, [])
+
+class MergeDictTests(DatastructuresTestCase):
+
+ def test_simple_mergedict(self):
+ d1 = {'chris':'cool', 'camri':'cute', 'cotton':'adorable',
+ 'tulip':'snuggable', 'twoofme':'firstone'}
+
+ d2 = {'chris2':'cool2', 'camri2':'cute2', 'cotton2':'adorable2',
+ 'tulip2':'snuggable2'}
+
+ d3 = {'chris3':'cool3', 'camri3':'cute3', 'cotton3':'adorable3',
+ 'tulip3':'snuggable3'}
+
+ d4 = {'twoofme': 'secondone'}
+
+ md = MergeDict(d1, d2, d3)
+
+ self.assertEquals(md['chris'], 'cool')
+ self.assertEquals(md['camri'], 'cute')
+ self.assertEquals(md['twoofme'], 'firstone')
+
+ md2 = md.copy()
+ self.assertEquals(md2['chris'], 'cool')
+
+ def test_mergedict_merges_multivaluedict(self):
+ """ MergeDict can merge MultiValueDicts """
+
+ multi1 = MultiValueDict({'key1': ['value1'],
+ 'key2': ['value2', 'value3']})
+
+ multi2 = MultiValueDict({'key2': ['value4'],
+ 'key4': ['value5', 'value6']})
+
+ mm = MergeDict(multi1, multi2)
+
+ # Although 'key2' appears in both dictionaries,
+ # only the first value is used.
+ self.assertEquals(mm.getlist('key2'), ['value2', 'value3'])
+ self.assertEquals(mm.getlist('key4'), ['value5', 'value6'])
+ self.assertEquals(mm.getlist('undefined'), [])
+
+ self.assertEquals(sorted(mm.keys()), ['key1', 'key2', 'key4'])
+ self.assertEquals(len(mm.values()), 3)
+
+ self.assertTrue('value1' in mm.values())
+
+ self.assertEquals(sorted(mm.items(), key=lambda k: k[0]),
+ [('key1', 'value1'), ('key2', 'value3'),
+ ('key4', 'value6')])
+
+ self.assertEquals([(k,mm.getlist(k)) for k in sorted(mm)],
+ [('key1', ['value1']),
+ ('key2', ['value2', 'value3']),
+ ('key4', ['value5', 'value6'])])
+
+class MultiValueDictTests(DatastructuresTestCase):
+
+ def test_multivaluedict(self):
+ d = MultiValueDict({'name': ['Adrian', 'Simon'],
+ 'position': ['Developer']})
+
+ self.assertEquals(d['name'], 'Simon')
+ self.assertEquals(d.get('name'), 'Simon')
+ self.assertEquals(d.getlist('name'), ['Adrian', 'Simon'])
+ self.assertEquals(list(d.iteritems()),
+ [('position', 'Developer'), ('name', 'Simon')])
+
+ self.assertEquals(list(d.iterlists()),
+ [('position', ['Developer']),
+ ('name', ['Adrian', 'Simon'])])
+
+ # MultiValueDictKeyError: "Key 'lastname' not found in
+ # <MultiValueDict: {'position': ['Developer'],
+ # 'name': ['Adrian', 'Simon']}>"
+ self.assertRaisesErrorWithMessage(MultiValueDictKeyError,
+ '"Key \'lastname\' not found in <MultiValueDict: {\'position\':'\
+ ' [\'Developer\'], \'name\': [\'Adrian\', \'Simon\']}>"',
+ d.__getitem__, 'lastname')
+
+ self.assertEquals(d.get('lastname'), None)
+ self.assertEquals(d.get('lastname', 'nonexistent'), 'nonexistent')
+ self.assertEquals(d.getlist('lastname'), [])
+
+ d.setlist('lastname', ['Holovaty', 'Willison'])
+ self.assertEquals(d.getlist('lastname'), ['Holovaty', 'Willison'])
+ self.assertEquals(d.values(), ['Developer', 'Simon', 'Willison'])
+ self.assertEquals(list(d.itervalues()),
+ ['Developer', 'Simon', 'Willison'])
+
+
+class DotExpandedDictTests(DatastructuresTestCase):
+
+ def test_dotexpandeddict(self):
+
+ d = DotExpandedDict({'person.1.firstname': ['Simon'],
+ 'person.1.lastname': ['Willison'],
+ 'person.2.firstname': ['Adrian'],
+ 'person.2.lastname': ['Holovaty']})
+
+ self.assertEquals(d['person']['1']['lastname'], ['Willison'])
+ self.assertEquals(d['person']['2']['lastname'], ['Holovaty'])
+ self.assertEquals(d['person']['2']['firstname'], ['Adrian'])
+
+
+class ImmutableListTests(DatastructuresTestCase):
+
+ def test_sort(self):
+ d = ImmutableList(range(10))
+
+ # AttributeError: ImmutableList object is immutable.
+ self.assertRaisesErrorWithMessage(AttributeError,
+ 'ImmutableList object is immutable.', d.sort)
+
+ self.assertEquals(repr(d), '(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)')
+
+ def test_custom_warning(self):
+ d = ImmutableList(range(10), warning="Object is immutable!")
+
+ self.assertEquals(d[1], 1)
+
+ # AttributeError: Object is immutable!
+ self.assertRaisesErrorWithMessage(AttributeError,
+ 'Object is immutable!', d.__setitem__, 1, 'test')
+
+
+class DictWrapperTests(DatastructuresTestCase):
+
+ def test_dictwrapper(self):
+ f = lambda x: "*%s" % x
+ d = DictWrapper({'a': 'a'}, f, 'xx_')
+ self.assertEquals("Normal: %(a)s. Modified: %(xx_a)s" % d,
+ 'Normal: a. Modified: *a')