Browse Source
Merge pull request #260 from oihane/8.0-fix-auto_qweb
Merge pull request #260 from oihane/8.0-fix-auto_qweb
[IMP] <base_report_auto_create_qweb> added button to fix #255pull/269/merge
Pedro M. Baeza
9 years ago
6 changed files with 112 additions and 6 deletions
-
1.travis.yml
-
7base_report_auto_create_qweb/__openerp__.py
-
32base_report_auto_create_qweb/models/report_xml.py
-
5base_report_auto_create_qweb/tests/__init__.py
-
66base_report_auto_create_qweb/tests/test_base_report_auto_create_qweb.py
-
7base_report_auto_create_qweb/views/report_xml_view.xml
@ -0,0 +1,5 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# (c) 2015 Oihane Crucelaegui - AvanzOSC |
|||
# License AGPL-3 - See http://www.gnu.org/licenses/agpl-3.0.html |
|||
|
|||
from . import test_base_report_auto_create_qweb |
@ -0,0 +1,66 @@ |
|||
# -*- coding: utf-8 -*- |
|||
# (c) 2015 Oihane Crucelaegui - AvanzOSC |
|||
# License AGPL-3 - See http://www.gnu.org/licenses/agpl-3.0.html |
|||
|
|||
import openerp.tests.common as common |
|||
from openerp import exceptions |
|||
|
|||
|
|||
class TestBaseReportAutoQwebCreate(common.TransactionCase): |
|||
|
|||
def setUp(self): |
|||
super(TestBaseReportAutoQwebCreate, self).setUp() |
|||
self.report_model = self.env['ir.actions.report.xml'] |
|||
self.duplicate_model = self.env['ir.actions.report.xml.duplicate'] |
|||
self.view_model = self.env['ir.ui.view'] |
|||
|
|||
def test_creation_html(self): |
|||
report_html = self.report_model.create({ |
|||
'name': 'Test 1', |
|||
'model': 'res.partner', |
|||
'report_type': 'qweb-html', |
|||
'report_name': 'test1.report_test', |
|||
}) |
|||
report_html.button_create_qweb() |
|||
view_num = self.view_model.search_count( |
|||
[('name', 'ilike', report_html.report_name.split('.')[1]), |
|||
('type', '=', 'qweb')]) |
|||
self.assertNotEqual(view_num, 0, 'There are not related views') |
|||
self.assertEqual(view_num, 1, 'Only one view must be created.') |
|||
|
|||
def test_creation_duplicate_pdf(self): |
|||
report_pdf = self.report_model.create({ |
|||
'name': 'Test 2', |
|||
'model': 'res.partner', |
|||
'report_type': 'qweb-pdf', |
|||
'report_name': 'test2.report_test', |
|||
}) |
|||
report_pdf.button_create_qweb() |
|||
view_num = self.view_model.search_count( |
|||
[('name', 'ilike', report_pdf.report_name.split('.')[1]), |
|||
('type', '=', 'qweb')]) |
|||
self.assertNotEqual(view_num, 0, 'There are not related views.') |
|||
self.assertEqual(view_num, 1, 'One view must be created.') |
|||
wizard = self.duplicate_model.with_context( |
|||
active_id=report_pdf.id, model=report_pdf.model).create({ |
|||
'suffix': 'copytest', |
|||
}) |
|||
wizard.duplicate_report() |
|||
report_pdf_copies = self.report_model.search( |
|||
[('report_name', 'ilike', 'test2_copytest.report_test_copytest')]) |
|||
for report_pdf_copy in report_pdf_copies: |
|||
view_num2 = self.view_model.search_count( |
|||
[('name', 'ilike', report_pdf_copy.report_name.split('.')[1]), |
|||
('type', '=', 'qweb')]) |
|||
self.assertNotEqual(view_num2, 0, 'There are not related views.') |
|||
self.assertEqual(view_num2, view_num, |
|||
'Same view numbers must have been created.') |
|||
|
|||
def test_wrong_template_name(self): |
|||
with self.assertRaises(exceptions.Warning): |
|||
self.report_model.create({ |
|||
'name': 'Test', |
|||
'model': 'res.partner', |
|||
'report_type': 'qweb-pdf', |
|||
'report_name': 'report_test', |
|||
}) |
Write
Preview
Loading…
Cancel
Save
Reference in new issue