[IMP] ir.values: add (breaking) testcase for conditional defaults, currently misbehaving
[odoo/odoo.git] / openerp / addons / base / test / test_ir_values.yml
index da26b98..c26e725 100644 (file)
@@ -2,27 +2,86 @@
     Create some default value for some (non-existing) model, for all users.
 -
     !python {model: ir.values }: |
-        self.set(cr, uid, 'default', False, 'my_test_ir_value',['unexisting_model'], 'global value')
+        # use the old API
+        self.set(cr, uid, 'default', False, 'my_test_field',['unexisting_model'], 'global value')
+        # use the new API
+        self.set_default(cr, uid, 'other_unexisting_model', 'my_other_test_field', 'conditional value', condition='foo=bar')
 -
-    Retrieve it.
+    Retrieve them.
 -
     !python {model: ir.values }: |
-        # d is a list of triple (id, name, value)
+        # d is a list of triplets (id, name, value)
+        # Old API
         d = self.get(cr, uid, 'default', False, ['unexisting_model'])
-        assert d[0][1] == u'my_test_ir_value', "Can't retrieve the created default value."
-        assert d[0][2] == 'global value', "Can't retrieve the created default value."
+        assert len(d) == 1, "Only one single value should be retrieved for this model"
+        assert d[0][1] == 'my_test_field', "Can't retrieve the created default value. (1)"
+        assert d[0][2] == 'global value', "Can't retrieve the created default value. (2)"
+
+        # New API, Conditional version
+        d = self.get_defaults(cr, uid, 'other_unexisting_model')
+        assert len(d) == 0, "No value should be retrieved, the condition is not met"
+        d = self.get_defaults(cr, uid, 'other_unexisting_model', condition="foo=eggs")
+        assert len(d) == 0, 'Condition is not met either, no defaults should be returned'
+        d = self.get_defaults(cr, uid, 'other_unexisting_model', condition="foo=bar")
+        assert len(d) == 1, "Only one single value should be retrieved"
+        assert d[0][1] == 'my_other_test_field', "Can't retrieve the created default value. (5)"
+        assert d[0][2] == 'conditional value', "Can't retrieve the created default value. (6)"
 -
     Do it again but for a specific user.
 -
     !python {model: ir.values }: |
-        self.set(cr, uid, 'default', False, 'my_test_ir_value',['unexisting_model'], 'specific value', preserve_user=True)
+        self.set(cr, uid, 'default', False, 'my_test_field',['unexisting_model'], 'specific value', preserve_user=True)
 -
     Retrieve it and check it is the one for the current user.
 -
     !python {model: ir.values }: |
         d = self.get(cr, uid, 'default', False, ['unexisting_model'])
         assert len(d) == 1, "Only one default must be returned per field"
-        assert d[0][1] == u'my_test_ir_value', "Can't retrieve the created default value."
+        assert d[0][1] == 'my_test_field', "Can't retrieve the created default value."
         assert d[0][2] == 'specific value', "Can't retrieve the created default value."
+-
+    Create some action bindings for a non-existing model
+-
+    !python {model: ir.values }: |
+        self.set(cr, uid, 'action', 'tree_but_open', 'OnDblClick Action', ['unexisting_model'], 'ir.actions.act_window,10', isobject=True)
+        self.set(cr, uid, 'action', 'tree_but_open', 'OnDblClick Action 2', ['unexisting_model'], 'ir.actions.act_window,11', isobject=True)
+        self.set(cr, uid, 'action', 'client_action_multi', 'Side Wizard', ['unexisting_model'], 'ir.actions.act_window,12', isobject=True)
+        self.set(cr, uid, 'action', 'client_print_multi', 'Nice Report', ['unexisting_model'], 'ir.actions.report.xml,2', isobject=True)
+        self.set(cr, uid, 'action', 'client_action_relate', 'Related Stuff', ['unexisting_model'], 'ir.actions.act_window,14', isobject=True)
+-
+    Replace one action binding to set a new name
+-
+    !python {model: ir.values }: |
+        self.set(cr, uid, 'action', 'tree_but_open', 'OnDblClick Action New', ['unexisting_model'], 'ir.actions.act_window,10', isobject=True)
+-
+    Retrieve the action bindings and check they're correct
+-
+    !python {model: ir.values }: |
+        actions = self.get(cr, uid, 'action', 'tree_but_open', ['unexisting_model'])
+        assert len(actions) == 2, "Mismatching number of bound actions"
+        #first action
+        assert len(actions[0]) == 3, "Malformed action definition"
+        assert actions[0][1] == 'OnDblClick Action 2', 'Bound action does not match definition'
+        assert isinstance(actions[0][2], dict) and actions[0][2]['id'] == 11, 'Bound action does not match definition'
+        #second action - this ones comes last because it was re-created with a different name
+        assert len(actions[1]) == 3, "Malformed action definition"
+        assert actions[1][1] == 'OnDblClick Action New', 'Re-Registering an action should replace it'
+        assert isinstance(actions[1][2], dict) and actions[1][2]['id'] == 10, 'Bound action does not match definition'
+
+        actions = self.get(cr, uid, 'action', 'client_action_multi', ['unexisting_model'])
+        assert len(actions) == 1, "Mismatching number of bound actions"
+        assert len(actions[0]) == 3, "Malformed action definition"
+        assert actions[0][1] == 'Side Wizard', 'Bound action does not match definition'
+        assert isinstance(actions[0][2], dict) and actions[0][2]['id'] == 12, 'Bound action does not match definition'
+
+        actions = self.get(cr, uid, 'action', 'client_print_multi', ['unexisting_model'])
+        assert len(actions) == 1, "Mismatching number of bound actions"
+        assert len(actions[0]) == 3, "Malformed action definition"
+        assert actions[0][1] == 'Nice Report', 'Bound action does not match definition'
+        assert isinstance(actions[0][2], dict) and actions[0][2]['id'] == 2, 'Bound action does not match definition'
 
-# TODO: ADD tests for action bindings too, the other half of ir_values.
\ No newline at end of file
+        actions = self.get(cr, uid, 'action', 'client_action_relate', ['unexisting_model'])
+        assert len(actions) == 1, "Mismatching number of bound actions"
+        assert len(actions[0]) == 3, "Malformed action definition"
+        assert actions[0][1] == 'Related Stuff', 'Bound action does not match definition'
+        assert isinstance(actions[0][2], dict) and actions[0][2]['id'] == 14, 'Bound action does not match definition'