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.

127 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. self.field_name = self.env.ref('base.field_res_partner_name')
  34. ChangesetFieldRule.create({
  35. 'field_id': self.field_name.id,
  36. 'action': 'validate',
  37. })
  38. def setUp(self):
  39. super(TestChangesetOrigin, self).setUp()
  40. self._setup_rules()
  41. self.partner = self.env['res.partner'].create({
  42. 'name': 'X',
  43. })
  44. def test_origin_value_of_change_with_apply(self):
  45. """ Origin field is read from the parter or 'old' - with apply
  46. According to the state of the change.
  47. """
  48. self.partner.write({
  49. 'name': 'Y',
  50. })
  51. changeset = self.partner.changeset_ids
  52. change = changeset.change_ids
  53. self.assertEqual(self.partner.name, 'X')
  54. self.assertEqual(change.origin_value_char, 'X')
  55. self.assertEqual(change.origin_value_display, 'X')
  56. self.partner.with_context(__no_changeset=True).write({'name': 'A'})
  57. self.assertEqual(change.origin_value_char, 'A')
  58. self.assertEqual(change.origin_value_display, 'A')
  59. change.apply()
  60. self.assertEqual(change.origin_value_char, 'A')
  61. self.assertEqual(change.origin_value_display, 'A')
  62. self.partner.with_context(__no_changeset=True).write({'name': 'B'})
  63. self.assertEqual(change.origin_value_char, 'A')
  64. self.assertEqual(change.origin_value_display, 'A')
  65. def test_origin_value_of_change_with_cancel(self):
  66. """ Origin field is read from the parter or 'old' - with cancel
  67. According to the state of the change.
  68. """
  69. self.partner.write({
  70. 'name': 'Y',
  71. })
  72. changeset = self.partner.changeset_ids
  73. change = changeset.change_ids
  74. self.assertEqual(self.partner.name, 'X')
  75. self.assertEqual(change.origin_value_char, 'X')
  76. self.assertEqual(change.origin_value_display, 'X')
  77. self.partner.with_context(__no_changeset=True).write({'name': 'A'})
  78. self.assertEqual(change.origin_value_char, 'A')
  79. self.assertEqual(change.origin_value_display, 'A')
  80. change.cancel()
  81. self.assertEqual(change.origin_value_char, 'A')
  82. self.assertEqual(change.origin_value_display, 'A')
  83. self.partner.with_context(__no_changeset=True).write({'name': 'B'})
  84. self.assertEqual(change.origin_value_char, 'A')
  85. self.assertEqual(change.origin_value_display, 'A')
  86. def test_old_field_of_change_with_apply(self):
  87. """ Old field is stored when the change is applied """
  88. self.partner.write({
  89. 'name': 'Y',
  90. })
  91. changeset = self.partner.changeset_ids
  92. change = changeset.change_ids
  93. self.assertEqual(self.partner.name, 'X')
  94. self.assertFalse(change.old_value_char)
  95. self.partner.with_context(__no_changeset=True).write({'name': 'A'})
  96. self.assertFalse(change.old_value_char)
  97. change.apply()
  98. self.assertEqual(change.old_value_char, 'A')
  99. self.partner.with_context(__no_changeset=True).write({'name': 'B'})
  100. self.assertEqual(change.old_value_char, 'A')
  101. def test_old_field_of_change_with_cancel(self):
  102. """ Old field is stored when the change is canceled """
  103. self.partner.write({
  104. 'name': 'Y',
  105. })
  106. changeset = self.partner.changeset_ids
  107. change = changeset.change_ids
  108. self.assertEqual(self.partner.name, 'X')
  109. self.assertFalse(change.old_value_char)
  110. self.partner.with_context(__no_changeset=True).write({'name': 'A'})
  111. self.assertFalse(change.old_value_char)
  112. change.cancel()
  113. self.assertEqual(change.old_value_char, 'A')
  114. self.partner.with_context(__no_changeset=True).write({'name': 'B'})
  115. self.assertEqual(change.old_value_char, 'A')