[FIX]various fixes

This commit is contained in:
aheficent
2018-01-02 13:05:09 +01:00
committed by Mateu Griful
parent 1c206cc221
commit 66d5d0651a
5 changed files with 206 additions and 55 deletions

View File

@@ -23,6 +23,10 @@ class ProcurementOrder(models.Model):
res['partner_id'] = line.delivery_address_id.id res['partner_id'] = line.delivery_address_id.id
else: else:
res['partner_id'] = line.rma_id.partner_id.id res['partner_id'] = line.rma_id.partner_id.id
dest_loc = self.env["stock.location"].browse([
res["location_dest_id"]])[0]
if dest_loc.usage == "internal":
res["price_unit"] = line.price_unit
return res return res

View File

@@ -144,7 +144,8 @@ class RmaOrderLine(models.Model):
def _compute_qty_supplier_rma(self): def _compute_qty_supplier_rma(self):
for rec in self: for rec in self:
qty = rec._get_supplier_rma_qty() qty = rec._get_supplier_rma_qty()
rec.qty_to_supplier_rma = rec.qty_to_receive - qty rec.qty_to_supplier_rma = (rec.qty_to_receive - qty
if rec.customer_to_supplier else 0)
rec.qty_in_supplier_rma = qty rec.qty_in_supplier_rma = qty
@api.multi @api.multi
@@ -433,11 +434,14 @@ class RmaOrderLine(models.Model):
def _check_move_partner(self): def _check_move_partner(self):
for rec in self: for rec in self:
if (rec.reference_move_id and if (rec.reference_move_id and
rec.reference_move_id.picking_id.partner_id != (rec.reference_move_id.partner_id != rec.partner_id) and
rec.partner_id): (rec.reference_move_id.picking_id.partner_id !=
raise ValidationError(_( rec.partner_id)):
"RMA customer and originating stock move customer " raise ValidationError(_(
"doesn't match.")) "RMA customer (%s) and originating stock move customer"
" (%s) doesn't match." % (
rec.reference_move_id.partner_id.name,
rec.partner_id.name)))
@api.multi @api.multi
def _remove_other_data_origin(self, exception): def _remove_other_data_origin(self, exception):

View File

@@ -26,8 +26,8 @@ class TestRma(common.TransactionCase):
'rma.rma_operation_supplier_replace') 'rma.rma_operation_supplier_replace')
self.product_id = self.env.ref('product.product_product_4') self.product_id = self.env.ref('product.product_product_4')
self.product_1 = self.env.ref('product.product_product_25') self.product_1 = self.env.ref('product.product_product_25')
self.product_2 = self.env.ref('product.product_product_30') self.product_2 = self.env.ref('product.product_product_7')
self.product_3 = self.env.ref('product.product_product_33') self.product_3 = self.env.ref('product.product_product_11')
self.uom_unit = self.env.ref('product.product_uom_unit') self.uom_unit = self.env.ref('product.product_uom_unit')
# assign an operation # assign an operation
self.product_1.write( self.product_1.write(
@@ -50,23 +50,33 @@ class TestRma(common.TransactionCase):
products2move = [(self.product_1, 3), (self.product_2, 5), products2move = [(self.product_1, 3), (self.product_2, 5),
(self.product_3, 2)] (self.product_3, 2)]
self.rma_customer_id = self._create_rma_from_move( self.rma_customer_id = self._create_rma_from_move(
products2move, 'customer', self.env.ref('base.res_partner_2'), products2move, 'customer', self.partner_id,
dropship=False) 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, def _create_rma_from_move(self, products2move, type, partner, dropship,
supplier_address_id=None): supplier_address_id=None):
picking_in = self._create_picking(partner)
moves = [] moves = []
if type == 'customer': if type == 'customer':
for item in products2move: for item in products2move:
move_values = self._prepare_move( move_values = self._prepare_move(
item[0], item[1], self.stock_location, item[0], item[1], self.stock_location,
self.customer_location) self.customer_location, picking_in)
moves.append(self.env['stock.move'].create(move_values)) moves.append(self.env['stock.move'].create(move_values))
else: else:
for item in products2move: for item in products2move:
move_values = self._prepare_move( move_values = self._prepare_move(
item[0], item[1], self.supplier_location, item[0], item[1], self.supplier_location,
self.stock_rma_location) self.stock_rma_location, picking_in)
moves.append(self.env['stock.move'].create(move_values)) moves.append(self.env['stock.move'].create(move_values))
# Create the RMA from the stock_move # Create the RMA from the stock_move
rma_id = self.rma.create( rma_id = self.rma.create(
@@ -78,32 +88,97 @@ class TestRma(common.TransactionCase):
}) })
for move in moves: for move in moves:
if type == 'customer': if type == 'customer':
wizard = self.rma_add_stock_move.with_context( wizard = self.rma_add_stock_move.new(
{'stock_move_id': move.id, 'customer': True, {'stock_move_id': move.id, 'customer': True,
'active_ids': rma_id.id, 'active_ids': rma_id.id,
'partner_id': move.partner_id.id,
'active_model': 'rma.order', 'active_model': 'rma.order',
} }
).create({}) )
data = wizard._prepare_rma_line_from_stock_move(move) 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',
}).default_get({[str(rma_id.id),
str(self.partner_id.id)]})
data = wizard.with_context(customer=1).\
_prepare_rma_line_from_stock_move(move)
wizard.add_lines()
for operation in move.product_id.rma_customer_operation_id:
operation.in_route_id = False
move.product_id.categ_id.rma_customer_operation_id = False
move.product_id.rma_customer_operation_id = False
wizard._prepare_rma_line_from_stock_move(move)
else: else:
wizard = self.rma_add_stock_move.with_context( wizard = self.rma_add_stock_move.new(
{'stock_move_id': move.id, 'supplier': True, {'stock_move_id': move.id, 'supplier': True,
'active_ids': rma_id.id, 'active_ids': rma_id.id,
'partner_id': move.partner_id.id,
'active_model': 'rma.order', 'active_model': 'rma.order',
} }
).create({}) )
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',
}).default_get({[str(rma_id.id),
str(self.partner_id.id)]})
wizard._prepare_rma_line_from_stock_move(move)
wizard.add_lines()
wizard = self.rma_add_stock_move.new(
{'stock_move_id': move.id, 'supplier': True,
'active_ids': [],
'partner_id': move.partner_id.id,
'active_model': 'rma.order',
}
)
wizard.add_lines()
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',
}
)
data = wizard._prepare_rma_line_from_stock_move(move) data = wizard._prepare_rma_line_from_stock_move(move)
for operation in move.product_id.rma_customer_operation_id:
operation.in_route_id = False
move.product_id.rma_customer_operation_id = False
wizard.add_lines()
if dropship: if dropship:
data.update(customer_to_supplier=dropship, data.update(customer_to_supplier=dropship,
supplier_address_id=supplier_address_id.id) supplier_address_id=supplier_address_id.id)
self.rma_line.create(data) 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._get_default_type()
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 # approve the RMA
rma_id.action_rma_to_approve() for line in rma_id.rma_line_ids:
rma_id.action_rma_approve() line.action_rma_to_approve()
line.action_rma_approve()
return rma_id return rma_id
def _prepare_move(self, product, qty, src, dest): def _prepare_move(self, product, qty, src, dest, picking_in):
res = { res = {
'partner_id': self.partner_id.id,
'product_id': product.id, 'product_id': product.id,
'name': product.partner_ref, 'name': product.partner_ref,
'state': 'confirmed', 'state': 'confirmed',
@@ -112,16 +187,86 @@ class TestRma(common.TransactionCase):
'origin': 'Test RMA', 'origin': 'Test RMA',
'location_id': src.id, 'location_id': src.id,
'location_dest_id': dest.id, 'location_dest_id': dest.id,
'picking_id': picking_in.id
} }
return res return res
def test_rma_order_line(self):
partner2 = self.env.ref('base.res_partner_2')
picking_in = self._create_picking(partner2)
moves_1 = []
move_values = self._prepare_move(self.product_1, 3,
self.stock_location,
self.customer_location, picking_in)
moves_1.append(self.env['stock.move'].create(move_values))
wizard_1 = self.rma_add_stock_move.new(
{'supplier': True,
'stock_move_id': [(6, 0, [m.id for m in moves_1])],
'active_ids': self.rma_customer_id.id,
'active_model': 'rma.order',
'partner_id': self.partner_id.id,
'move_ids': [(6, 0, [m.id for m in moves_1])]
}
)
wizard_1.add_lines()
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()
self.rma_customer_id.action_view_supplier_lines()
with self.assertRaises(ValidationError):
line.rma_id.partner_id = partner2.id
self.rma_customer_id.rma_line_ids[0].\
partner_id = partner2.id
self.rma_customer_id.action_view_supplier_lines()
def test_customer_rma(self): def test_customer_rma(self):
wizard = self.rma_make_picking.with_context({ wizard = self.rma_make_picking.with_context({
'active_ids': self.rma_customer_id.rma_line_ids.ids, 'active_ids': self.rma_customer_id.rma_line_ids.ids,
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'incoming', 'picking_type': 'incoming',
'active_id': 1 'active_id': 1
}).create({}) }).create({'rma_id': self.rma_customer_id.id})
wizard.with_context({
'active_ids': self.rma_customer_id.rma_line_ids.ids,
'active_model': 'rma.order.line',
'picking_type': 'incoming',
'active_id': 1
}).default_get({})
procurements = wizard._create_picking() procurements = wizard._create_picking()
group_ids = set([proc.group_id.id for proc in procurements if group_ids = set([proc.group_id.id for proc in procurements if
proc.group_id]) proc.group_id])
@@ -136,24 +281,28 @@ class TestRma(common.TransactionCase):
# common qtys for all products # common qtys for all products
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_received, 0,
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_to_deliver, 0,
"Wrong qty to deliver")
self.assertEquals(line.qty_outgoing, 0, self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing") "Wrong qty outgoing")
self.assertEquals(line.qty_delivered, 0, self.assertEquals(line.qty_delivered, 0,
"Wrong qty delivered") "Wrong qty delivered")
# product specific # product specific
if line.product_id == self.product_1: if line.product_id == self.product_1:
self.assertEquals(line.qty_to_deliver, 3,
"Wrong qty to deliver")
self.assertEquals(line.qty_to_receive, 3, self.assertEquals(line.qty_to_receive, 3,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 3, self.assertEquals(line.qty_incoming, 3,
"Wrong qty incoming") "Wrong qty incoming")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_to_deliver, 5,
"Wrong qty to deliver")
self.assertEquals(line.qty_to_receive, 5, self.assertEquals(line.qty_to_receive, 5,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 5, self.assertEquals(line.qty_incoming, 5,
"Wrong qty incoming") "Wrong qty incoming")
if line.product_id == self.product_3: if line.product_id == self.product_3:
self.assertEquals(line.qty_to_deliver, 2,
"Wrong qty to deliver")
self.assertEquals(line.qty_to_receive, 2, self.assertEquals(line.qty_to_receive, 2,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 2, self.assertEquals(line.qty_incoming, 2,
@@ -256,6 +405,9 @@ class TestRma(common.TransactionCase):
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 2, self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered") "Wrong qty delivered")
self.rma_customer_id.action_rma_done() self.line.action_rma_done()
self.assertEquals(self.rma_customer_id.state, 'done', self.assertEquals(self.line.state, 'done',
"Wrong State") "Wrong State")
self.rma_customer_id.action_view_in_shipments()
self.rma_customer_id.action_view_out_shipments()
self.rma_customer_id.action_view_lines()

View File

@@ -2,7 +2,7 @@
# © 2017 Eficent Business and IT Consulting Services S.L. # © 2017 Eficent Business and IT Consulting Services S.L.
# License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html) # License LGPL-3.0 or later (https://www.gnu.org/licenses/lgpl.html)
from odoo.addons.rma.tests import test_rma from . import test_rma
class TestRmaDropship(test_rma.TestRma): class TestRmaDropship(test_rma.TestRma):

View File

@@ -66,12 +66,8 @@ class TestSupplierRma(test_rma.TestRma):
picking.action_assign() picking.action_assign()
picking.do_transfer() picking.do_transfer()
for line in self.rma_supplier_id.rma_line_ids: for line in self.rma_supplier_id.rma_line_ids:
self.assertEquals(line.qty_to_deliver, 0,
"Wrong qty to deliver")
self.assertEquals(line.qty_incoming, 0, self.assertEquals(line.qty_incoming, 0,
"Wrong qty incoming") "Wrong qty incoming")
self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing")
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_received, 0,
"Wrong qty received") "Wrong qty received")
if line.product_id == self.product_1: if line.product_id == self.product_1:
@@ -100,58 +96,52 @@ class TestSupplierRma(test_rma.TestRma):
proc.group_id]) proc.group_id])
domain = [('group_id', 'in', list(group_ids))] domain = [('group_id', 'in', list(group_ids))]
pickings = self.stockpicking.search(domain) pickings = self.stockpicking.search(domain)
self.assertEquals(len(pickings), 2, self.assertEquals(len(pickings), 3,
"Incorrect number of pickings created") "Incorrect number of pickings created")
picking_out = pickings[1] picking_out = pickings[0]
moves = picking_out.move_lines moves = picking_out.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 2,
"Incorrect number of moves created") "Incorrect number of moves created")
for line in self.rma_supplier_id.rma_line_ids: for line in self.rma_supplier_id.rma_line_ids:
self.assertEquals(line.qty_to_deliver, 0, self.assertEquals(line.qty_incoming, 0,
"Wrong qty to deliver") "Wrong qty incoming")
self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing")
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_received, 0,
"Wrong qty received") "Wrong qty received")
if line.product_id == self.product_1: if line.product_id == self.product_1:
self.assertEquals(line.qty_to_receive, 3, self.assertEquals(line.qty_to_receive, 3,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 3, self.assertEquals(line.qty_incoming, 0,
"Wrong qty incoming") "Wrong qty incoming")
self.assertEquals(line.qty_delivered, 3, self.assertEquals(line.qty_delivered, 3,
"Wrong qty delivered") "Wrong qty delivered")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_to_receive, 5, self.assertEquals(line.qty_to_receive, 5,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 5, self.assertEquals(line.qty_to_deliver, 5,
"Wrong qty incoming") "Wrong qty to deliver")
self.assertEquals(line.qty_delivered, 5,
"Wrong qty delivered")
if line.product_id == self.product_3: if line.product_id == self.product_3:
self.assertEquals(line.qty_to_receive, 2, self.assertEquals(line.qty_to_receive, 2,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 2, self.assertEquals(line.qty_to_deliver, 2,
"Wrong qty incoming") "Wrong qty to deliver")
self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered")
picking_out.action_assign() picking_out.action_assign()
picking_out.do_transfer() picking_out.do_transfer()
for line in self.rma_supplier_id.rma_line_ids: for line in self.rma_supplier_id.rma_line_ids[0]:
self.assertEquals(line.qty_to_receive, 0, self.assertEquals(line.qty_to_receive, 3,
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 0, self.assertEquals(line.qty_incoming, 0,
"Wrong qty incoming") "Wrong qty incoming")
self.assertEquals(line.qty_to_deliver, 0, self.assertEquals(line.qty_to_deliver, 0,
"Wrong qty to deliver") "Wrong qty to deliver")
self.assertEquals(line.qty_outgoing, 0, self.assertEquals(line.qty_outgoing, 3,
"Wrong qty outgoing") "Wrong qty outgoing")
if line.product_id == self.product_1: if line.product_id == self.product_1:
self.assertEquals(line.qty_received, 3, self.assertEquals(line.qty_received, 0,
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 3, self.assertEquals(line.qty_delivered, 3,
"Wrong qty delivered") "Wrong qty delivered")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_received, 5, self.assertEquals(line.qty_received, 0,
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 5, self.assertEquals(line.qty_delivered, 5,
"Wrong qty delivered") "Wrong qty delivered")
@@ -160,6 +150,7 @@ class TestSupplierRma(test_rma.TestRma):
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 2, self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered") "Wrong qty delivered")
self.rma_supplier_id.action_rma_done() for line in self.rma_supplier_id.rma_line_ids:
self.assertEquals(self.rma_supplier_id.state, 'done', line.action_rma_done()
"Wrong State") self.assertEquals(line.state, 'done',
"Wrong State")