[IMP] sale:-improvements in the yml file
[odoo/odoo.git] / addons / sale / test / prepaid_order_policy.yml
1 -    
2   I create a Sale Order for LG Viewty Smart for qty 500 having Shipping Policy is 'Payment Before Delivery'
3 -
4   !record {model: sale.order, id: sale_order_so1}:
5     date_order: '2010-07-20'
6     invoice_quantity: order
7     name: Test_SO001
8     order_line:
9       - name: Slider Mobile
10         price_unit: 200
11         product_uom: product.product_uom_unit
12         product_uom_qty: 500.0
13         state: draft
14         delay: 7.0
15         product_id: sale.product_product_slidermobile0
16         product_uos_qty: 500.0
17         th_weight: 0.0
18         type: make_to_order
19     order_policy: prepaid
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
26     shop_id: sale.shop
27 -
28   I confirm the sale order.
29 -
30   !workflow {model: sale.order, action: order_confirm, ref: sale_order_so1}
31 -
32   I verify whether the invoice has been generated for SO since Shipping policy is 'Payment Before Delivery'
33 -
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"
37 -
38   I verify there are no pickings attached to this sale order
39 -
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')])
44    if picking_id:
45     print "There is a picking attached to this sale order"
46 -
47   I open the Invoice for the SO.
48 -
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"))
52     import netsvc
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)
57 -
58   I assign an analytic journal to the Bank journal
59
60   !record {model: account.journal, id: sale.account_journal_bankjournal0}:
61     analytic_journal_id: account.cose_journal_sale
62 -
63   I pay the invoice
64 -
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'),
73         name='test002')
74 -
75   I verify the invoice is in done state or not. 
76 -
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."
82 -
83   I check that Paid has been set to true.
84 -
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"
88 -
89   I verify the picking associated with the sale order sale_order_so1
90 -
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"
94 -
95   Products are delivered to the Cleartrail Customer.
96 -
97   !python {model: stock.picking }: |
98    import time
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')])
102    if picking_id:
103       pick=self.browse(cr,uid,picking_id[0])
104       pick.force_assign(cr, uid)
105       partial_datas = {
106            'partner_id':pick.address_id.partner_id.id,
107             'address_id': pick.address_id.id,
108             'delivery_date' : time.strftime('%Y-%m-%d'),
109            }
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,
115       }
116       self.do_partial(cr, uid, [pick.id],partial_datas)
117 -
118   I verify that picking order is in done state.
119 -
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."
126 -
127   I verify that a procurement has been generated for so
128 -
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!')
135 -
136   Then I click on the "Run Procurement" button
137
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"))
141     import netsvc
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)
146 -
147   I verify that a procurement state is "running"
148 -
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!')
159 -
160   I verify that a purchase order has been generated
161 -
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')
172
173   I click on the "Confirm" button to confirm the purchase order
174 -
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"))
183         import netsvc
184         wf_service = netsvc.LocalService("workflow")
185         pur_ids = pur_obj.search(cr, uid, [('origin','=',so.name)])
186         for pur in pur_ids:
187           wf_service.trg_validate(uid, 'purchase.order',pur,'purchase_confirm', cr)
188
189   I click on the "Approved by supplier" button to approve the purchase order
190 -
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"))
199         import netsvc
200         wf_service = netsvc.LocalService("workflow")
201         pur_ids = pur_obj.search(cr, uid, [('origin','=',so.name)])
202         for pur in pur_ids:
203           wf_service.trg_validate(uid, 'purchase.order',pur,'purchase_approve', cr) 
204 -
205   I verify that a picking related to purchase order has been generated. 
206 -
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"
217 -
218   Then I click on the "Products Received" button of Incoming Shipments
219 -
220   !record {model: stock.partial.picking, id: stock_partial_picking_0}:
221     date: '2010-07-20 17:52:09'
222 -
223   I click on the "Validate" button
224 -
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 )])
236         import netsvc
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)
240 -
241   I verify that picking for purchase order has been done.
242 -
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!')
256 -
257   I verify that a "Picked" has been set to true 
258 -
259   !python {model: sale.order}: |
260     so = self.browse(cr, uid, ref("sale_order_so1"))
261     assert (so.shipped == True), "Picking is not done."
262 -
263   I verify that a sale order is in done state
264 -
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."