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.

81 lines
3.1 KiB

  1. # coding: utf-8
  2. # Copyright (C) 2017: Opener B.V. (https://opener.amsterdam)
  3. # @author: Stefan Rijnhart <stefan@opener.am>
  4. # License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
  5. from odoo import fields
  6. from odoo.tests.common import TransactionCase
  7. class TestPosPickingLoad(TransactionCase):
  8. def test_pos_picking_load(self):
  9. product = self.env.ref('product.product_product_24')
  10. # Create a Sale order and confirm it to generate a picking to load
  11. sale_order = self.env['sale.order'].create({
  12. 'partner_id': self.env.ref('base.res_partner_1').id,
  13. 'order_line': [(0, 0, {
  14. 'product_id': product.id,
  15. 'price_unit': 6,
  16. 'product_uom_qty': 2,
  17. })],
  18. })
  19. sale_order.action_confirm()
  20. self.assertTrue(sale_order.picking_ids)
  21. sale_order.picking_ids.picking_type_id.write({
  22. 'available_in_pos': True})
  23. # Configure Point of sale
  24. config = self.env.ref('point_of_sale.pos_config_main').copy()
  25. config.write({
  26. 'picking_type_id': sale_order.picking_ids.picking_type_id.id})
  27. # Open a new session
  28. session = self.env['pos.session'].create({
  29. 'user_id': self.env.user.id,
  30. 'config_id': config.id})
  31. session.signal_workflow('open')
  32. date_now = fields.Datetime.now()
  33. # Create a pos order
  34. self.env['pos.order'].create_from_ui([{
  35. 'to_invoice': False,
  36. 'data': {
  37. 'user_id': self.env.user.id,
  38. 'creation_date': date_now,
  39. 'fiscal_position_id': False,
  40. 'name': 'Order 00017-002-0003',
  41. 'partner_id': sale_order.partner_id.id,
  42. 'amount_paid': 12,
  43. 'pos_session_id': session.id,
  44. 'lines': [[0, 0, {
  45. 'product_id': product.id,
  46. 'price_unit': 6,
  47. 'name': product.name,
  48. 'discount': 0,
  49. 'qty': 2,
  50. 'tax_ids': [[6, False, []]],
  51. }]],
  52. 'statement_ids': [[0, 0, {
  53. 'journal_id': False,
  54. 'amount': 12,
  55. 'name': date_now,
  56. 'account_id': config.journal_ids[
  57. 0].default_debit_account_id.id,
  58. 'statement_id': session.statement_ids[0].id,
  59. }]],
  60. 'amount_tax': 0,
  61. 'origin_picking_id': sale_order.picking_ids.id,
  62. 'uid': '00017-002-0003',
  63. 'amount_return': 0,
  64. 'sequence_number': 3,
  65. 'amount_total': 12,
  66. },
  67. 'id': '00017-002-0003',
  68. }])
  69. pos_order = self.env['pos.order'].search(
  70. [('origin_picking_id', 'in', sale_order.picking_ids.ids)])
  71. self.assertTrue(pos_order)
  72. self.assertEqual(pos_order.origin_picking_id.state, 'cancel')
  73. self.assertIn(pos_order.picking_id, sale_order.picking_ids)
  74. self.assertEqual(
  75. pos_order.picking_id.group_id,
  76. pos_order.origin_picking_id.group_id)