diff options
author | Eduardo Habkost <ehabkost@redhat.com> | 2009-08-13 18:09:17 -0300 |
---|---|---|
committer | Jeremy Kerr <jk@ozlabs.org> | 2009-08-15 13:18:01 +1000 |
commit | 428762cd01e05ba4ebb991541a84a7e514f10a88 (patch) | |
tree | 996cac873f39ce30dc44d83e499d320a1fcedc40 /apps | |
parent | fc58a911d4a43d6e0b06a1bd2e397e5448a591a7 (diff) | |
download | patchwork-428762cd01e05ba4ebb991541a84a7e514f10a88.tar.bz2 patchwork-428762cd01e05ba4ebb991541a84a7e514f10a88.tar.xz |
tests: check some edge cases in bundle reordering tests
While testing BundleReorderTest, I felt like adding more test cases to
check if reordering is touching only the right patches on the bundle.
This increases the number of patches on the test bundle to 5, and
changes the code to do the following tests:
- Reorder all patches
- Reorder only the first 3 patches
- Reorder only the last 3 patches
- Reorder only the middle 3 patches
- On all above tests, check if the 'order' field on the BundlePatch
objects is still consistent
Signed-off-by: Eduardo Habkost <ehabkost@redhat.com>
Signed-off-by: Jeremy Kerr <jk@ozlabs.org>
Diffstat (limited to 'apps')
-rw-r--r-- | apps/patchwork/tests/bundles.py | 51 |
1 files changed, 35 insertions, 16 deletions
diff --git a/apps/patchwork/tests/bundles.py b/apps/patchwork/tests/bundles.py index 2e4c8fa..659500e 100644 --- a/apps/patchwork/tests/bundles.py +++ b/apps/patchwork/tests/bundles.py @@ -48,8 +48,8 @@ class BundleListTest(TestCase): self.user.delete() class BundleTestBase(TestCase): - def setUp(self): - patch_names = ['testpatch1', 'testpatch2', 'testpatch3'] + def setUp(self, patch_count=3): + patch_names = ['testpatch%d' % (i) for i in range(1, patch_count+1)] self.user = create_user() self.client.login(username = self.user.username, password = self.user.username) @@ -336,31 +336,50 @@ class BundleAddFromPatchTest(BundleTestBase): class BundleReorderTest(BundleTestBase): def setUp(self): - super(BundleReorderTest, self).setUp() - self.bundle.append_patch(self.patches[0]) - self.bundle.append_patch(self.patches[1]) - self.bundle.append_patch(self.patches[2]) + super(BundleReorderTest, self).setUp(5) + for i in range(5): + self.bundle.append_patch(self.patches[i]) - def testBundleReorder(self): - bundlepatch = BundlePatch.objects.get(bundle = self.bundle, - patch = self.patches[0]) + def checkReordering(self, neworder, start, end): + neworder_ids = [ self.patches[i].id for i in neworder ] - neworder = [self.patches[2], self.patches[0], self.patches[1]] - neworder_ids = [ p.id for p in neworder ] + firstpatch = BundlePatch.objects.get(bundle = self.bundle, + patch = self.patches[start]).patch + slice_ids = neworder_ids[start:end] params = {'form': 'reorderform', - 'order_start': bundlepatch.patch.id, - 'neworder': neworder_ids} + 'order_start': firstpatch.id, + 'neworder': slice_ids} response = self.client.post('/user/bundle/%d/' % self.bundle.id, params) self.failUnlessEqual(response.status_code, 200) - bundle_ids = [ bp.patch.id for bp in \ - BundlePatch.objects.filter(bundle = self.bundle) \ - .order_by('order') ] + bps = BundlePatch.objects.filter(bundle = self.bundle) \ + .order_by('order') + # check if patch IDs are in the expected order: + bundle_ids = [ bp.patch.id for bp in bps ] self.failUnlessEqual(neworder_ids, bundle_ids) + # check if order field is still sequential: + order_numbers = [ bp.order for bp in bps ] + expected_order = range(1, len(neworder)+1) # [1 ... len(neworder)] + self.failUnlessEqual(order_numbers, expected_order) + + def testBundleReorderAll(self): + # reorder all patches: + self.checkReordering([2,1,4,0,3], 0, 5) + + def testBundleReorderEnd(self): + # reorder only the last three patches + self.checkReordering([0,1,3,2,4], 2, 5) + + def testBundleReorderBegin(self): + # reorder only the first three patches + self.checkReordering([2,0,1,3,4], 0, 3) + def testBundleReorderMiddle(self): + # reorder only 2nd, 3rd, and 4th patches + self.checkReordering([0,2,3,1,4], 1, 4) |