mirror of
https://github.com/ForgeFlow/stock-rma.git
synced 2025-01-21 12:57:49 +02:00
[9.0][REW] rma_sale: complete rework of the tests (they didn't make sense at all before)
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © 2017 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
from . import test_rma
|
||||
from . import test_supplier_rma
|
||||
from . import test_rma_dropship
|
||||
|
||||
from . import test_rma_sale
|
||||
|
||||
@@ -1,470 +0,0 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © 2017 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
|
||||
from openerp.tests import common
|
||||
from openerp import fields
|
||||
|
||||
|
||||
class TestRma(common.TransactionCase):
|
||||
|
||||
""" Test the routes and the quantities """
|
||||
|
||||
def setUp(self):
|
||||
super(TestRma, self).setUp()
|
||||
|
||||
self.rma_make_picking = self.env['rma_make_picking.wizard']
|
||||
self.make_supplier_rma = self.env["rma.order.line.make.supplier.rma"]
|
||||
self.rma_add_stock_move = self.env['rma_add_stock_move']
|
||||
self.stockpicking = self.env['stock.picking']
|
||||
self.rma = self.env['rma.order']
|
||||
self.rma_line = self.env['rma.order.line']
|
||||
self.rma_op = self.env['rma.operation']
|
||||
self.rma_cust_replace_op_id = self.env.ref(
|
||||
'rma.rma_operation_customer_replace')
|
||||
self.rma_sup_replace_op_id = self.env.ref(
|
||||
'rma.rma_operation_supplier_replace')
|
||||
self.product_id = self.env.ref('product.product_product_4')
|
||||
self.product_1 = self.env.ref('product.product_product_25')
|
||||
self.product_2 = self.env.ref('product.product_product_7')
|
||||
self.product_3 = self.env.ref('product.product_product_11')
|
||||
self.uom_unit = self.env.ref('product.product_uom_unit')
|
||||
# assign an operation
|
||||
self.product_1.write(
|
||||
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id,
|
||||
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id})
|
||||
self.product_2.write(
|
||||
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id,
|
||||
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id})
|
||||
self.product_3.write(
|
||||
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id,
|
||||
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id})
|
||||
self.partner_id = self.env.ref('base.res_partner_12')
|
||||
self.stock_location = self.env.ref('stock.stock_location_stock')
|
||||
wh = self.env.ref('stock.warehouse0')
|
||||
self.stock_rma_location = wh.lot_rma_id
|
||||
self.customer_location = self.env.ref(
|
||||
'stock.stock_location_customers')
|
||||
self.supplier_location = self.env.ref(
|
||||
'stock.stock_location_suppliers')
|
||||
self.product_uom_id = self.env.ref('product.product_uom_unit')
|
||||
products2move = [(self.product_1, 3), (self.product_2, 5),
|
||||
(self.product_3, 2)]
|
||||
self.rma_customer_id = self._create_rma_from_move(
|
||||
products2move, 'customer', self.env.ref('base.res_partner_2'),
|
||||
dropship=False)
|
||||
|
||||
def _create_picking(self, partner):
|
||||
return self.stockpicking.create({
|
||||
'partner_id': partner.id,
|
||||
'picking_type_id': self.env.ref('stock.picking_type_in').id,
|
||||
'location_id': self.stock_location.id,
|
||||
'location_dest_id': self.supplier_location.id
|
||||
})
|
||||
|
||||
def _create_rma_from_move(self, products2move, type, partner, dropship,
|
||||
supplier_address_id=None):
|
||||
picking_in = self._create_picking(partner)
|
||||
|
||||
moves = []
|
||||
if type == 'customer':
|
||||
for item in products2move:
|
||||
move_values = self._prepare_move(
|
||||
item[0], item[1], self.stock_location,
|
||||
self.customer_location, picking_in)
|
||||
moves.append(self.env['stock.move'].create(move_values))
|
||||
else:
|
||||
for item in products2move:
|
||||
move_values = self._prepare_move(
|
||||
item[0], item[1], self.supplier_location,
|
||||
self.stock_rma_location, picking_in)
|
||||
moves.append(self.env['stock.move'].create(move_values))
|
||||
# Create the RMA from the stock_move
|
||||
rma_id = self.rma.create(
|
||||
{
|
||||
'reference': '0001',
|
||||
'type': type,
|
||||
'partner_id': partner.id,
|
||||
'company_id': self.env.ref('base.main_company').id
|
||||
})
|
||||
for move in moves:
|
||||
if type == 'customer':
|
||||
wizard = self.rma_add_stock_move.new(
|
||||
{'stock_move_id': move.id, 'customer': True,
|
||||
'active_ids': rma_id.id,
|
||||
'partner_id': move.partner_id.id,
|
||||
'active_model': 'rma.order',
|
||||
}
|
||||
)
|
||||
wizard.with_context({
|
||||
'stock_move_id': move.id, 'customer': True,
|
||||
'active_ids': rma_id.id,
|
||||
'partner_id': move.partner_id.id,
|
||||
'active_model': 'rma.order',
|
||||
})
|
||||
|
||||
data = wizard._prepare_rma_line_from_stock_move(move)
|
||||
data['partner_id'] = move.partner_id.id
|
||||
wizard.add_lines()
|
||||
|
||||
else:
|
||||
wizard = self.rma_add_stock_move.new(
|
||||
{'stock_move_id': move.id, 'supplier': True,
|
||||
'active_ids': rma_id.id,
|
||||
'partner_id': move.partner_id.id,
|
||||
'active_model': 'rma.order',
|
||||
}
|
||||
)
|
||||
wizard.with_context(
|
||||
{'stock_move_id': move.id, 'supplier': True,
|
||||
'active_ids': rma_id.id,
|
||||
'partner_id': move.partner_id.id,
|
||||
'active_model': 'rma.order',
|
||||
})
|
||||
|
||||
data = wizard._prepare_rma_line_from_stock_move(move)
|
||||
data['partner_id'] = move.partner_id.id
|
||||
wizard.add_lines()
|
||||
if dropship:
|
||||
data.update(customer_to_supplier=dropship,
|
||||
supplier_address_id=supplier_address_id.id)
|
||||
data['partner_id'] = move.partner_id.id
|
||||
data['rma_id'] = rma_id.id
|
||||
self.line = self.rma_line.create(data)
|
||||
# approve the RMA Line
|
||||
self.rma_line.action_rma_to_approve()
|
||||
self.line.action_rma_approve()
|
||||
rma_id._compute_in_shipment_count()
|
||||
rma_id._compute_out_shipment_count()
|
||||
rma_id._compute_supplier_line_count()
|
||||
rma_id._compute_line_count()
|
||||
rma_id.action_view_in_shipments()
|
||||
rma_id.action_view_out_shipments()
|
||||
rma_id.action_view_lines()
|
||||
|
||||
rma_id.partner_id.action_open_partner_rma()
|
||||
rma_id.partner_id._compute_rma_line_count()
|
||||
# approve the RMA
|
||||
# rma_id.action_rma_to_approve()
|
||||
# rma_id.action_rma_approve()
|
||||
return rma_id
|
||||
|
||||
def _prepare_move(self, product, qty, src, dest, picking_in):
|
||||
res = {
|
||||
'partner_id': self.partner_id.id,
|
||||
'product_id': product.id,
|
||||
'name': product.partner_ref,
|
||||
'state': 'confirmed',
|
||||
'product_uom': self.product_uom_id.id or product.uom_id.id,
|
||||
'product_uom_qty': qty,
|
||||
'origin': 'Test RMA',
|
||||
'location_id': src.id,
|
||||
'location_dest_id': dest.id,
|
||||
'picking_id': picking_in.id
|
||||
}
|
||||
return res
|
||||
|
||||
def test_add_sale(self):
|
||||
wizard = self.env['rma_add_sale'].with_context({
|
||||
'active_ids': self.rma_customer_id.ids,
|
||||
'active_model': 'rma.order',
|
||||
'active_id': self.rma_customer_id.id
|
||||
}).create({'partner_id': self.partner_id.id,
|
||||
'rma_id': self.rma_customer_id.id,
|
||||
'sale_id': self._create_sale_order().id,
|
||||
'sale_line_ids':
|
||||
[(6, 0, [self._create_sale_order().order_line.id])],
|
||||
})
|
||||
wizard.default_get([str(self._create_sale_order().id),
|
||||
str(self._create_sale_order().order_line.id),
|
||||
str(self.partner_id.id)])
|
||||
wizard.add_lines()
|
||||
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
line._compute_qty_to_sell()
|
||||
line.sale_type = 'ordered'
|
||||
line._compute_qty_to_sell()
|
||||
line.sale_type = 'received'
|
||||
line._compute_qty_to_sell()
|
||||
line._compute_qty_sold()
|
||||
line._compute_sales_count()
|
||||
|
||||
data = {'sale_line_id': self._create_sale_order().order_line.id}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_sale_line_id()
|
||||
|
||||
line.action_view_sale_order()
|
||||
self.rma_customer_id.\
|
||||
_get_line_domain(self.rma_customer_id,
|
||||
self.rma_customer_id.rma_line_ids[3])
|
||||
self.rma_customer_id._compute_sales_count()
|
||||
self.rma_customer_id.action_view_sale_order()
|
||||
|
||||
def test_rma_order_line_make_sale_order(self):
|
||||
|
||||
self.rma_sale_order_item =\
|
||||
self.env['rma.order.line.make.sale.order.item']
|
||||
self.rma_sale_order = self.env['rma.order.line.make.sale.order']
|
||||
|
||||
self.product_id.income =\
|
||||
self.env.ref('account.data_account_type_receivable').id
|
||||
self.product_id.expense =\
|
||||
self.env.ref('account.data_account_type_expenses').id
|
||||
|
||||
sale_order = self.rma_sale_order.with_context({
|
||||
'active_ids': self.rma_customer_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'active_id': 1
|
||||
}).create({'sale_order_id': self._create_sale_order().id,
|
||||
'partner_id': self.partner_id.id,
|
||||
})
|
||||
self.rma_sale_order_item.create({
|
||||
'line_id': self.rma_customer_id.rma_line_ids[0].id,
|
||||
'rma_id': self.rma_customer_id.id,
|
||||
'product_id': self.product_id.id,
|
||||
'name': 'Test RMA Refund',
|
||||
'product_qty': self.rma_customer_id.rma_line_ids[0].product_qty,
|
||||
'wiz_id': sale_order.id
|
||||
})
|
||||
for line in sale_order.item_ids:
|
||||
line.product_qty = self.rma_customer_id.rma_line_ids[0].product_qty
|
||||
sale_order.make_sale_order()
|
||||
sale_order.write({'sale_order_id': False})
|
||||
sale_order.make_sale_order()
|
||||
|
||||
def test_rma_refund(self):
|
||||
|
||||
self.rma_refund_item = self.env['rma.refund.item']
|
||||
self.rma_refund = self.env['rma.refund']
|
||||
|
||||
self.product_id.income =\
|
||||
self.env.ref('account.data_account_type_receivable').id
|
||||
self.product_id.expense =\
|
||||
self.env.ref('account.data_account_type_expenses').id
|
||||
|
||||
self.product_id.product_tmpl_id.categ_id.\
|
||||
property_stock_account_input_categ_id =\
|
||||
self.env.ref('account.data_account_type_receivable').id
|
||||
self.product_id.product_tmpl_id.categ_id.\
|
||||
property_stock_account_output_categ_id =\
|
||||
self.env.ref('account.data_account_type_expenses').id
|
||||
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
line.refund_policy = 'ordered'
|
||||
|
||||
refund = self.rma_refund.with_context({
|
||||
'active_ids': self.rma_customer_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'active_id': 1
|
||||
}).create({'description': 'Test Reason',
|
||||
'date_invoice': fields.datetime.now()
|
||||
})
|
||||
self.rma_refund_item.create({
|
||||
'line_id': self.rma_customer_id.rma_line_ids[0].id,
|
||||
'rma_id': self.rma_customer_id.id,
|
||||
'product_id': self.product_id.id,
|
||||
'name': 'Test RMA Refund',
|
||||
'product_qty': self.rma_customer_id.rma_line_ids[0].product_qty,
|
||||
'wiz_id': refund.id
|
||||
})
|
||||
|
||||
def _create_sale_order(self):
|
||||
self.sale_order_id = self.env['sale.order'].create({
|
||||
'partner_id': self.partner_id.id,
|
||||
'partner_invoice_id': self.partner_id.id,
|
||||
'partner_shipping_id': self.partner_id.id,
|
||||
'order_line': [(0, 0, {
|
||||
'name': self.product_id.name,
|
||||
'product_id': self.product_id.id,
|
||||
'product_uom_qty':
|
||||
self.rma_customer_id.rma_line_ids[0].product_qty,
|
||||
'price_unit': 100.00,
|
||||
})]
|
||||
})
|
||||
self.env["sale.order.line"].\
|
||||
name_search(name=self.product_id.name, operator='ilike',
|
||||
args=[('id', 'in', self.sale_order_id.order_line.ids)])
|
||||
self.env["sale.order.line"].\
|
||||
_name_search(name=self.product_id.name, operator='ilike',
|
||||
args=[('id', 'in', self.sale_order_id.order_line.ids)
|
||||
])
|
||||
self.sale_order_id.order_line._prepare_order_line_procurement()
|
||||
return self.sale_order_id
|
||||
|
||||
def test_rma_order_line(self):
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
line.with_context({'default_rma_id': line.rma_id.id
|
||||
})._default_warehouse_id()
|
||||
line._default_location_id()
|
||||
line.with_context({'partner_id': line.rma_id.partner_id.id
|
||||
})._default_delivery_address()
|
||||
line._compute_in_shipment_count()
|
||||
line._compute_out_shipment_count()
|
||||
line._compute_procurement_count()
|
||||
|
||||
data = {'reference_move_id': line.reference_move_id.id}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_reference_move_id()
|
||||
|
||||
line.action_rma_to_approve()
|
||||
line.action_rma_draft()
|
||||
line.action_rma_done()
|
||||
|
||||
data = {'product_id': line.product_id.id}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_product_id()
|
||||
|
||||
data = {'operation_id': line.operation_id.id}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_operation_id()
|
||||
|
||||
data = {'customer_to_supplier': line.customer_to_supplier}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_receipt_policy()
|
||||
|
||||
data = {'lot_id': line.lot_id.id}
|
||||
new_line = self.rma_line.new(data)
|
||||
new_line._onchange_lot_id()
|
||||
|
||||
line.action_view_in_shipments()
|
||||
line.action_view_out_shipments()
|
||||
line.action_view_procurements()
|
||||
|
||||
def test_customer_rma(self):
|
||||
wizard = self.rma_make_picking.with_context({
|
||||
'active_ids': self.rma_customer_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'picking_type': 'incoming',
|
||||
'active_id': 1
|
||||
}).create({})
|
||||
procurements = wizard._create_picking()
|
||||
group_ids = set([proc.group_id.id for proc in procurements if
|
||||
proc.group_id])
|
||||
domain = [('group_id', 'in', list(group_ids))]
|
||||
picking = self.stockpicking.search(domain)
|
||||
self.assertEquals(len(picking), 1,
|
||||
"Incorrect number of pickings created")
|
||||
moves = picking.move_lines
|
||||
self.assertEquals(len(moves), 3,
|
||||
"Incorrect number of moves created")
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
# common qtys for all products
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty delivered")
|
||||
# product specific
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
picking.action_assign()
|
||||
picking.do_new_transfer()
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty delivered")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_to_deliver, 3,
|
||||
"Wrong qty to_deliver")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_to_deliver, 5,
|
||||
"Wrong qty to_deliver")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_to_deliver, 2,
|
||||
"Wrong qty to_deliver")
|
||||
|
||||
wizard = self.rma_make_picking.with_context({
|
||||
'active_id': 1,
|
||||
'active_ids': self.rma_customer_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'picking_type': 'outgoing',
|
||||
}).create({})
|
||||
procurements = wizard._create_picking()
|
||||
group_ids = set([proc.group_id.id for proc in procurements if
|
||||
proc.group_id])
|
||||
domain = [('group_id', 'in', list(group_ids))]
|
||||
pickings = self.stockpicking.search(domain)
|
||||
self.assertEquals(len(pickings), 2,
|
||||
"Incorrect number of pickings created")
|
||||
picking_out = pickings[1]
|
||||
moves = picking_out.move_lines
|
||||
self.assertEquals(len(moves), 3,
|
||||
"Incorrect number of moves created")
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty delivered")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_deliver, 3,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 6,
|
||||
"Wrong qty outgoing")
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_to_deliver, 5,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 10,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_to_deliver, 2,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 4,
|
||||
"Wrong qty outgoing")
|
||||
picking_out.action_assign()
|
||||
picking_out.do_new_transfer()
|
||||
for line in self.rma_customer_id.rma_line_ids:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty deliver")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to received")
|
||||
self.assertEquals(line.qty_to_deliver, 3,
|
||||
"Wrong qty to delivered")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to received")
|
||||
self.assertEquals(line.qty_to_deliver, 5,
|
||||
"Wrong qty to delivered")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to received")
|
||||
self.assertEquals(line.qty_to_deliver, 2,
|
||||
"Wrong qty to delivered")
|
||||
self.line.action_rma_done()
|
||||
self.assertEquals(self.line.state, 'done',
|
||||
"Wrong State")
|
||||
@@ -1,96 +0,0 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © 2017 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
|
||||
from . import test_rma
|
||||
|
||||
|
||||
class TestRmaDropship(test_rma.TestRma):
|
||||
|
||||
def setUp(self):
|
||||
super(TestRmaDropship, self).setUp()
|
||||
products2move = [(self.product_1, 3), (self.product_2, 5),
|
||||
(self.product_3, 2)]
|
||||
self.rma_droship_id = self._create_rma_from_move(
|
||||
products2move, 'customer', self.env.ref('base.res_partner_2'),
|
||||
dropship=True,
|
||||
supplier_address_id=self.env.ref('base.res_partner_3'))
|
||||
|
||||
def test_dropship(self):
|
||||
wizard = self.make_supplier_rma.with_context({
|
||||
'active_ids': self.rma_droship_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'active_id': 1
|
||||
}).create({})
|
||||
res = wizard.make_supplier_rma()
|
||||
supplier_rma = self.rma.browse(res['res_id'])
|
||||
for line in supplier_rma.rma_line_ids:
|
||||
line.action_rma_to_approve()
|
||||
line.action_rma_approve()
|
||||
wizard = self.rma_make_picking.with_context({
|
||||
'active_id': 1,
|
||||
'active_ids': supplier_rma.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'picking_type': 'incoming',
|
||||
}).create({})
|
||||
procurements = wizard._create_picking()
|
||||
group_ids = set([proc.group_id.id for proc in procurements if
|
||||
proc.group_id])
|
||||
domain = [('group_id', 'in', list(group_ids))]
|
||||
picking = self.stockpicking.search(domain)
|
||||
self.assertEquals(len(picking), 1,
|
||||
"Incorrect number of pickings created")
|
||||
moves = picking.move_lines
|
||||
self.assertEquals(len(moves), 3,
|
||||
"Incorrect number of moves created")
|
||||
for line in supplier_rma.rma_line_ids:
|
||||
# common qtys for all products
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_outgoing, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty delivered")
|
||||
# product specific
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 3,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_incoming, 3,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 5,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_incoming, 5,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 2,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_incoming, 2,
|
||||
"Wrong qty outgoing")
|
||||
|
||||
for line in self.rma_droship_id.rma_line_ids:
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_supplier_rma, 0,
|
||||
"Wrong qty to supplier rma")
|
||||
self.assertEquals(line.qty_in_supplier_rma, 3,
|
||||
"Wrong qty in supplier rma")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_supplier_rma, 0,
|
||||
"Wrong qty to supplier rma")
|
||||
self.assertEquals(line.qty_in_supplier_rma, 5,
|
||||
"Wrong qty in supplier rma")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_supplier_rma, 0,
|
||||
"Wrong qty to supplier rma")
|
||||
self.assertEquals(line.qty_in_supplier_rma, 2,
|
||||
"Wrong qty in supplier rma")
|
||||
for line in self.rma_droship_id.rma_line_ids:
|
||||
line.action_rma_done()
|
||||
self.assertEquals(line.state, 'done',
|
||||
"Wrong State")
|
||||
154
rma_sale/tests/test_rma_sale.py
Normal file
154
rma_sale/tests/test_rma_sale.py
Normal file
@@ -0,0 +1,154 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# Copyright 2017-18 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
|
||||
from openerp.tests import common
|
||||
|
||||
|
||||
class TestRmaSale(common.SingleTransactionCase):
|
||||
|
||||
@classmethod
|
||||
def setUpClass(cls):
|
||||
super(TestRmaSale, cls).setUpClass()
|
||||
|
||||
cls.rma_obj = cls.env['rma.order']
|
||||
cls.rma_line_obj = cls.env['rma.order.line']
|
||||
cls.rma_op_obj = cls.env['rma.operation']
|
||||
cls.rma_add_sale_wiz = cls.env['rma_add_sale']
|
||||
cls.rma_make_sale_wiz = cls.env['rma.order.line.make.sale.order']
|
||||
cls.so_obj = cls.env['sale.order']
|
||||
cls.sol_obj = cls.env['sale.order.line']
|
||||
cls.product_obj = cls.env['product.product']
|
||||
cls.partner_obj = cls.env['res.partner']
|
||||
|
||||
cls.rma_route_cust = cls.env.ref('rma.route_rma_customer')
|
||||
|
||||
# Create customer
|
||||
customer1 = cls.partner_obj.create({'name': 'Customer 1'})
|
||||
|
||||
# Create products
|
||||
cls.product_1 = cls.product_obj.create({
|
||||
'name': 'Test Product 1',
|
||||
'type': 'product',
|
||||
'list_price': 100.0,
|
||||
})
|
||||
cls.product_2 = cls.product_obj.create({
|
||||
'name': 'Test Product 2',
|
||||
'type': 'product',
|
||||
'list_price': 150.0,
|
||||
})
|
||||
|
||||
# Create SO:
|
||||
cls.so = cls.so_obj.create({
|
||||
'partner_id': customer1.id,
|
||||
'partner_invoice_id': customer1.id,
|
||||
'partner_shipping_id': customer1.id,
|
||||
'order_line': [
|
||||
(0, 0, {
|
||||
'name': cls.product_1.name,
|
||||
'product_id': cls.product_1.id,
|
||||
'product_uom_qty': 20.0,
|
||||
'product_uom': cls.product_1.uom_id.id,
|
||||
'price_unit': cls.product_1.list_price
|
||||
}),
|
||||
(0, 0, {
|
||||
'name': cls.product_2.name,
|
||||
'product_id': cls.product_2.id,
|
||||
'product_uom_qty': 18.0,
|
||||
'product_uom': cls.product_2.uom_id.id,
|
||||
'price_unit': cls.product_2.list_price
|
||||
}),
|
||||
],
|
||||
'pricelist_id': cls.env.ref('product.list0').id,
|
||||
})
|
||||
|
||||
# Create RMA group and operation:
|
||||
cls.rma_group = cls.rma_obj.create({
|
||||
'partner_id': customer1.id,
|
||||
})
|
||||
cls.operation_1 = cls.rma_op_obj.create({
|
||||
'code': 'TEST',
|
||||
'name': 'Sale afer receive',
|
||||
'type': 'customer',
|
||||
'receipt_policy': 'ordered',
|
||||
'sale_policy': 'received',
|
||||
'in_route_id': cls.rma_route_cust.id,
|
||||
'out_route_id': cls.rma_route_cust.id,
|
||||
})
|
||||
cls.operation_2 = cls.rma_op_obj.create({
|
||||
'code': 'TEST',
|
||||
'name': 'Receive and Sale',
|
||||
'type': 'customer',
|
||||
'receipt_policy': 'ordered',
|
||||
'sale_policy': 'ordered',
|
||||
'in_route_id': cls.rma_route_cust.id,
|
||||
'out_route_id': cls.rma_route_cust.id,
|
||||
})
|
||||
|
||||
def test_01_add_from_sale_order(self):
|
||||
"""Test wizard to create RMA from Sales Orders."""
|
||||
add_sale = self.rma_add_sale_wiz.with_context({
|
||||
'customer': True,
|
||||
'active_ids': self.rma_group.id,
|
||||
'active_model': 'rma.order',
|
||||
}).create({
|
||||
'sale_id': self.so.id,
|
||||
'sale_line_ids': [(6, 0, self.so.order_line.ids)],
|
||||
})
|
||||
add_sale.add_lines()
|
||||
self.assertEqual(len(self.rma_group.rma_line_ids), 2)
|
||||
|
||||
def test_02_rma_sale_operation(self):
|
||||
"""Test RMA quantities using sale operations."""
|
||||
# Received sale_policy:
|
||||
rma_1 = self.rma_group.rma_line_ids.filtered(
|
||||
lambda r: r.product_id == self.product_1)
|
||||
rma_1.write({
|
||||
'operation_id': self.operation_1.id,
|
||||
})
|
||||
rma_1._onchange_operation_id()
|
||||
self.assertEqual(rma_1.sale_policy, 'received')
|
||||
self.assertEqual(rma_1.qty_to_sell, 0.0)
|
||||
# TODO: receive and check qty_to_sell is 20.0
|
||||
# Ordered sale_policy:
|
||||
rma_2 = self.rma_group.rma_line_ids.filtered(
|
||||
lambda r: r.product_id == self.product_2)
|
||||
rma_2.write({
|
||||
'operation_id': self.operation_2.id,
|
||||
})
|
||||
rma_2._onchange_operation_id()
|
||||
self.assertEqual(rma_2.sale_policy, 'ordered')
|
||||
self.assertEqual(rma_2.qty_to_sell, 18.0)
|
||||
|
||||
def test_03_rma_create_sale(self):
|
||||
"""Generate a Sales Order from a customer RMA."""
|
||||
rma = self.rma_group.rma_line_ids.filtered(
|
||||
lambda r: r.product_id == self.product_2)
|
||||
self.assertEqual(rma.sales_count, 0)
|
||||
self.assertEqual(rma.qty_to_sell, 18.0)
|
||||
self.assertEqual(rma.qty_sold, 0.0)
|
||||
make_sale = self.rma_make_sale_wiz.with_context({
|
||||
'customer': True,
|
||||
'active_ids': rma.id,
|
||||
'active_model': 'rma.order.line',
|
||||
}).create({
|
||||
'partner_id': rma.partner_id.id,
|
||||
})
|
||||
make_sale.make_sale_order()
|
||||
self.assertEqual(rma.sales_count, 1)
|
||||
rma.sale_line_ids.order_id.action_confirm()
|
||||
self.assertEqual(rma.qty_to_sell, 0.0)
|
||||
self.assertEqual(rma.qty_sold, 18.0)
|
||||
|
||||
def test_04_fill_rma_from_so_line(self):
|
||||
"""Test filling a RMA (line) from a Sales Order line."""
|
||||
so_line = self.so.order_line.filtered(
|
||||
lambda r: r.product_id == self.product_1)
|
||||
rma = self.rma_line_obj.new({
|
||||
'partner_id': self.so.partner_id.id,
|
||||
'sale_line_id': so_line.id,
|
||||
})
|
||||
self.assertFalse(rma.product_id)
|
||||
rma._onchange_sale_line_id()
|
||||
self.assertEqual(rma.product_id, self.product_1)
|
||||
self.assertEqual(rma.product_qty, 20.0)
|
||||
@@ -1,156 +0,0 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
# © 2017 Eficent Business and IT Consulting Services S.L.
|
||||
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
|
||||
|
||||
from . import test_rma
|
||||
|
||||
|
||||
class TestSupplierRma(test_rma.TestRma):
|
||||
|
||||
def setUp(self):
|
||||
super(TestSupplierRma, self).setUp()
|
||||
products2move = [(self.product_1, 3), (self.product_2, 5),
|
||||
(self.product_3, 2)]
|
||||
self.rma_supplier_id = self._create_rma_from_move(
|
||||
products2move, 'supplier', self.env.ref('base.res_partner_1'),
|
||||
dropship=False)
|
||||
|
||||
def test_supplier_rma(self):
|
||||
wizard = self.rma_make_picking.with_context({
|
||||
'active_ids': self.rma_supplier_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'picking_type': 'outgoing',
|
||||
'active_id': 1
|
||||
}).create({})
|
||||
procurements = wizard._create_picking()
|
||||
group_ids = set([proc.group_id.id for proc in procurements if
|
||||
proc.group_id])
|
||||
domain = [('group_id', 'in', list(group_ids))]
|
||||
picking = self.stockpicking.search(domain)
|
||||
self.assertEquals(len(picking), 1,
|
||||
"Incorrect number of pickings created")
|
||||
moves = picking.move_lines
|
||||
self.assertEquals(len(moves), 3,
|
||||
"Incorrect number of moves created")
|
||||
for line in self.rma_supplier_id.rma_line_ids:
|
||||
# common qtys for all products
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 0,
|
||||
"Wrong qty delivered")
|
||||
# product specific
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 3,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 3,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 5,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 5,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_to_deliver, 2,
|
||||
"Wrong qty to deliver")
|
||||
self.assertEquals(line.qty_outgoing, 2,
|
||||
"Wrong qty outgoing")
|
||||
|
||||
picking.action_assign()
|
||||
picking.do_transfer()
|
||||
for line in self.rma_supplier_id.rma_line_ids:
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_delivered, 3,
|
||||
"Wrong qty delivered")
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_delivered, 5,
|
||||
"Wrong qty delivered")
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to receive")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_delivered, 2,
|
||||
"Wrong qty delivered")
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to receive")
|
||||
wizard = self.rma_make_picking.with_context({
|
||||
'active_id': 1,
|
||||
'active_ids': self.rma_supplier_id.rma_line_ids.ids,
|
||||
'active_model': 'rma.order.line',
|
||||
'picking_type': 'incoming',
|
||||
}).create({})
|
||||
procurements = wizard._create_picking()
|
||||
group_ids = set([proc.group_id.id for proc in procurements if
|
||||
proc.group_id])
|
||||
domain = [('group_id', 'in', list(group_ids))]
|
||||
pickings = self.stockpicking.search(domain)
|
||||
self.assertEquals(len(pickings), 2,
|
||||
"Incorrect number of pickings created")
|
||||
picking_out = pickings[1]
|
||||
moves = picking_out.move_lines
|
||||
self.assertEquals(len(moves), 3,
|
||||
"Incorrect number of moves created")
|
||||
for line in self.rma_supplier_id.rma_line_ids:
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_delivered, 3,
|
||||
"Wrong qty delivered")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_to_receive, 5,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_delivered, 5,
|
||||
"Wrong qty deliver")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_to_receive, 2,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_delivered, 2,
|
||||
"Wrong qty deliver")
|
||||
picking_out.action_assign()
|
||||
picking_out.do_transfer()
|
||||
for line in self.rma_supplier_id.rma_line_ids[0]:
|
||||
self.assertEquals(line.qty_to_receive, 3,
|
||||
"Wrong qty to receive")
|
||||
self.assertEquals(line.qty_incoming, 0,
|
||||
"Wrong qty incoming")
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty receive")
|
||||
self.assertEquals(line.qty_outgoing, 0,
|
||||
"Wrong qty outgoing")
|
||||
if line.product_id == self.product_1:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_delivered, 6,
|
||||
"Wrong qty delivered")
|
||||
if line.product_id == self.product_2:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_delivered, 10,
|
||||
"Wrong qty delivered")
|
||||
if line.product_id == self.product_3:
|
||||
self.assertEquals(line.qty_received, 0,
|
||||
"Wrong qty received")
|
||||
self.assertEquals(line.qty_delivered, 4,
|
||||
"Wrong qty delivered")
|
||||
for line in self.rma_supplier_id.rma_line_ids:
|
||||
line.action_rma_done()
|
||||
self.assertEquals(line.state, 'done',
|
||||
"Wrong State")
|
||||
Reference in New Issue
Block a user