2 I create a Sale Order for LG Viewty Smart for qty 500 having Shipping Policy is 'Payment Before Delivery'
4 !record {model: sale.order, id: sale_order_so1}:
5 date_order: '2010-07-20'
6 invoice_quantity: order
11 product_uom: product.product_uom_unit
12 product_uom_qty: 500.0
15 product_id: sale.product_product_slidermobile0
16 product_uos_qty: 500.0
20 partner_id: sale.res_partner_cleartrail0
21 partner_invoice_id: sale.res_partner_address_2
22 partner_order_id: sale.res_partner_address_1
23 partner_shipping_id: sale.res_partner_address_3
24 picking_policy: direct
25 pricelist_id: product.list0
28 I confirm the sale order.
30 !workflow {model: sale.order, action: order_confirm, ref: sale_order_so1}
32 I verify whether the invoice has been generated for SO since Shipping policy is 'Payment Before Delivery'
34 !python {model: sale.order}: |
35 so = self.browse(cr, uid, ref("sale_order_so1"))
36 assert so.invoice_ids, "Invoices has not been generated for sale_order_so1"
38 I verify there are no pickings attached to this sale order
40 !python {model: stock.picking }: |
41 sale_order_obj = self.pool.get('sale.order')
42 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
43 picking_id = self.search(cr, uid, [('origin','=',so.name),('type','=','out')])
45 print "There is a picking attached to this sale order"
47 I open the Invoice for the SO.
49 !python {model: account.invoice}: |
50 sale_order_obj = self.pool.get('sale.order')
51 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
53 wf_service = netsvc.LocalService("workflow")
54 invoice_ids = so.invoice_ids
55 for invoice in invoice_ids:
56 wf_service.trg_validate(uid, 'account.invoice',invoice.id,'invoice_open', cr)
58 I assign an analytic journal to the Bank journal
60 !record {model: account.journal, id: sale.account_journal_bankjournal0}:
61 analytic_journal_id: account.cose_journal_sale
65 !python {model: account.invoice}: |
66 sale_order_obj = self.pool.get('sale.order')
67 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
68 invoice_id = self.search(cr, uid, [('origin','=',so.name),('state','=','open')])
69 self.pay_and_reconcile(cr, uid, invoice_id,
70 85000.0, ref('account.cash'), ref('account.period_8'),
71 ref('sale.account_journal_bankjournal0'), ref('account.cash'),
72 ref('account.period_5'), ref('sale.account_journal_bankjournal0'),
75 I verify the invoice is in done state or not.
77 !python {model: account.invoice}: |
78 sale_order_obj = self.pool.get('sale.order')
79 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
80 invoice_id = self.search(cr, uid, [('origin','=',so.name),('state','=','paid')])
81 assert invoice_id, "Invoice for SO is not in done state."
83 I check that Paid has been set to true.
85 !python {model: sale.order}: |
86 sale_id=self.browse(cr, uid, ref("sale_order_so1"))
87 assert(sale_id.invoiced == True), "Paid has not been set to true"
89 I verify the picking associated with the sale order sale_order_so1
91 !python {model: sale.order}: |
92 so = self.browse(cr, uid, ref("sale_order_so1"))
93 assert so.picking_ids,"Picking has not been generated"
95 Products are delivered to the Cleartrail Customer.
97 !python {model: stock.picking }: |
99 sale_order_obj = self.pool.get('sale.order')
100 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
101 picking_id = self.search(cr, uid, [('origin','=',so.name),('type','=','out')])
103 pick=self.browse(cr,uid,picking_id[0])
104 pick.force_assign(cr, uid)
106 'partner_id':pick.address_id.partner_id.id,
107 'address_id': pick.address_id.id,
108 'delivery_date' : time.strftime('%Y-%m-%d'),
110 move = pick.move_lines[0]
111 partial_datas['move%s'%(move.id)]= {
112 'product_id': move.product_id.id,
113 'product_qty': move.product_qty,
114 'product_uom': move.product_uom.id,
116 self.do_partial(cr, uid, [pick.id],partial_datas)
118 I verify that picking order is in done state.
120 !python {model: stock.picking }: |
121 sale_order_obj = self.pool.get('sale.order')
122 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
123 picking_id = self.search(cr, uid, [('origin','=',so.name),('type','=','out')])
124 pick = self.browse(cr,uid,picking_id[0])
125 assert (pick.state) =='done', "Picking for SO is not in done state."
127 I verify that a procurement has been generated for so
129 !python {model: procurement.order}: |
130 from tools.translate import _
131 sale_order_obj = self.pool.get('sale.order')
132 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
133 proc_ids = self.search(cr, uid, [('origin','=',so.name)])
134 assert proc_ids, _('No Procurements!')
136 Then I click on the "Run Procurement" button
138 !python {model: procurement.order}: |
139 sale_order_obj = self.pool.get('sale.order')
140 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
142 wf_service = netsvc.LocalService("workflow")
143 proc_ids = self.search(cr, uid, [('origin','=',so.name)])
144 for proc in proc_ids:
145 wf_service.trg_validate(uid, 'procurement.order',proc,'button_check', cr)
147 I verify that a procurement state is "running"
149 !python {model: procurement.order}: |
150 from tools.translate import _
151 modules = self.pool.get('ir.module.module')
152 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
153 mod_brw = modules.browse(cr,uid,mod_pur)[0]
154 if(mod_brw.state == 'installed'):
155 sale_order_obj = self.pool.get('sale.order')
156 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
157 proc_ids = self.search(cr, uid, [('origin','=',so.name),('state','=','running')])
158 assert proc_ids, _('Procurement is not in the running state!')
160 I verify that a purchase order has been generated
162 !python {model: sale.order}: |
163 from tools.translate import _
164 modules = self.pool.get('ir.module.module')
165 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
166 mod_brw = modules.browse(cr,uid,mod_pur)[0]
167 if(mod_brw.state == 'installed'):
168 so = self.browse(cr, uid, ref("sale_order_so1"))
169 pur_obj=self.pool.get('purchase.order')
170 pur_id=pur_obj.search(cr, uid, [('origin','=',so.name)])
171 assert pur_id, _('Purchase order has not been generated')
173 I click on the "Confirm" button to confirm the purchase order
175 !python {model: sale.order}: |
176 from tools.translate import _
177 modules = self.pool.get('ir.module.module')
178 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
179 mod_brw = modules.browse(cr,uid,mod_pur)[0]
180 if(mod_brw.state == 'installed'):
181 pur_obj=self.pool.get('purchase.order')
182 so = self.browse(cr, uid, ref("sale_order_so1"))
184 wf_service = netsvc.LocalService("workflow")
185 pur_ids = pur_obj.search(cr, uid, [('origin','=',so.name)])
187 wf_service.trg_validate(uid, 'purchase.order',pur,'purchase_confirm', cr)
189 I click on the "Approved by supplier" button to approve the purchase order
191 !python {model: sale.order}: |
192 from tools.translate import _
193 modules = self.pool.get('ir.module.module')
194 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
195 mod_brw = modules.browse(cr,uid,mod_pur)[0]
196 if (mod_brw.state == 'installed'):
197 pur_obj = self.pool.get('purchase.order')
198 so = self.browse(cr, uid, ref("sale_order_so1"))
200 wf_service = netsvc.LocalService("workflow")
201 pur_ids = pur_obj.search(cr, uid, [('origin','=',so.name)])
203 wf_service.trg_validate(uid, 'purchase.order',pur,'purchase_approve', cr)
205 I verify that a picking related to purchase order has been generated.
207 !python {model: sale.order}: |
208 modules = self.pool.get('ir.module.module')
209 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
210 mod_brw = modules.browse(cr,uid,mod_pur)[0]
211 if (mod_brw.state == 'installed'):
212 pur_obj = self.pool.get('purchase.order')
213 so = self.browse(cr, uid, ref("sale_order_so1"))
214 pur_id = pur_obj.search(cr, uid, [('origin','=',so.name)])
215 po = pur_obj.browse(cr, uid, pur_id)[0]
216 assert(po.picking_ids),"Picking for purchase order has not been generated"
218 Then I click on the "Products Received" button of Incoming Shipments
220 !record {model: stock.partial.picking, id: stock_partial_picking_0}:
221 date: '2010-07-20 17:52:09'
223 I click on the "Validate" button
225 !python {model: stock.picking}: |
226 modules = self.pool.get('ir.module.module')
227 sale_order_obj = self.pool.get('sale.order')
228 pur_obj = self.pool.get('purchase.order')
229 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
230 mod_brw = modules.browse(cr,uid,mod_pur)[0]
231 if (mod_brw.state == 'installed'):
232 so = sale_order_obj.browse(cr, uid, ref("sale_order_so1"))
233 pur_id = pur_obj.search(cr, uid, [('origin','=',so.name)])
234 po = pur_obj.browse(cr, uid, pur_id)[0]
235 pick_ser_id = self.search(cr, uid, [('purchase_id', '=', po.id )])
237 wf_service = netsvc.LocalService("workflow")
238 for pick in pick_ser_id:
239 wf_service.trg_validate(uid, 'stock.picking',pick,'button_done', cr)
241 I verify that picking for purchase order has been done.
243 !python {model: sale.order}: |
244 from tools.translate import _
245 modules = self.pool.get('ir.module.module')
246 mod_pur = modules.search(cr, uid, [('name','=','purchase')])
247 mod_brw = modules.browse(cr,uid,mod_pur)[0]
248 if(mod_brw.state == 'installed'):
249 pur_obj = self.pool.get('purchase.order')
250 so = self.browse(cr, uid, ref("sale_order_so1"))
251 pur_id = pur_obj.search(cr, uid, [('origin','=',so.name)])
252 po = pur_obj.browse(cr, uid, pur_id)[0]
253 picking_obj = self.pool.get('stock.picking')
254 ids = picking_obj.search(cr, uid, [('purchase_id', '=', po.id ),('state', '=', 'done')])
255 assert ids, _('Picking is not in the done state!')
257 I verify that a "Picked" has been set to true
259 !python {model: sale.order}: |
260 so = self.browse(cr, uid, ref("sale_order_so1"))
261 assert (so.shipped == True), "Picking is not done."
263 I verify that a sale order is in done state
265 !python {model: sale.order}: |
266 so = self.browse(cr, uid, ref("sale_order_so1"))
267 assert (so.state == 'done'), "Sale order is not in the done state."