Mayur Maheshwari(OpenERP) has proposed merging
lp:~openerp-dev/openobject-addons/trunk-account_voucher_yml-mma into
lp:~openerp-dev/openobject-addons/trunk-account_voucher_yml.
Requested reviews:
OpenERP R&D Team (openerp-dev)
For more details, see:
https://code.launchpad.net/~openerp-dev/openobject-addons/trunk-account_voucher_yml-mma/+merge/100914
Hello,
Account_voucher: I Have Added yaml test file which test the case of this bug
[https://bugs.launchpad.net/openobject-addons/+bug/954155]
Thanks.
mma
--
https://code.launchpad.net/~openerp-dev/openobject-addons/trunk-account_voucher_yml-mma/+merge/100914
Your team OpenERP R&D Team is requested to review the proposed merge of
lp:~openerp-dev/openobject-addons/trunk-account_voucher_yml-mma into
lp:~openerp-dev/openobject-addons/trunk-account_voucher_yml.
=== modified file 'account_voucher/__openerp__.py'
--- account_voucher/__openerp__.py 2012-02-13 15:27:55 +0000
+++ account_voucher/__openerp__.py 2012-04-05 06:46:19 +0000
@@ -66,6 +66,7 @@
"test/case2_usd_eur_debtor_in_usd.yml",
"test/case3_eur_eur.yml",
"test/case4_cad_chf.yml",
+ "test/case_eur_usd.yml",
],
'certificate': '0037580727101',
"auto_install": False,
=== added file 'account_voucher/test/case_eur_usd.yml'
--- account_voucher/test/case_eur_usd.yml 1970-01-01 00:00:00 +0000
+++ account_voucher/test/case_eur_usd.yml 2012-04-05 06:46:19 +0000
@@ -0,0 +1,143 @@
+-
+ In order to check the payment with multi-currency in OpenERP,
+ I create Invoices in EUR and make Payment in USD based on the currency rating.
+-
+ I create currency rate for USD
+-
+ !record {model: res.currency.rate, id: usd_rate}:
+ currency_id: base.USD
+ name: !eval "'%s-05-01' %(datetime.now().year)"
+ rate: 1.400000
+-
+ I create a asset account with currency USD
+-
+ !record {model: account.account, id: account_eur_usd_id}:
+ currency_id: base.USD
+ name: "Bank usd"
+ code: "BUSD"
+ type: 'liquidity'
+ user_type: account.data_account_type_asset
+-
+ I create a bank journal with USD as currency
+-
+ !record {model: account.journal, id: bank_journal_USD1}:
+ name: Bank Journal Test(USD)
+ code: BEUSD
+ type: bank
+ analytic_journal_id: account.sit
+ sequence_id: account.sequence_bank_journal
+ default_debit_account_id: account_eur_usd_id
+ default_credit_account_id: account_eur_usd_id
+ currency: base.USD
+ company_id: base.main_company
+ view_id: account.account_journal_bank_view
+-
+ I create a invoice
+-
+ !record {model: account.invoice, id: account_invoice_eur_usd}:
+ account_id: account.a_recv
+ company_id: base.main_company
+ currency_id: base.EUR
+ date_invoice: !eval "'%s-01-01' %(datetime.now().year)"
+ period_id: account.period_1
+ invoice_line:
+ - account_id: account.a_sale
+ name: '[PC1] Basic PC'
+ price_unit: 1000.0
+ quantity: 1.0
+ product_id: product.product_product_pc1
+ uos_id: product.product_uom_unit
+ journal_id: account.sales_journal
+ partner_id: base.res_partner_seagate
+-
+ I perform action to validate this invoice
+-
+ !workflow {model: account.invoice, action: invoice_open, ref: account_invoice_eur_usd}
+-
+ I check invoice move is correct
+-
+ !python {model: account.invoice}: |
+ invoice = self.browse(cr, uid, ref("account_invoice_eur_usd"))
+ assert invoice.state == 'open', "invoice state is not open"
+ assert invoice.period_id, "Period is not created for open invoice"
+ assert invoice.move_id, "Move not created for open invoice"
+ assert invoice.move_id.state == 'posted', "Move state is not posted"
+ for move_line in invoice.move_id.line_id:
+ assert move_line.state == 'valid', "Move line state is not valid"
+-
+ I set the context that will be used for the encoding of all the vouchers of this file
+-
+ !context
+ 'type': 'receipt'
+-
+ I create voucher for payment
+-
+ !record {model: account.voucher, id: account_voucher_eur_usd_case, view: view_vendor_receipt_form}:
+ account_id: account.cash
+ amount: 1350.0
+ company_id: base.main_company
+ journal_id: bank_journal_USD1
+ name: 'payment: Case EUR/USD'
+ partner_id: base.res_partner_seagate
+ period_id: account.period_5
+ date: !eval time.strftime("%Y-05-01")
+ payment_option: 'with_writeoff'
+ writeoff_acc_id: account.a_expense
+ comment: 'Write Off'
+-
+ I fill the full amount to the voucher
+-
+ !python {model: account.voucher}: |
+ data = []
+ voucher = self.browse(cr, uid, ref('account_voucher_eur_usd_case'))
+ for item in voucher.line_cr_ids:
+ if item.amount_unreconciled == item.amount_original:
+ data += [(item.id, item.amount_original)]
+ for line_id, amount in data:
+ self.pool.get('account.voucher.line').write(cr, uid, [line_id], {'amount': amount})
+ assert (voucher.state=='draft'), "Voucher is not in draft state"
+-
+ I check that writeoff amount computed is 50.0
+-
+ !python {model: account.voucher}: |
+ voucher = self.browse(cr, uid, ref('account_voucher_eur_usd_case'))
+ assert (voucher.writeoff_amount == 50.0), "Writeoff amount is not 50.0"
+-
+ I confirm the voucher
+-
+ !workflow {model: account.voucher, action: proforma_voucher, ref: account_voucher_eur_usd_case}
+-
+ I check that the voucher state is "Posted"
+-
+ !assert {model: account.voucher, id: account_voucher_eur_usd_case}:
+ - state == 'posted'
+-
+ I check a payment is created with proper data in voucher
+-
+ !python {model: account.voucher}: |
+ inv_obj = self.pool.get('account.invoice')
+ invoice = inv_obj.browse(cr, uid, ref('account_invoice_eur_usd'))
+ voucher = self.browse(cr, uid, ref('account_voucher_eur_usd_case'))
+ prec = self.pool.get('decimal.precision').precision_get(cr, uid, 'Account')
+ assert voucher.move_ids, "Move line is not created for this voucher"
+ assert (voucher.number == voucher.move_ids[0].move_id.name), "referance number is not created"
+ assert voucher.period_id, "period is not created"
+ for move_line in voucher.move_ids:
+ assert move_line.state == 'valid', "Voucher move is not valid"
+
+ rate = voucher.journal_id.currency.rate_ids[0].rate
+ assert (round(voucher.amount/rate, prec) == voucher.move_ids[2].debit),"debtor account is not correct"
+ assert (round(voucher.writeoff_amount/rate, prec) == voucher.move_ids[0].debit),"write off bank account is not correct"
+ assert (invoice.amount_total == voucher.move_ids[1].credit), " total reconcile is not correct of invoice"
+-
+ I check that the payment amount is created with proper data in customer invoice
+-
+ !python {model: account.invoice}: |
+ invoice = self.browse(cr, uid, ref("account_invoice_eur_usd"))
+ assert invoice.state == 'paid', "invoice is not paid"
+ payment_line = invoice.payment_ids[0]
+ assert payment_line, "payment line not created for paid invoice"
+ assert payment_line.state == 'valid', "payment move line state is not valid"
+ assert payment_line.debit == 0.0 and payment_line.credit == invoice.amount_total, "proper amount is not debit to payment account "
+ assert payment_line.reconcile_id, "reconcile is not created for paid invoice"
+
_______________________________________________
Mailing list: https://launchpad.net/~openerp-dev-gtk
Post to : [email protected]
Unsubscribe : https://launchpad.net/~openerp-dev-gtk
More help : https://help.launchpad.net/ListHelp