multiple fixes

This commit is contained in:
Jordi Ballester
2018-02-14 13:35:09 +01:00
committed by ahenriquez
parent 0f0558b88f
commit e3de350b91
9 changed files with 156 additions and 173 deletions

View File

@@ -1,5 +1,5 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<odoo noupdate="1"> <odoo noupdate="0">
<record id="rma_operation_customer_replace" model="rma.operation"> <record id="rma_operation_customer_replace" model="rma.operation">
<field name="name">Replace After Receive</field> <field name="name">Replace After Receive</field>
<field name="code">RPLC</field> <field name="code">RPLC</field>
@@ -21,29 +21,24 @@
</record> </record>
<record id="rma_operation_ds_replace" model="rma.operation"> <record id="rma_operation_ds_replace" model="rma.operation">
<field name="name">Replace deliver to vendor</field> <field name="name">Drop Ship - Replace deliver to vendor</field>
<field name="code">DSRPLB</field> <field name="code">DSRPLB</field>
<field name="receipt_policy">ordered</field> <field name="receipt_policy">ordered</field>
<field name="delivery_policy">no</field> <field name="delivery_policy">no</field>
<field name="type">customer</field> <field name="type">customer</field>
<field name="out_route_id" ref="rma.route_rma_dropship"/> <field name="customer_to_supplier">True</field>
</record> <field name="in_route_id" ref="rma.route_rma_dropship"/>
<record id="rma_operation_ds_replace_customer" model="rma.operation">
<field name="name">Replace receive in vendor</field>
<field name="code">DSRPLV</field>
<field name="receipt_policy">no</field>
<field name="delivery_policy">received</field>
<field name="type">customer</field>
<field name="out_route_id" ref="rma.route_rma_dropship"/> <field name="out_route_id" ref="rma.route_rma_dropship"/>
</record> </record>
<record id="rma_operation_ds_replace_supplier" model="rma.operation"> <record id="rma_operation_ds_replace_supplier" model="rma.operation">
<field name="name">Replace deliver to customer</field> <field name="name">Drop Ship - Replace deliver to customer</field>
<field name="code">DSRPC</field> <field name="code">DSRPC</field>
<field name="receipt_policy">no</field> <field name="receipt_policy">ordered</field>
<field name="delivery_policy">received</field> <field name="delivery_policy">no</field>
<field name="type">supplier</field> <field name="type">supplier</field>
<field name="supplier_to_customer">True</field>
<field name="in_route_id" ref="rma.route_rma_dropship"/>
<field name="out_route_id" ref="rma.route_rma_dropship"/> <field name="out_route_id" ref="rma.route_rma_dropship"/>
</record> </record>

View File

@@ -139,7 +139,7 @@ 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.product_qty - qty
rec.qty_in_supplier_rma = qty rec.qty_in_supplier_rma = qty
delivery_address_id = fields.Many2one( delivery_address_id = fields.Many2one(
@@ -489,8 +489,10 @@ class RmaOrderLine(models.Model):
self.in_warehouse_id.lot_rma_id self.in_warehouse_id.lot_rma_id
self.customer_to_supplier = self.operation_id.customer_to_supplier self.customer_to_supplier = self.operation_id.customer_to_supplier
self.supplier_to_customer = self.operation_id.supplier_to_customer self.supplier_to_customer = self.operation_id.supplier_to_customer
self.in_route_id = self.operation_id.in_route_id if self.operation_id.in_route_id:
self.out_route_id = self.operation_id.out_route_id self.in_route_id = self.operation_id.in_route_id
if self.operation_id.out_route_id:
self.out_route_id = self.operation_id.out_route_id
return result return result
@api.onchange('customer_to_supplier', 'type') @api.onchange('customer_to_supplier', 'type')
@@ -511,9 +513,10 @@ class RmaOrderLine(models.Model):
def action_view_in_shipments(self): def action_view_in_shipments(self):
action = self.env.ref('stock.action_picking_tree_all') action = self.env.ref('stock.action_picking_tree_all')
result = action.read()[0] result = action.read()[0]
picking_ids = self.env['stock.picking'].search( moves = self.env['stock.move'].search([
[('origin', '=', self.name), ('rma_line_id', 'in', self.ids)])
('picking_type_code', '=', 'incoming')]).ids picking_ids = moves.mapped('picking_id').filtered(
lambda p: p.picking_type_code == 'incoming').ids
# choose the view_mode accordingly # choose the view_mode accordingly
if len(picking_ids) > 1: if len(picking_ids) > 1:
result['domain'] = [('id', 'in', picking_ids)] result['domain'] = [('id', 'in', picking_ids)]
@@ -527,9 +530,10 @@ class RmaOrderLine(models.Model):
def action_view_out_shipments(self): def action_view_out_shipments(self):
action = self.env.ref('stock.action_picking_tree_all') action = self.env.ref('stock.action_picking_tree_all')
result = action.read()[0] result = action.read()[0]
picking_ids = self.env['stock.picking'].search( moves = self.env['stock.move'].search([
[('origin', '=', self.name), ('rma_line_id', 'in', self.ids)])
('picking_type_code', '=', 'outgoing')]).ids picking_ids = moves.mapped('picking_id').filtered(
lambda p: p.picking_type_code == 'outgoing').ids
# choose the view_mode accordingly # choose the view_mode accordingly
if len(picking_ids) > 1: if len(picking_ids) > 1:
result['domain'] = [('id', 'in', picking_ids)] result['domain'] = [('id', 'in', picking_ids)]

View File

@@ -160,6 +160,8 @@ class TestRma(common.TransactionCase):
supplier_address_id=supplier_address_id.id) supplier_address_id=supplier_address_id.id)
data['partner_id'] = move.partner_id.id data['partner_id'] = move.partner_id.id
data['rma_id'] = rma_id.id data['rma_id'] = rma_id.id
if type == 'supplier':
self.rma_line = self.rma_line.with_context(supplier=True)
self.line = self.rma_line.create(data) self.line = self.rma_line.create(data)
# approve the RMA Line # approve the RMA Line
self.rma_line.action_rma_to_approve() self.rma_line.action_rma_to_approve()
@@ -264,18 +266,18 @@ class TestRma(common.TransactionCase):
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'incoming', 'picking_type': 'incoming',
'active_id': 1 'active_id': 1
}).create({'rma_id': self.rma_customer_id.id}) }).create({})
wizard.with_context({ wizard.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
}).default_get({}) }).default_get({})
procurements = wizard._create_picking() wizard._create_picking()
domain = [('origin', '=', procurements)] res = self.rma_customer_id.rma_line_ids.action_view_in_shipments()
picking = self.stockpicking.search(domain) self.assertTrue('res_id' in res,
self.assertEquals(len(picking), 1, "Incorrect number of pickings created")
"Incorrect number of pickings created") picking = self.env['stock.picking'].browse(res['res_id'])
moves = picking.move_lines moves = picking.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 3,
"Incorrect number of moves created") "Incorrect number of moves created")
@@ -309,33 +311,29 @@ class TestRma(common.TransactionCase):
"Wrong qty to receive") "Wrong qty to receive")
self.assertEquals(line.qty_incoming, 2, self.assertEquals(line.qty_incoming, 2,
"Wrong qty incoming") "Wrong qty incoming")
picking.action_confirm()
picking.action_assign() picking.action_assign()
picking.force_assign() for line in picking.move_line_ids:
picking.do_new_transfer() line.qty_done = line.product_uom_qty
picking.action_done()
for line in self.rma_customer_id.rma_line_ids: for line in self.rma_customer_id.rma_line_ids:
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_to_receive, 0,
"Wrong qty to_receive") "Wrong qty to_receive")
# self.assertEquals(line.qty_incoming, 5, self.assertEquals(line.qty_incoming, 0,
# "Wrong qty incoming") "Wrong qty incoming")
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")
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_received, 3,
"Wrong qty to received") "Wrong qty received")
self.assertEquals(line.qty_incoming, 3,
"Wrong qty incoming")
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_received, 5,
"Wrong qty to received") "Wrong qty received")
self.assertEquals(line.qty_incoming, 5,
"Wrong qty incoming")
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_received, 2,
"Wrong qty to received") "Wrong qty received")
self.assertEquals(line.qty_incoming, 2,
"Wrong qty incoming")
wizard = self.rma_make_picking.with_context({ wizard = self.rma_make_picking.with_context({
'active_id': 1, 'active_id': 1,
@@ -343,72 +341,51 @@ class TestRma(common.TransactionCase):
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'outgoing', 'picking_type': 'outgoing',
}).create({}) }).create({})
procurements = wizard._create_picking() wizard._create_picking()
domain = [('origin', '=', procurements)] res = self.rma_customer_id.rma_line_ids.action_view_out_shipments()
pickings = self.stockpicking.search(domain) self.assertTrue('res_id' in res,
self.assertEquals(len(pickings), 2, "Incorrect number of pickings created")
"Incorrect number of pickings created") picking = self.env['stock.picking'].browse(res['res_id'])
picking_out = pickings[0] moves = picking.move_lines
moves = picking_out.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 3,
"Incorrect number of moves created") "Incorrect number of moves created")
for line in self.rma_customer_id.rma_line_ids: for line in self.rma_customer_id.rma_line_ids:
self.assertEquals(line.qty_received, 0,
"Wrong qty receive")
self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing")
self.assertEquals(line.qty_delivered, 0, self.assertEquals(line.qty_delivered, 0,
"Wrong qty delivered") "Wrong qty delivered")
if line.product_id == self.product_1: if line.product_id == self.product_1:
self.assertEquals(line.qty_to_deliver, 0, self.assertEquals(line.qty_to_deliver, 3,
"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")
self.assertEquals(line.qty_received, 0,
"Wrong qty received")
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_deliver, 5,
"Wrong qty to received") "Wrong qty to deliver")
self.assertEquals(line.qty_incoming, 5, self.assertEquals(line.qty_outgoing, 5,
"Wrong qty incoming")
self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing") "Wrong qty outgoing")
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_deliver, 2,
"Wrong qty to received") "Wrong qty to deliver")
self.assertEquals(line.qty_incoming, 2, self.assertEquals(line.qty_outgoing, 2,
"Wrong qty incoming")
self.assertEquals(line.qty_outgoing, 0,
"Wrong qty outgoing") "Wrong qty outgoing")
picking_out.action_assign() picking.action_confirm()
picking_out.do_new_transfer() picking.action_assign()
for line in picking.move_line_ids:
line.qty_done = line.product_uom_qty
picking.action_done()
for line in self.rma_customer_id.rma_line_ids[0]: for line in self.rma_customer_id.rma_line_ids[0]:
self.assertEquals(line.qty_to_receive, 3,
"Wrong qty to receive")
self.assertEquals(line.qty_incoming, 3,
"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, 0,
"Wrong qty outgoing") "Wrong qty outgoing")
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_delivered, 3,
"Wrong qty to received") "Wrong qty delivered")
self.assertEquals(line.qty_to_deliver, 0,
"Wrong qty to delivered")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_received, 5,
"Wrong qty received")
self.assertEquals(line.qty_delivered, 5, self.assertEquals(line.qty_delivered, 5,
"Wrong qty delivered") "Wrong qty delivered")
if line.product_id == self.product_3: if line.product_id == self.product_3:
self.assertEquals(line.qty_received, 2,
"Wrong qty received")
self.assertEquals(line.qty_delivered, 2, self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered") "Wrong qty delivered")
self.line.action_rma_done() self.line.action_rma_done()
self.assertEquals(self.line.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

@@ -8,18 +8,26 @@ class TestRmaDropship(test_rma.TestRma):
def setUp(self): def setUp(self):
super(TestRmaDropship, self).setUp() super(TestRmaDropship, self).setUp()
rma_operation_ds_replace = self.env.ref(
'rma.rma_operation_ds_replace')
self.rma_operation_ds_replace_supplier = self.env.ref(
'rma.rma_operation_ds_replace_supplier')
self.product_id.write( self.product_id.write(
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id, {'rma_customer_operation_id': rma_operation_ds_replace.id,
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id}) 'rma_supplier_operation_id':
self.rma_operation_ds_replace_supplier.id})
self.product_1.write( self.product_1.write(
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id, {'rma_customer_operation_id': rma_operation_ds_replace.id,
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id}) 'rma_supplier_operation_id':
self.rma_operation_ds_replace_supplier.id})
self.product_2.write( self.product_2.write(
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id, {'rma_customer_operation_id': rma_operation_ds_replace.id,
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id}) 'rma_supplier_operation_id':
self.rma_operation_ds_replace_supplier.id})
self.product_3.write( self.product_3.write(
{'rma_customer_operation_id': self.rma_cust_replace_op_id.id, {'rma_customer_operation_id': rma_operation_ds_replace.id,
'rma_supplier_operation_id': self.rma_sup_replace_op_id.id}) 'rma_supplier_operation_id':
self.rma_operation_ds_replace_supplier.id})
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_droship_id = self._create_rma_from_move( self.rma_droship_id = self._create_rma_from_move(
@@ -32,13 +40,14 @@ class TestRmaDropship(test_rma.TestRma):
'active_ids': self.rma_droship_id.rma_line_ids.ids, 'active_ids': self.rma_droship_id.rma_line_ids.ids,
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'active_id': 1 'active_id': 1
}).create({'partner_id': self.partner_id.id, }).create({})
'supplier_rma_id': self.rma_droship_id.id,
})
res = wizard.make_supplier_rma() res = wizard.make_supplier_rma()
supplier_rma = self.rma.browse(res['res_id']) supplier_rma = self.rma.browse(res['res_id'])
for line in supplier_rma.rma_line_ids: for line in supplier_rma.rma_line_ids:
line.delivery_address_id = self.env.ref('base.res_partner_2')
line.operation_id = self.rma_operation_ds_replace_supplier
line._onchange_operation_id()
line.action_rma_to_approve() line.action_rma_to_approve()
line.action_rma_approve() line.action_rma_approve()
wizard = self.rma_make_picking.with_context({ wizard = self.rma_make_picking.with_context({
@@ -47,22 +56,15 @@ class TestRmaDropship(test_rma.TestRma):
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'incoming', 'picking_type': 'incoming',
}).create({}) }).create({})
procurements = wizard._create_picking() wizard._create_picking()
domain = [('origin', '=', procurements)] res = supplier_rma.rma_line_ids.action_view_in_shipments()
picking = self.stockpicking.search(domain) self.assertTrue('res_id' in res,
self.assertEquals(len(picking), 1, "Incorrect number of pickings created")
"Incorrect number of pickings created") picking = self.env['stock.picking'].browse(res['res_id'])
moves = picking.move_lines moves = picking.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 3,
"Incorrect number of moves created") "Incorrect number of moves created")
for line in supplier_rma.rma_line_ids: 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 # product specific
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,

View File

@@ -8,6 +8,8 @@ class TestSupplierRma(test_rma.TestRma):
def setUp(self): def setUp(self):
super(TestSupplierRma, self).setUp() super(TestSupplierRma, self).setUp()
self.rma_operation_supplier_replace = self.env.ref(
'rma.rma_operation_supplier_replace')
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_supplier_id = self._create_rma_from_move( self.rma_supplier_id = self._create_rma_from_move(
@@ -15,17 +17,22 @@ class TestSupplierRma(test_rma.TestRma):
dropship=False) dropship=False)
def test_supplier_rma(self): def test_supplier_rma(self):
for line in self.rma_supplier_id.rma_line_ids:
line.operation_id = self.rma_operation_supplier_replace
line._onchange_operation_id()
line.action_rma_to_approve()
line.action_rma_approve()
wizard = self.rma_make_picking.with_context({ wizard = self.rma_make_picking.with_context({
'active_ids': self.rma_supplier_id.rma_line_ids.ids, 'active_ids': self.rma_supplier_id.rma_line_ids.ids,
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'outgoing', 'picking_type': 'outgoing',
'active_id': 1 'active_id': 1
}).create({}) }).create({})
procurements = wizard._create_picking() wizard._create_picking()
domain = [('origin', '=', procurements)] res = self.rma_supplier_id.rma_line_ids.action_view_out_shipments()
picking = self.stockpicking.search(domain) self.assertTrue('res_id' in res,
self.assertEquals(len(picking), 1, "Incorrect number of pickings created")
"Incorrect number of pickings created") picking = self.env['stock.picking'].browse(res['res_id'])
moves = picking.move_lines moves = picking.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 3,
"Incorrect number of moves created") "Incorrect number of moves created")
@@ -59,26 +66,27 @@ class TestSupplierRma(test_rma.TestRma):
"Wrong qty to deliver") "Wrong qty to deliver")
self.assertEquals(line.qty_outgoing, 2, self.assertEquals(line.qty_outgoing, 2,
"Wrong qty outgoing") "Wrong qty outgoing")
picking.force_assign()
picking.action_assign() for line in picking.move_lines:
picking.do_new_transfer() line.quantity_done = line.product_uom_qty
picking.button_validate()
for line in self.rma_supplier_id.rma_line_ids: for line in self.rma_supplier_id.rma_line_ids:
self.assertEquals(line.qty_incoming, 0, self.assertEquals(line.qty_incoming, 0,
"Wrong qty incoming") "Wrong qty incoming")
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_delivered, 0, self.assertEquals(line.qty_delivered, 3,
"Wrong qty delivered") "Wrong qty delivered")
self.assertEquals(line.qty_to_receive, 3, self.assertEquals(line.qty_to_receive, 3,
"Wrong qty to receive") "Wrong qty to receive")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_delivered, 0, self.assertEquals(line.qty_delivered, 5,
"Wrong qty delivered") "Wrong qty delivered")
self.assertEquals(line.qty_to_receive, 5, self.assertEquals(line.qty_to_receive, 5,
"Wrong qty to receive") "Wrong qty to receive")
if line.product_id == self.product_3: if line.product_id == self.product_3:
self.assertEquals(line.qty_delivered, 0, self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered") "Wrong qty delivered")
self.assertEquals(line.qty_to_receive, 2, self.assertEquals(line.qty_to_receive, 2,
"Wrong qty to receive") "Wrong qty to receive")
@@ -88,63 +96,48 @@ class TestSupplierRma(test_rma.TestRma):
'active_model': 'rma.order.line', 'active_model': 'rma.order.line',
'picking_type': 'incoming', 'picking_type': 'incoming',
}).create({}) }).create({})
procurements = wizard._create_picking() wizard._create_picking()
domain = [('origin', '=', procurements)] res = self.rma_supplier_id.rma_line_ids.action_view_in_shipments()
pickings = self.stockpicking.search(domain) self.assertTrue('res_id' in res,
self.assertEquals(len(pickings), 2, "Incorrect number of pickings created")
"Incorrect number of pickings created") picking = self.env['stock.picking'].browse(res['res_id'])
picking_out = pickings[0] moves = picking.move_lines
moves = picking_out.move_lines
self.assertEquals(len(moves), 3, self.assertEquals(len(moves), 3,
"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_incoming, 0,
"Wrong qty incoming")
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, 0, self.assertEquals(line.qty_incoming, 3,
"Wrong qty incoming") "Wrong qty incoming")
self.assertEquals(line.qty_delivered, 0,
"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_to_deliver, 5, self.assertEquals(line.qty_incoming, 5,
"Wrong qty to deliver") "Wrong qty incoming")
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_to_deliver, 2, self.assertEquals(line.qty_incoming, 2,
"Wrong qty to deliver") "Wrong qty incoming")
picking_out.action_assign() picking.action_assign()
picking_out.do_new_transfer() for line in picking.move_line_ids:
line.qty_done = line.product_uom_qty
picking.action_done()
for line in self.rma_supplier_id.rma_line_ids[0]: 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, self.assertEquals(line.qty_incoming, 0,
"Wrong qty incoming") "Wrong qty incoming")
self.assertEquals(line.qty_to_deliver, 3,
"Wrong qty to deliver")
self.assertEquals(line.qty_outgoing, 6,
"Wrong qty outgoing")
if line.product_id == self.product_1: if line.product_id == self.product_1:
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_received, 3,
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 0,
"Wrong qty delivered")
if line.product_id == self.product_2: if line.product_id == self.product_2:
self.assertEquals(line.qty_received, 0, self.assertEquals(line.qty_received, 5,
"Wrong qty received") "Wrong qty received")
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_received, 2, self.assertEquals(line.qty_received, 2,
"Wrong qty received") "Wrong qty received")
self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered")
for line in self.rma_supplier_id.rma_line_ids: for line in self.rma_supplier_id.rma_line_ids:
line.action_rma_done() line.action_rma_done()
self.assertEquals(line.state, 'done', self.assertEquals(line.state, 'done',

View File

@@ -38,13 +38,13 @@
<field name="location_id" <field name="location_id"
domain="[('usage', '=', 'internal')]"/> domain="[('usage', '=', 'internal')]"/>
<field name="customer_to_supplier" <field name="customer_to_supplier"
attrs="{'invisible':[('type', '=', 'supplier')]}"/>
<field name="supplier_to_customer"
attrs="{'invisible':[('type', '=', 'customer')]}"/> attrs="{'invisible':[('type', '=', 'customer')]}"/>
</group> </group>
<group name="outbound" string="Outbound"> <group name="outbound" string="Outbound">
<field name="out_route_id"/> <field name="out_route_id"/>
<field name="out_warehouse_id"/> <field name="out_warehouse_id"/>
<field name="supplier_to_customer"
attrs="{'invisible':[('type', '=', 'supplier')]}"/>
</group> </group>
</group> </group>
</form> </form>

View File

@@ -144,10 +144,13 @@
</group> </group>
<group name="outbound" string="Outbound"> <group name="outbound" string="Outbound">
<field name="out_warehouse_id"/> <field name="out_warehouse_id"/>
<field name="delivery_address_id"
groups='rma.group_rma_delivery_invoice_address'/>
<field name="out_route_id"/> <field name="out_route_id"/>
</group> </group>
<group name="delivery_address"
string="Delivery Address (drop ship">
<field name="delivery_address_id"
groups='rma.group_rma_delivery_invoice_address'/>
</group>
</group> </group>
</group> </group>
</page> </page>

View File

@@ -3,7 +3,7 @@
import time import time
from odoo import models, fields, api, _ from odoo import models, fields, api, _
from odoo.exceptions import ValidationError from odoo.exceptions import UserError, ValidationError
from odoo.tools import DEFAULT_SERVER_DATETIME_FORMAT as DT_FORMAT from odoo.tools import DEFAULT_SERVER_DATETIME_FORMAT as DT_FORMAT
import odoo.addons.decimal_precision as dp import odoo.addons.decimal_precision as dp
@@ -103,6 +103,9 @@ class RmaMakePicking(models.TransientModel):
if line.customer_to_supplier: if line.customer_to_supplier:
location = self._get_address_location( location = self._get_address_location(
delivery_address_id, 'supplier') delivery_address_id, 'supplier')
elif line.supplier_to_customer:
location = self._get_address_location(
delivery_address_id, 'customer')
else: else:
location = line.location_id location = line.location_id
warehouse = line.in_warehouse_id warehouse = line.in_warehouse_id
@@ -134,6 +137,7 @@ class RmaMakePicking(models.TransientModel):
@api.model @api.model
def _create_procurement(self, item, picking_type): def _create_procurement(self, item, picking_type):
errors = []
group = self.find_procurement_group(item) group = self.find_procurement_group(item)
if not group: if not group:
pg_data = self._get_procurement_group_data(item) pg_data = self._get_procurement_group_data(item)
@@ -144,15 +148,20 @@ class RmaMakePicking(models.TransientModel):
qty = item.qty_to_deliver qty = item.qty_to_deliver
values = self._get_procurement_data(item, group, qty, picking_type) values = self._get_procurement_data(item, group, qty, picking_type)
# create picking # create picking
self.env['procurement.group'].run( try:
item.line_id.product_id, self.env['procurement.group'].run(
qty, item.line_id.product_id,
item.line_id.product_id.product_tmpl_id.uom_id, qty,
values.get('location_id'), item.line_id.product_id.product_tmpl_id.uom_id,
values.get('origin'), values.get('location_id'),
values.get('origin'), values.get('origin'),
values values.get('origin'),
) values
)
except UserError as error:
errors.append(error.name)
if errors:
raise UserError('\n'.join(errors))
return values.get('origin') return values.get('origin')
@api.multi @api.multi
@@ -198,7 +207,6 @@ class RmaMakePicking(models.TransientModel):
@api.multi @api.multi
def action_create_picking(self): def action_create_picking(self):
procurement = self._create_picking() procurement = self._create_picking()
pickings = False
action = self.env.ref('stock.do_view_pickings') action = self.env.ref('stock.do_view_pickings')
action = action.read()[0] action = action.read()[0]
if procurement: if procurement:

View File

@@ -66,15 +66,16 @@ class RmaLineMakeSupplierRma(models.TransientModel):
raise ValidationError(_('Enter a supplier.')) raise ValidationError(_('Enter a supplier.'))
return { return {
'partner_id': self.partner_id.id, 'partner_id': self.partner_id.id,
'delivery_address_id': self.partner_id.id,
'type': 'supplier', 'type': 'supplier',
'company_id': company.id, 'company_id': company.id,
} }
@api.model @api.model
def _prepare_supplier_rma_line(self, rma, item): def _prepare_supplier_rma_line(self, rma, item):
operation = self.env['rma.operation'].search( operation = item.line_id.product_id.rma_supplier_operation_id
[('type', '=', 'supplier')], limit=1) if not operation:
operation = self.env['rma.operation'].search(
[('type', '=', 'supplier')], limit=1)
if not operation.in_route_id or not operation.out_route_id: if not operation.in_route_id or not operation.out_route_id:
route = self.env['stock.location.route'].search( route = self.env['stock.location.route'].search(
[('rma_selectable', '=', True)], limit=1) [('rma_selectable', '=', True)], limit=1)
@@ -97,7 +98,7 @@ class RmaLineMakeSupplierRma(models.TransientModel):
'customer_rma_id': item.line_id.id, 'customer_rma_id': item.line_id.id,
'product_qty': item.product_qty, 'product_qty': item.product_qty,
'rma_id': rma.id, 'rma_id': rma.id,
'uom_id': item.uom_id.id, 'uom_id': item.line_id.uom_id.id,
'operation_id': operation.id, 'operation_id': operation.id,
'receipt_policy': operation.receipt_policy, 'receipt_policy': operation.receipt_policy,
'delivery_policy': operation.delivery_policy, 'delivery_policy': operation.delivery_policy,