[IMP] default operation in product and product_categ for customer and supplier

[IMP]Separate menus for customer and supplier operations
* Add active field to rma operation
* Added tests
* Fix travis
* Fix create supplier rma from customer rma
This commit is contained in:
aheficent
2017-08-16 12:52:35 +02:00
committed by ahenriquez
parent 539be323ef
commit 3551ce078a
16 changed files with 459 additions and 124 deletions

View File

@@ -13,61 +13,95 @@ class TestRma(common.TransactionCase):
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_op_id = self.env.ref('rma.rma_operation_customer_replace')
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_30')
self.product_3 = self.env.ref('product.product_product_33')
self.uom_unit = self.env.ref('product.product_uom_unit')
# assign an operation
self.product_1.write({'rma_operation_id': self.rma_op_id.id})
self.product_2.write({'rma_operation_id': self.rma_op_id.id})
self.product_3.write({'rma_operation_id': self.rma_op_id.id})
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')
self.stock_rma_location = self.env.ref('rma.location_rma')
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')
self.product_uom_id = self.env.ref('product.product_uom_unit')
moves = []
products2move = [(self.product_1, 3), (self.product_2, 5),
(self.product_3, 2)]
for item in products2move:
move_values = self._prepare_move(item[0], item[1])
moves.append(self.env['stock.move'].create(move_values))
self.rma_customer_id = self._create_rma_from_move(
products2move, 'customer', self.env.ref('base.res_partner_2'),
dropship=False)
def _create_rma_from_move(self, products2move, type, partner, dropship,
supplier_address_id=None):
moves = []
if type == 'customer':
for item in products2move:
move_values = self._prepare_move(
item[0], item[1], self.stock_location,
self.customer_location)
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)
moves.append(self.env['stock.move'].create(move_values))
# Create the RMA from the stock_move
self.rma_id = self.rma.create(
rma_id = self.rma.create(
{
'reference': '0001',
'type': 'customer',
'partner_id': self.env.ref('base.res_partner_2').id
'type': type,
'partner_id': partner.id,
'company_id': self.env.ref('base.main_company').id
})
for move in moves:
data = self.rma_add_stock_move.with_context(
{'stock_move_id': move.id}
)._prepare_rma_line_from_stock_move(move)
operation = self.rma_op.browse(data['operation_id'])
data.update(
rma_id=self.rma_id.id,
receipt_policy=operation.receipt_policy,
delivery_policy=operation.delivery_policy,
in_warehouse_id=operation.in_warehouse_id.id,
out_warehouse_id=operation.out_warehouse_id.id,
location_id=self.stock_rma_location.id,
in_route_id=operation.in_route_id.id,
out_route_id=operation.out_route_id.id)
if type == 'customer':
wizard = self.rma_add_stock_move.with_context(
{'stock_move_id': move.id, 'customer': True,
'active_ids': rma_id.id,
'active_model': 'rma.order',
}
).create({})
data = wizard._prepare_rma_line_from_stock_move(move)
else:
wizard = self.rma_add_stock_move.with_context(
{'stock_move_id': move.id, 'supplier': True,
'active_ids': rma_id.id,
'active_model': 'rma.order',
}
).create({})
data = wizard._prepare_rma_line_from_stock_move(move)
if dropship:
data.update(customer_to_supplier=dropship,
supplier_address_id=supplier_address_id.id)
self.rma_line.create(data)
# approve the RMA
self.rma_id.action_rma_to_approve()
self.rma_id.action_rma_approve()
rma_id.action_rma_to_approve()
rma_id.action_rma_approve()
return rma_id
def _prepare_move(self, product, qty):
def _prepare_move(self, product, qty, src, dest):
res = {
'product_id': product.id,
'name': product.partner_ref,
@@ -75,14 +109,14 @@ class TestRma(common.TransactionCase):
'product_uom': self.product_uom_id.id or product.uom_id.id,
'product_uom_qty': qty,
'origin': 'Test RMA',
'location_id': self.stock_location.id,
'location_dest_id': self.customer_location.id,
'location_id': src.id,
'location_dest_id': dest.id,
}
return res
def test_00_receive_items(self):
def test_customer_rma(self):
wizard = self.rma_make_picking.with_context({
'active_ids': self.rma_id.rma_line_ids.ids,
'active_ids': self.rma_customer_id.rma_line_ids.ids,
'active_model': 'rma.order.line',
'picking_type': 'incoming',
'active_id': 1
@@ -97,7 +131,7 @@ class TestRma(common.TransactionCase):
moves = picking.move_lines
self.assertEquals(len(moves), 3,
"Incorrect number of moves created")
for line in self.rma_id.rma_line_ids:
for line in self.rma_customer_id.rma_line_ids:
# common qtys for all products
self.assertEquals(line.qty_received, 0,
"Wrong qty received")
@@ -125,7 +159,7 @@ class TestRma(common.TransactionCase):
"Wrong qty incoming")
picking.action_assign()
picking.do_transfer()
for line in self.rma_id.rma_line_ids:
for line in self.rma_customer_id.rma_line_ids:
self.assertEquals(line.qty_to_receive, 0,
"Wrong qty to_receive")
self.assertEquals(line.qty_incoming, 0,
@@ -152,7 +186,7 @@ class TestRma(common.TransactionCase):
wizard = self.rma_make_picking.with_context({
'active_id': 1,
'active_ids': self.rma_id.rma_line_ids.ids,
'active_ids': self.rma_customer_id.rma_line_ids.ids,
'active_model': 'rma.order.line',
'picking_type': 'outgoing',
}).create({})
@@ -167,7 +201,7 @@ class TestRma(common.TransactionCase):
moves = picking_out.move_lines
self.assertEquals(len(moves), 3,
"Incorrect number of moves created")
for line in self.rma_id.rma_line_ids:
for line in self.rma_customer_id.rma_line_ids:
self.assertEquals(line.qty_to_receive, 0,
"Wrong qty to receive")
self.assertEquals(line.qty_incoming, 0,
@@ -197,7 +231,7 @@ class TestRma(common.TransactionCase):
"Wrong qty outgoing")
picking_out.action_assign()
picking_out.do_transfer()
for line in self.rma_id.rma_line_ids:
for line in self.rma_customer_id.rma_line_ids:
self.assertEquals(line.qty_to_receive, 0,
"Wrong qty to receive")
self.assertEquals(line.qty_incoming, 0,
@@ -221,4 +255,6 @@ class TestRma(common.TransactionCase):
"Wrong qty received")
self.assertEquals(line.qty_delivered, 2,
"Wrong qty delivered")
self.rma_id.action_rma_done()
self.rma_customer_id.action_rma_done()
self.assertEquals(self.rma_customer_id.state, 'done',
"Wrong State")