You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

129 lines
5.1 KiB

  1. # -*- coding: utf-8 -*-
  2. #
  3. #
  4. # Authors: Guewen Baconnier
  5. # Copyright 2015 Camptocamp SA
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as
  9. # published by the Free Software Foundation, either version 3 of the
  10. # License, or (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU Affero General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. #
  21. from openerp.tests import common
  22. from .common import ChangesetMixin
  23. class TestChangesetOrigin(ChangesetMixin, common.TransactionCase):
  24. """ Check that origin - old fields are stored as expected.
  25. 'origin' fields dynamically read fields from the partner when the state
  26. of the change is 'draft'. Once a change becomes 'done' or 'cancel', the
  27. 'old' field copies the value from the partner and then the 'origin' field
  28. displays the 'old' value.
  29. """
  30. def _setup_rules(self):
  31. ChangesetFieldRule = self.env['changeset.field.rule']
  32. ChangesetFieldRule.search([]).unlink()
  33. partner_model_id = self.env.ref('base.model_res_partner').id
  34. self.field_name = self.env.ref('base.field_res_partner_name')
  35. ChangesetFieldRule.create({
  36. 'model_id': partner_model_id,
  37. 'field_id': self.field_name.id,
  38. 'action': 'validate',
  39. })
  40. def setUp(self):
  41. super(TestChangesetOrigin, self).setUp()
  42. self._setup_rules()
  43. self.partner = self.env['res.partner'].create({
  44. 'name': 'X',
  45. })
  46. def test_origin_value_of_change_with_apply(self):
  47. """ Origin field is read from the parter or 'old' - with apply
  48. According to the state of the change.
  49. """
  50. self.partner.with_context(__changeset_rules=True).write({
  51. 'name': 'Y',
  52. })
  53. changeset = self.partner.changeset_ids
  54. change = changeset.change_ids
  55. self.assertEqual(self.partner.name, 'X')
  56. self.assertEqual(change.origin_value_char, 'X')
  57. self.assertEqual(change.origin_value_display, 'X')
  58. self.partner.write({'name': 'A'})
  59. self.assertEqual(change.origin_value_char, 'A')
  60. self.assertEqual(change.origin_value_display, 'A')
  61. change.apply()
  62. self.assertEqual(change.origin_value_char, 'A')
  63. self.assertEqual(change.origin_value_display, 'A')
  64. self.partner.write({'name': 'B'})
  65. self.assertEqual(change.origin_value_char, 'A')
  66. self.assertEqual(change.origin_value_display, 'A')
  67. def test_origin_value_of_change_with_cancel(self):
  68. """ Origin field is read from the parter or 'old' - with cancel
  69. According to the state of the change.
  70. """
  71. self.partner.with_context(__changeset_rules=True).write({
  72. 'name': 'Y',
  73. })
  74. changeset = self.partner.changeset_ids
  75. change = changeset.change_ids
  76. self.assertEqual(self.partner.name, 'X')
  77. self.assertEqual(change.origin_value_char, 'X')
  78. self.assertEqual(change.origin_value_display, 'X')
  79. self.partner.write({'name': 'A'})
  80. self.assertEqual(change.origin_value_char, 'A')
  81. self.assertEqual(change.origin_value_display, 'A')
  82. change.cancel()
  83. self.assertEqual(change.origin_value_char, 'A')
  84. self.assertEqual(change.origin_value_display, 'A')
  85. self.partner.write({'name': 'B'})
  86. self.assertEqual(change.origin_value_char, 'A')
  87. self.assertEqual(change.origin_value_display, 'A')
  88. def test_old_field_of_change_with_apply(self):
  89. """ Old field is stored when the change is applied """
  90. self.partner.with_context(__changeset_rules=True).write({
  91. 'name': 'Y',
  92. })
  93. changeset = self.partner.changeset_ids
  94. change = changeset.change_ids
  95. self.assertEqual(self.partner.name, 'X')
  96. self.assertFalse(change.old_value_char)
  97. self.partner.write({'name': 'A'})
  98. self.assertFalse(change.old_value_char)
  99. change.apply()
  100. self.assertEqual(change.old_value_char, 'A')
  101. self.partner.write({'name': 'B'})
  102. self.assertEqual(change.old_value_char, 'A')
  103. def test_old_field_of_change_with_cancel(self):
  104. """ Old field is stored when the change is canceled """
  105. self.partner.with_context(__changeset_rules=True).write({
  106. 'name': 'Y',
  107. })
  108. changeset = self.partner.changeset_ids
  109. change = changeset.change_ids
  110. self.assertEqual(self.partner.name, 'X')
  111. self.assertFalse(change.old_value_char)
  112. self.partner.write({'name': 'A'})
  113. self.assertFalse(change.old_value_char)
  114. change.cancel()
  115. self.assertEqual(change.old_value_char, 'A')
  116. self.partner.write({'name': 'B'})
  117. self.assertEqual(change.old_value_char, 'A')