~therp-nl/openobject-server/7.0-lp1062795-search_m2m_negative_gives_wrong_results

« back to all changes in this revision

Viewing changes to openerp/addons/base/tests/test_expression.py

  • Committer: Vo Minh Thu
  • Date: 2012-10-26 10:08:19 UTC
  • Revision ID: vmt@openerp.com-20121026100819-b2o4q9a082um6p2m
[IMP] expression.py: added tests for the in/not in operators involving a many2many.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
import unittest2
 
2
 
 
3
import openerp.tests.common as common
 
4
 
 
5
class test_expression(common.TransactionCase):
 
6
 
 
7
    def test_00(self):
 
8
 
 
9
        registry, cr, uid = self.registry, self.cr, self.uid
 
10
 
 
11
        categories = registry('res.partner.category')
 
12
        cat_a = categories.create(cr, uid, {'name': 'test_expression_category_A'})
 
13
        cat_b = categories.create(cr, uid, {'name': 'test_expression_category_B'})
 
14
 
 
15
        partners = registry('res.partner')
 
16
        a = partners.create(cr, uid, {'name': 'test_expression_partner_A', 'category_id': [(6, 0, [cat_a])]})
 
17
        b = partners.create(cr, uid, {'name': 'test_expression_partner_B', 'category_id': [(6, 0, [cat_b])]})
 
18
        ab = partners.create(cr, uid, {'name': 'test_expression_partner_AB', 'category_id': [(6, 0, [cat_a, cat_b])]})
 
19
        c = partners.create(cr, uid, {'name': 'test_expression_partner_C'})
 
20
 
 
21
        with_a = partners.search(cr, uid, [('category_id', 'in', [cat_a])])
 
22
        self.assertEqual(set([a, ab]), set(with_a), "Search for category_id in cat_a failed.")
 
23
 
 
24
        with_b = partners.search(cr, uid, [('category_id', 'in', [cat_b])])
 
25
        self.assertEqual(set([ab, b]), set(with_b), "Search for category_id in cat_b failed.")
 
26
 
 
27
        with_a_or_b = partners.search(cr, uid, [('category_id', 'in', [cat_a, cat_b])])
 
28
        self.assertEqual(set([ab, a, b]), set(with_a_or_b), "Search for category_id contains cat_a or cat_b failed.")
 
29
 
 
30
        with_a_and_b = partners.search(cr, uid, [('category_id', 'in', [cat_a]), ('category_id', 'in', [cat_b])])
 
31
        self.assertEqual(set([ab]), set(with_a_and_b), "Search for category_id contains cat_a and cat_b failed.")
 
32
 
 
33
        # Note it is the same as with_a_or_b above.
 
34
        with_a_or_with_b = partners.search(cr, uid, ['|', ('category_id', 'in', [cat_a]), ('category_id', 'in', [cat_b])])
 
35
        self.assertEqual(set([ab, a, b]), set(with_a_or_with_b), "Search for category_id contains cat_a or contains cat_b failed.")
 
36
 
 
37
        without_a_or_b = partners.search(cr, uid, [('category_id', 'not in', [cat_a, cat_b])])
 
38
        self.assertTrue(all(i not in without_a_or_b for i in [a, b, ab]), "Search for category_id doesn't contain cat_a or cat_b failed (1).")
 
39
        self.assertTrue(c in without_a_or_b, "Search for category_id doesn't contain cat_a or cat_b failed (2).")
 
40
 
 
41
        without_a_and_without_b = partners.search(cr, uid, [('category_id', 'not in', [cat_a]), ('category_id', 'not in', [cat_b])])
 
42
        self.assertTrue(all(i not in without_a_and_without_b for i in [a, b, ab]), "Search for category_id doesn't contain cat_a and cat_b failed (1).")
 
43
        self.assertTrue(c in without_a_and_without_b, "Search for category_id doesn't contain cat_a and cat_b failed (2).")
 
44
 
 
45
        without_a = partners.search(cr, uid, [('category_id', 'not in', [cat_a])])
 
46
        self.assertTrue(a not in without_a, "Search for category_id doesn't contain cat_a failed (1).")
 
47
        self.assertTrue(ab not in without_a, "Search for category_id doesn't contain cat_a failed (2).")
 
48
        self.assertTrue(set([b, c]).issubset(set(without_a)), "Search for category_id doesn't contain cat_a failed (3).")
 
49
 
 
50
        without_b = partners.search(cr, uid, [('category_id', 'not in', [cat_b])])
 
51
        self.assertTrue(b not in without_b, "Search for category_id doesn't contain cat_b failed (1).")
 
52
        self.assertTrue(ab not in without_b, "Search for category_id doesn't contain cat_b failed (2).")
 
53
        self.assertTrue(set([a, c]).issubset(set(without_b)), "Search for category_id doesn't contain cat_b failed (3).")
 
54
 
 
55
        # We can't express the following.
 
56
        # with_any_other_than_a = ...
 
57
        # self.assertTrue(ab in with_any_other_than_a, "Search for category_id with any other than cat_a failed.")
 
58