update tests to check generated xml-data
This commit is contained in:
parent
7f433d9b80
commit
bd39ae228a
2 changed files with 193 additions and 0 deletions
|
@ -5,11 +5,14 @@
|
|||
|
||||
from decimal import Decimal
|
||||
from datetime import date
|
||||
from facturx import get_facturx_xml_from_pdf
|
||||
|
||||
from trytond.tests.test_tryton import ModuleTestCase, with_transaction
|
||||
from trytond.pool import Pool
|
||||
from trytond.transaction import Transaction
|
||||
from trytond.modules.company.tests import create_company, set_company
|
||||
from trytond.modules.account.tests import create_chart, get_fiscalyear
|
||||
from .xml_data import xml_from_pdf
|
||||
|
||||
|
||||
def set_invoice_sequences(fiscalyear):
|
||||
|
@ -89,6 +92,7 @@ class InvoiceTestCase(ModuleTestCase):
|
|||
'lines': [('create', [{
|
||||
'type': 'line',
|
||||
'quantity': 2.0,
|
||||
'description': 'Product 1',
|
||||
'unit': Uom.search([('symbol', '=', 'u')])[0].id,
|
||||
'unit_price': Decimal('50.0'),
|
||||
'taxes': [('add', [tax_lst[0].id])],
|
||||
|
@ -112,8 +116,15 @@ class InvoiceTestCase(ModuleTestCase):
|
|||
pool = Pool()
|
||||
Configuration = pool.get('account.configuration')
|
||||
Party = pool.get('party.party')
|
||||
Country = pool.get('country.country')
|
||||
ActionReport = pool.get('ir.action.report')
|
||||
ExportWiz = pool.get('account_invoice_xrechnung.runrep', type='wizard')
|
||||
Tax = pool.get('account.tax')
|
||||
|
||||
country_de, = Country.create([{
|
||||
'name': 'Germany',
|
||||
'code': 'DE',
|
||||
'code3': 'DEU'}])
|
||||
pty1, = Party.create([{
|
||||
'name': 'Payee',
|
||||
'addresses': [('create', [{
|
||||
|
@ -121,10 +132,18 @@ class InvoiceTestCase(ModuleTestCase):
|
|||
'street': 'Applicant Street 1',
|
||||
'postal_code': '12345',
|
||||
'city': 'Usertown',
|
||||
'country': country_de.id,
|
||||
}])],
|
||||
}])
|
||||
|
||||
company1 = create_company('m-ds')
|
||||
Party.write(*[
|
||||
[company1.party],
|
||||
{'addresses': [(
|
||||
'write',
|
||||
[company1.party.addresses[0]],
|
||||
{'country': country_de.id})]}])
|
||||
|
||||
with set_company(company1):
|
||||
with Transaction().set_context({'company': company1.id}):
|
||||
|
||||
|
@ -141,8 +160,78 @@ class InvoiceTestCase(ModuleTestCase):
|
|||
self.assertEqual(cfg1.xrechn_zugferd_report.name, 'Invoice')
|
||||
create_chart(company=company1, tax=True)
|
||||
self.prep_fiscalyear(company1)
|
||||
|
||||
tax, = Tax.search([('name', '=', '20% VAT')])
|
||||
Tax.write(*[
|
||||
[tax],
|
||||
{'unece_code': 'GST', 'unece_category_code': 'S'}])
|
||||
invoice = self.prep_invoice(pty1)
|
||||
|
||||
# start wizard with two selected records
|
||||
with Transaction().set_context({
|
||||
'active_ids': [invoice.id],
|
||||
'active_id': invoice.id,
|
||||
'active_model': 'account.invoice'}):
|
||||
|
||||
(sess_id, start_state, end_state) = ExportWiz.create()
|
||||
w_obj = ExportWiz(sess_id)
|
||||
self.assertEqual(start_state, 'start')
|
||||
self.assertEqual(end_state, 'end')
|
||||
result = ExportWiz.execute(sess_id, {}, start_state)
|
||||
|
||||
self.assertEqual(
|
||||
list(result['view']['defaults'].keys()), [
|
||||
'as_zip', 'edocument', 'invoice', 'state',
|
||||
'invoice.'])
|
||||
|
||||
data = {}
|
||||
for x in result['view']['defaults'].keys():
|
||||
if '.' in x:
|
||||
continue
|
||||
data[x] = result['view']['defaults'][x]
|
||||
setattr(w_obj.start, x, data[x])
|
||||
self.assertEqual(
|
||||
w_obj.start.edocument,
|
||||
'edocument.facturxext.invoice-ferd')
|
||||
self.assertEqual(w_obj.start.invoice, invoice)
|
||||
self.assertEqual(w_obj.start.as_zip, True)
|
||||
w_obj.start.as_zip = False
|
||||
data['as_zip'] = False
|
||||
|
||||
# (action, data)
|
||||
result = ExportWiz.execute(
|
||||
sess_id, {'start': data}, 'export')
|
||||
self.assertEqual(len(result['actions']), 1)
|
||||
(action, data) = result['actions'][0]
|
||||
|
||||
self.assertEqual(
|
||||
action['report_name'],
|
||||
'account_invoice_xrechnung.export')
|
||||
self.assertEqual(action['type'], 'ir.action.report')
|
||||
self.assertEqual(action['records'], 'selected')
|
||||
|
||||
# 2nd step, wizard told us which report we must execute
|
||||
ReportExport = pool.get(
|
||||
'account_invoice_xrechnung.export',
|
||||
type='report')
|
||||
data2 = {}
|
||||
data2.update(data)
|
||||
data2['action_id'] = action['id']
|
||||
data2['model'] = 'account.invoice'
|
||||
|
||||
(ext, pdfdata, dprint, fname) = ReportExport.execute(
|
||||
[data['invoice']], data2)
|
||||
|
||||
# extract xml
|
||||
(xml_fname, xml_frompdf) = get_facturx_xml_from_pdf(
|
||||
pdfdata)
|
||||
|
||||
self.assertEqual(xml_fname, 'factur-x.xml')
|
||||
self.assertEqual(
|
||||
xml_frompdf.decode('utf8'),
|
||||
xml_from_pdf % {
|
||||
'datetoday': date.today().strftime('%Y%m%d')})
|
||||
ExportWiz.delete(sess_id)
|
||||
|
||||
# end InvoiceTestCase
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue