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.

110 lines
3.9 KiB

FIX pylint (cherry picked from commit eadcae217103fd8f2f8d3db87c6fb659e048812b) Conflicts: partner_identification/__openerp__.py Set version to 8.0.1.0.0. Remove dependency on sales_team, as the relevant change is not in 8.0. Change emails to the new ones (cherry picked from commit 3455ae614e28d7807fc19d7be54512cbe59d44ec) Update new name (cherry picked from commit 5b592d7562fddac0cf48c71e6607cf17c009e993) [FIX] try me on runbot link (cherry picked from commit bd587b6058a17814cee5496a0ed3c126600f6fd6) Conflicts: partner_identification/README.rst Changed runbot to 8.0 [IMP] partner_identification: Add context override (#373) Allow for context override of validations using ``id_no_validate`` (cherry picked from commit 76c2e7b784916cdca0753a46a7b2be75edc1d70d) [10.0][IMP] partner_identification: Add field computation and inverses (#419) * [IMP] partner_identification: Add field computation and inverses * Add methods to allow for computation and inverse of an ID field of a specific category type * [IMP] partner_identification: Add search option (cherry picked from commit 19c5fb6de2a710dd50248fd843465f454de887bf) [FIX] partner_identification: Infinite loop in search (#436) (cherry picked from commit fa9b390dc62f66ef33acd7aacdfb3b79912ebc28) [FIX] partner-contact CI interactions (cherry picked from commit bc93e7bbc3e0f059b228970f0a05e57f0efba310) [ADD][8.0] Backport of the 9.0 module. (cherry picked from commit a42540381d448c3a62fabf69043ed23bf1aeca3e) [8.0][MIG] partner_identification backport
8 years ago
FIX pylint (cherry picked from commit eadcae217103fd8f2f8d3db87c6fb659e048812b) Conflicts: partner_identification/__openerp__.py Set version to 8.0.1.0.0. Remove dependency on sales_team, as the relevant change is not in 8.0. Change emails to the new ones (cherry picked from commit 3455ae614e28d7807fc19d7be54512cbe59d44ec) Update new name (cherry picked from commit 5b592d7562fddac0cf48c71e6607cf17c009e993) [FIX] try me on runbot link (cherry picked from commit bd587b6058a17814cee5496a0ed3c126600f6fd6) Conflicts: partner_identification/README.rst Changed runbot to 8.0 [IMP] partner_identification: Add context override (#373) Allow for context override of validations using ``id_no_validate`` (cherry picked from commit 76c2e7b784916cdca0753a46a7b2be75edc1d70d) [10.0][IMP] partner_identification: Add field computation and inverses (#419) * [IMP] partner_identification: Add field computation and inverses * Add methods to allow for computation and inverse of an ID field of a specific category type * [IMP] partner_identification: Add search option (cherry picked from commit 19c5fb6de2a710dd50248fd843465f454de887bf) [FIX] partner_identification: Infinite loop in search (#436) (cherry picked from commit fa9b390dc62f66ef33acd7aacdfb3b79912ebc28) [FIX] partner-contact CI interactions (cherry picked from commit bc93e7bbc3e0f059b228970f0a05e57f0efba310) [ADD][8.0] Backport of the 9.0 module. (cherry picked from commit a42540381d448c3a62fabf69043ed23bf1aeca3e) [8.0][MIG] partner_identification backport
8 years ago
FIX pylint (cherry picked from commit eadcae217103fd8f2f8d3db87c6fb659e048812b) Conflicts: partner_identification/__openerp__.py Set version to 8.0.1.0.0. Remove dependency on sales_team, as the relevant change is not in 8.0. Change emails to the new ones (cherry picked from commit 3455ae614e28d7807fc19d7be54512cbe59d44ec) Update new name (cherry picked from commit 5b592d7562fddac0cf48c71e6607cf17c009e993) [FIX] try me on runbot link (cherry picked from commit bd587b6058a17814cee5496a0ed3c126600f6fd6) Conflicts: partner_identification/README.rst Changed runbot to 8.0 [IMP] partner_identification: Add context override (#373) Allow for context override of validations using ``id_no_validate`` (cherry picked from commit 76c2e7b784916cdca0753a46a7b2be75edc1d70d) [10.0][IMP] partner_identification: Add field computation and inverses (#419) * [IMP] partner_identification: Add field computation and inverses * Add methods to allow for computation and inverse of an ID field of a specific category type * [IMP] partner_identification: Add search option (cherry picked from commit 19c5fb6de2a710dd50248fd843465f454de887bf) [FIX] partner_identification: Infinite loop in search (#436) (cherry picked from commit fa9b390dc62f66ef33acd7aacdfb3b79912ebc28) [FIX] partner-contact CI interactions (cherry picked from commit bc93e7bbc3e0f059b228970f0a05e57f0efba310) [ADD][8.0] Backport of the 9.0 module. (cherry picked from commit a42540381d448c3a62fabf69043ed23bf1aeca3e) [8.0][MIG] partner_identification backport
8 years ago
  1. # -*- coding: utf-8 -*-
  2. # © 2016 ACSONE SA/NV (<http://acsone.eu>)
  3. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  4. from psycopg2._psycopg import IntegrityError
  5. from openerp.tests import common
  6. from openerp.exceptions import ValidationError
  7. class TestPartnerIdentificationBase(common.TransactionCase):
  8. def test_base_functionalities(self):
  9. """Dummy CRUD test
  10. """
  11. partner_id_category = self.env['res.partner.id_category'].create({
  12. 'code': 'id_code',
  13. 'name': 'id_name',
  14. })
  15. self.assertEqual(partner_id_category.name, 'id_name')
  16. self.assertEqual(partner_id_category.code, 'id_code')
  17. partner_1 = self.env.ref('base.res_partner_1')
  18. self.assertEquals(len(partner_1.id_numbers), 0)
  19. # create without required category
  20. with self.assertRaises(IntegrityError), self.cr.savepoint():
  21. partner_1.write({'id_numbers': [(0, 0, {
  22. 'name': '1234',
  23. })]})
  24. # successful creation
  25. partner_1.write({'id_numbers': [(0, 0, {
  26. 'name': '1234',
  27. 'category_id': partner_id_category.id
  28. })]})
  29. self.assertEquals(len(partner_1.id_numbers), 1)
  30. self.assertEquals(partner_1.id_numbers.name, '1234')
  31. # delete
  32. partner_1.write({'id_numbers': [(5, 0, 0)]})
  33. self.assertEquals(len(partner_1.id_numbers), 0)
  34. class TestPartnerCategoryValidation(common.TransactionCase):
  35. def test_partner_id_number_validation(self):
  36. partner_id_category = self.env['res.partner.id_category'].create({
  37. 'code': 'id_code',
  38. 'name': 'id_name',
  39. 'validation_code': """
  40. if id_number.name != '1234':
  41. failed = True
  42. """
  43. })
  44. partner_1 = self.env.ref('base.res_partner_1')
  45. with self.assertRaises(ValidationError), self.cr.savepoint():
  46. partner_1.write({'id_numbers': [(0, 0, {
  47. 'name': '01234',
  48. 'category_id': partner_id_category.id
  49. })]})
  50. partner_1.write({'id_numbers': [(0, 0, {
  51. 'name': '1234',
  52. 'category_id': partner_id_category.id
  53. })]})
  54. self.assertEquals(len(partner_1.id_numbers), 1)
  55. self.assertEquals(partner_1.id_numbers.name, '1234')
  56. partner_id_category2 = self.env['res.partner.id_category'].create({
  57. 'code': 'id_code2',
  58. 'name': 'id_name2',
  59. 'validation_code': """
  60. if id_number.name != '1235':
  61. failed = True
  62. """})
  63. # check that the constrains is also checked when we change the
  64. # associated category
  65. with self.assertRaises(ValidationError), self.cr.savepoint():
  66. partner_1.id_numbers.write({
  67. 'category_id': partner_id_category2.id
  68. })
  69. def test_bad_validation_code(self):
  70. partner_id_category = self.env['res.partner.id_category'].create({
  71. 'code': 'id_code',
  72. 'name': 'id_name',
  73. 'validation_code': """
  74. if id_number.name != '1234' # missing :
  75. failed = True
  76. """
  77. })
  78. partner_1 = self.env.ref('base.res_partner_1')
  79. with self.assertRaises(ValidationError):
  80. partner_1.write({'id_numbers': [(0, 0, {
  81. 'name': '1234',
  82. 'category_id': partner_id_category.id
  83. })]})
  84. def test_bad_validation_code_override(self):
  85. """ It should allow a bad validation code if context overrides. """
  86. partner_id_category = self.env['res.partner.id_category'].create({
  87. 'code': 'id_code',
  88. 'name': 'id_name',
  89. 'validation_code': """
  90. if id_number.name != '1234' # missing :
  91. failed = True
  92. """
  93. })
  94. partner_1 = self.env.ref('base.res_partner_1').with_context(
  95. id_no_validate=True,
  96. )
  97. partner_1.write({'id_numbers': [(0, 0, {
  98. 'name': '1234',
  99. 'category_id': partner_id_category.id
  100. })]})