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.

102 lines
4.0 KiB

  1. # -*- coding: utf-8 -*-
  2. # Copyright 2018 Tecnativa - David Vidal
  3. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  4. from odoo.tests import common
  5. @common.at_install(False)
  6. @common.post_install(True)
  7. class TestPOSOrderReturn(common.HttpCase):
  8. def setUp(self):
  9. super(TestPOSOrderReturn, self).setUp()
  10. self.partner = self.env['res.partner'].create({
  11. 'name': 'Mr. Odoo',
  12. })
  13. self.product_1 = self.env['product.product'].create({
  14. 'name': 'Test product 1',
  15. 'standard_price': 1.0,
  16. 'type': 'product',
  17. 'pos_allow_negative_qty': False,
  18. 'taxes_id': False,
  19. })
  20. self.product_2 = self.env['product.product'].create({
  21. 'name': 'Test product 2',
  22. 'standard_price': 1.0,
  23. 'type': 'product',
  24. 'pos_allow_negative_qty': True,
  25. 'taxes_id': False,
  26. })
  27. self.PosOrder = self.env['pos.order']
  28. self.pos_config = self.env.ref('point_of_sale.pos_config_main')
  29. self.pos_config.open_session_cb()
  30. self.pos_order = self.PosOrder.create({
  31. 'session_id': self.pos_config.current_session_id.id,
  32. 'partner_id': self.partner.id,
  33. 'pricelist_id': self.partner.property_product_pricelist.id,
  34. 'lines': [
  35. (0, 0, {
  36. 'name': 'POSLINE/0001',
  37. 'product_id': self.product_1.id,
  38. 'price_unit': 450,
  39. 'qty': 2.0,
  40. }),
  41. (0, 0, {
  42. 'name': 'POSLINE/0002',
  43. 'product_id': self.product_2.id,
  44. 'price_unit': 450,
  45. 'qty': 2.0,
  46. }),
  47. (0, 0, {
  48. 'name': 'POSLINE/0003',
  49. 'product_id': self.product_1.id,
  50. 'price_unit': 450,
  51. 'qty': 2.0,
  52. }),
  53. ],
  54. })
  55. pos_make_payment = self.env['pos.make.payment'].with_context({
  56. 'active_ids': [self.pos_order.id],
  57. 'active_id': self.pos_order.id,
  58. }).create({})
  59. pos_make_payment.with_context(active_id=self.pos_order.id).check()
  60. self.pos_order.create_picking()
  61. res = self.pos_order.action_pos_order_invoice()
  62. self.invoice = self.env['account.invoice'].browse(res['res_id'])
  63. def test_pos_order_full_refund(self):
  64. self.pos_order.refund()
  65. refund_order = self.pos_order.refund_order_ids
  66. self.assertEqual(len(refund_order), 1)
  67. pos_make_payment = self.env['pos.make.payment'].with_context({
  68. 'active_ids': refund_order.ids,
  69. 'active_id': refund_order.id,
  70. }).create({})
  71. pos_make_payment.with_context(active_id=refund_order.id).check()
  72. refund_invoice = refund_order.invoice_id
  73. self.assertEqual(refund_invoice.refund_invoice_id, self.invoice)
  74. # Partner balance is 0
  75. self.assertEqual(sum(
  76. self.partner.mapped('invoice_ids.amount_total_signed')), 0)
  77. def test_pos_order_partial_refund(self):
  78. partial_refund = self.env['pos.partial.return.wizard'].with_context({
  79. 'active_ids': self.pos_order.ids,
  80. 'active_id': self.pos_order.id,
  81. }).create({})
  82. # Return just 1 item from line POSLINE/0001
  83. partial_refund.line_ids[0].qty = 1
  84. # Return 2 items from line POSLINE/0003
  85. partial_refund.line_ids[1].qty = 2
  86. partial_refund.confirm()
  87. refund_order = self.pos_order.refund_order_ids
  88. self.assertEqual(len(refund_order), 1)
  89. self.assertEqual(len(refund_order.lines), 2)
  90. pos_make_payment = self.env['pos.make.payment'].with_context({
  91. 'active_ids': refund_order.ids,
  92. 'active_id': refund_order.id,
  93. }).create({})
  94. pos_make_payment.with_context(active_id=refund_order.id).check()
  95. # Partner balance is 1350
  96. self.assertEqual(sum(
  97. self.partner.mapped('invoice_ids.amount_total_signed')), 1350)