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.

125 lines
3.9 KiB

  1. # Copyright 2017 ACSONE SA/NV
  2. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
  3. from odoo import fields
  4. from odoo.tests.common import TransactionCase
  5. class TestParser(TransactionCase):
  6. def test_getting_parser(self):
  7. expected_parser = [
  8. 'name',
  9. 'active',
  10. 'credit_limit',
  11. 'color',
  12. ('category_id', ['name']),
  13. ('country_id', ['name', 'code']),
  14. ('child_ids', [
  15. 'name',
  16. 'id',
  17. 'email',
  18. ('country_id', ['name', 'code']),
  19. ('child_ids', ['name']),
  20. ]),
  21. 'lang',
  22. 'comment'
  23. ]
  24. exporter = self.env.ref('base_jsonify.ir_exp_partner')
  25. parser = exporter.get_json_parser()
  26. self.assertListEqual(parser, expected_parser)
  27. # modify an ir.exports_line to put an alias for a field
  28. self.env.ref('base_jsonify.category_id_name').write({
  29. 'alias': 'category_id:category/name'
  30. })
  31. expected_parser[4] = ('category_id:category', ['name'])
  32. parser = exporter.get_json_parser()
  33. self.assertEqual(parser, expected_parser)
  34. def test_json_export(self):
  35. parser = [
  36. 'lang',
  37. 'comment',
  38. 'credit_limit',
  39. 'name',
  40. 'color',
  41. ('child_ids:children', [
  42. ('child_ids:children', ['name']),
  43. 'email',
  44. ('country_id:country', ['code', 'name']),
  45. 'name',
  46. 'id',
  47. ]),
  48. ('country_id:country', ['code', 'name']),
  49. 'active',
  50. ('category_id', ['name']),
  51. 'create_date',
  52. 'date',
  53. ]
  54. partner = self.env['res.partner'].create({
  55. 'name': 'Akretion',
  56. 'country_id': self.env.ref('base.fr').id,
  57. 'lang': 'en_US', # default
  58. 'category_id': [(0, 0, {'name': 'Inovator'})],
  59. 'child_ids': [
  60. (0, 0, {
  61. 'name': 'Sebatien Beau',
  62. 'country_id': self.env.ref('base.fr').id
  63. })
  64. ],
  65. 'date': fields.Date.from_string("2019-10-31")
  66. })
  67. self.env.cr.execute(
  68. "update res_partner set create_date=%s where id=%s",
  69. ("2019-10-31 14:39:49", partner.id),
  70. )
  71. partner.refresh()
  72. expected_json = {
  73. 'lang': 'en_US',
  74. 'comment': None,
  75. 'credit_limit': 0.0,
  76. 'name': 'Akretion',
  77. 'color': 0,
  78. 'country': {
  79. 'code': 'FR',
  80. 'name': 'France'
  81. },
  82. 'active': True,
  83. 'category_id': [
  84. {'name': 'Inovator'}
  85. ],
  86. 'children': [{
  87. 'id': partner.child_ids.id,
  88. 'country': {
  89. 'code': 'FR',
  90. 'name': 'France'
  91. },
  92. 'children': [],
  93. 'name': 'Sebatien Beau',
  94. 'email': None
  95. }],
  96. "create_date": "2019-10-31T14:39:49+00:00",
  97. "date": "2019-10-31",
  98. }
  99. json_partner = partner.jsonify(parser)
  100. self.assertDictEqual(json_partner[0], expected_json)
  101. json_partner = partner.jsonify(parser)
  102. self.assertDictEqual(json_partner[0], expected_json)
  103. # Check that only boolean fields have boolean values into json
  104. # By default if a field is not set into Odoo, the value is always False
  105. # This value is not the expected one into the json
  106. partner.write({'child_ids': [(6, 0, [])],
  107. 'active': False,
  108. 'lang': False})
  109. json_partner = partner.jsonify(parser)
  110. expected_json['active'] = False
  111. expected_json['lang'] = None
  112. expected_json['children'] = []
  113. self.assertDictEqual(json_partner[0], expected_json)