2 In order to test the purchase flow,I start by creating a new product 'iPod'
4 !record {model: product.product, id: product_product_ipod0}:
5 categ_id: 'product.product_category_3'
10 procure_method: make_to_stock
11 property_stock_inventory: stock.location_inventory
12 property_stock_procurement: stock.location_procurement
13 property_stock_production: stock.location_production
18 uom_id: product.product_uom_unit
19 uom_po_id: product.product_uom_unit
25 In order to test the purchase flow,I create a new record where "invoice_method" is From Order.
27 I create purchase order for iPod.
29 !record {model: purchase.order, id: purchase_order_po0}:
30 company_id: base.main_company
31 date_order: !eval time.strftime('%Y-%m-%d')
33 location_id: stock.stock_location_stock
35 - date_planned: !eval time.strftime('%Y-%m-%d')
38 product_id: 'product_product_ipod0'
40 product_uom: product.product_uom_unit
42 partner_address_id: base.res_partner_address_7
43 partner_id: base.res_partner_4
44 pricelist_id: purchase.list0
46 Initially purchase order is in the draft state.
48 !assert {model: purchase.order, id: purchase_order_po0}:
51 I confirm the purchase order for iPod.
53 !workflow {model: purchase.order, action: purchase_confirm, ref: purchase_order_po0}
55 I changed Expected Date to Next Day.
57 !python {model: purchase.order}: |
58 from tools.translate import _
59 from datetime import datetime
60 from dateutil.relativedelta import relativedelta
61 next_day = datetime.today() + relativedelta(days=1)
62 self.write(cr, uid, [ref("purchase_order_po0")], {'minimum_planned_date': next_day})
64 I check that the order which was initially in the draft state has transit to confirm state.
66 !assert {model: purchase.order, id: purchase_order_po0}:
69 I check that an entry gets created in the "Lines to Invoice" of Invoice Control on the basis of purchase order line.
71 !python {model: purchase.order}: |
72 from tools.translate import _
73 pur_order_obj=self.browse(cr, uid, ref("purchase_order_po0"))
74 pur_line=self.pool.get( 'purchase.order.line')
75 search_ids=pur_line.search(cr, uid, [('order_id', '=', pur_order_obj.name) ])
76 assert search_ids, _('Purchase order line is not created!')
78 To check that wizard "Create Invoices" gets called.
80 I create purchase order line invoice entry.
82 !record {model: purchase.order.line_invoice, id: purchase_order_line_invoice_0}:
85 I create invoice for products in the purchase order.
87 !python {model: purchase.order.line_invoice}: |
88 pur_obj=self.pool.get('purchase.order')
90 pur_id1=pur_obj.browse(cr, uid, ref("purchase_order_po0"))
91 for line in pur_id1.order_line:
93 self.makeInvoices(cr, uid, [1], context={'active_ids': ids})
95 I check that invoice gets created.
97 !python {model: purchase.order}: |
98 from tools.translate import _
99 pur_order_obj=self.browse(cr, uid, ref("purchase_order_po0"))
100 pur_line=self.pool.get( 'purchase.order.line')
101 search_ids=pur_line.search(cr, uid, [('order_id', '=', pur_order_obj.name),('invoiced', '=', '1') ])
102 assert search_ids, _('Invoice is not created!')
104 I check that a record gets created in the Pending Invoices.
106 !python {model: purchase.order}: |
107 from tools.translate import _
108 pur_id1=self.browse(cr, uid, ref("purchase_order_po0"))
109 account_obj = self.pool.get('account.invoice')
110 ids = account_obj.search(cr, uid, [('origin', '=', pur_id1.name)])
111 assert ids, _('Pending Invoice is not created!')
113 I check that the order which was initially in the confirmed state has transit to approved state.
115 !assert {model: purchase.order, id: purchase_order_po0}:
116 - state == 'approved'
118 I check that date_approve field of Delivery&Invoices gets bind with the date on which it has been approved.
120 !python {model: purchase.order}: |
121 pur_id=self.browse(cr, uid, ref("purchase_order_po0"))
122 assert(pur_id.date_approve)
124 I check that an entry gets created in the pickings.
126 !python {model: purchase.order}: |
127 pur_id=self.browse(cr, uid, ref("purchase_order_po0"))
128 assert(pur_id.picking_ids)
130 I check that an entry gets created in the stock moves.
132 !python {model: purchase.order}: |
133 from tools.translate import _
134 pur_id1=self.browse(cr, uid, ref("purchase_order_po0"))
135 picking_obj = self.pool.get('stock.picking')
136 ids = picking_obj.search(cr, uid, [('origin', '=', pur_id1.name)])
137 pick_id = picking_obj.browse(cr, uid, ids)[0]
138 move_obj = self.pool.get('stock.move')
139 search_id = move_obj.search(cr, uid, [('picking_id', '=', pick_id.name)])
140 assert search_id, _('No Incoming Product!')
142 I check that Traceability moves are created.
144 I check that an invoice_ids field of Delivery&Invoices gets bind with the value.
146 !python {model: purchase.order}: |
147 pur_id2=self.browse(cr, uid, ref("purchase_order_po0"))
148 assert(pur_id2.invoice_ids)