3
import openerp.tests.common as common
5
class test_expression(common.TransactionCase):
9
registry, cr, uid = self.registry, self.cr, self.uid
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'})
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'})
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.")
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.")
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.")
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.")
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.")
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).")
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).")
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).")
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).")
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.")