mirror of
https://github.com/OCA/reporting-engine.git
synced 2025-02-16 16:30:38 +02:00
[IMP][FIX] py3o_report, py3o_report_fusion_server: Compute the availability of py3o report
Before this change it was not possible to install modules declaring py3o report into a non native format without specifying a Fusion server once the module py3o_report_fusion_server was installed. With theses changes, we now take care of the availability of the libreoffice runtime to display/log a warning message when the report is in a non native runtime.
This commit is contained in:
@@ -2,6 +2,8 @@
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
||||
import mock
|
||||
from odoo.exceptions import ValidationError
|
||||
from odoo.addons.report_py3o.models.ir_actions_report import \
|
||||
PY3O_CONVERSION_COMMAND_PARAMETER
|
||||
from odoo.addons.report_py3o.tests import test_report_py3o
|
||||
|
||||
|
||||
@@ -22,14 +24,31 @@ class TestReportPy3oFusionServer(test_report_py3o.TestReportPy3o):
|
||||
"py3o_server_id": py3o_server.id,
|
||||
"py3o_filetype": 'pdf',
|
||||
})
|
||||
self.py3o_server = py3o_server
|
||||
|
||||
def test_no_local_fusion_without_fusion_server(self):
|
||||
self.assertTrue(self.report.py3o_is_local_fusion)
|
||||
# Fusion server is only required if not local...
|
||||
self.report.write({
|
||||
"py3o_server_id": None,
|
||||
"py3o_is_local_fusion": True,
|
||||
})
|
||||
self.report.write({
|
||||
"py3o_server_id": self.py3o_server.id,
|
||||
"py3o_is_local_fusion": True,
|
||||
})
|
||||
self.report.write({
|
||||
"py3o_server_id": self.py3o_server.id,
|
||||
"py3o_is_local_fusion": False,
|
||||
})
|
||||
with self.assertRaises(ValidationError) as e:
|
||||
self.report.write({"py3o_server_id": None})
|
||||
self.report.write({
|
||||
"py3o_server_id": None,
|
||||
"py3o_is_local_fusion": False,
|
||||
})
|
||||
self.assertEqual(
|
||||
e.exception.name,
|
||||
"Can not use not native format in local fusion. "
|
||||
"You can not use remote fusion without Fusion server. "
|
||||
"Please specify a Fusion Server")
|
||||
|
||||
def test_reports_no_local_fusion(self):
|
||||
@@ -40,3 +59,41 @@ class TestReportPy3oFusionServer(test_report_py3o.TestReportPy3o):
|
||||
for options in self.env['py3o.pdf.options'].search([]):
|
||||
options_dict = options.odoo2libreoffice_options()
|
||||
self.assertIsInstance(options_dict, dict)
|
||||
|
||||
def test_py3o_report_availability(self):
|
||||
# if the report is not into a native format, we must have at least
|
||||
# a libreoffice runtime or a fusion server. Otherwise the report is
|
||||
# not usable and will fail at rutime.
|
||||
# This test could fails if libreoffice is not available on the server
|
||||
self.report.py3o_filetype = "odt"
|
||||
self.assertTrue(self.report.lo_bin_path)
|
||||
self.assertTrue(self.report.py3o_server_id)
|
||||
self.assertTrue(self.report.is_py3o_native_format)
|
||||
self.assertFalse(self.report.is_py3o_report_not_available)
|
||||
self.assertFalse(self.report.msg_py3o_report_not_available)
|
||||
|
||||
# specify a wrong lo bin path and a non native format.
|
||||
self.env['ir.config_parameter'].set_param(
|
||||
PY3O_CONVERSION_COMMAND_PARAMETER, "/wrong_path")
|
||||
self.report.py3o_filetype = "pdf"
|
||||
self.report.refresh()
|
||||
# no native and no bin path, everything is still OK since a fusion
|
||||
# server is specified.
|
||||
self.assertFalse(self.report.lo_bin_path)
|
||||
self.assertTrue(self.report.py3o_server_id)
|
||||
self.assertFalse(self.report.is_py3o_native_format)
|
||||
self.assertFalse(self.report.is_py3o_report_not_available)
|
||||
self.assertFalse(self.report.msg_py3o_report_not_available)
|
||||
|
||||
# if we remove the fusion server, the report becomes unavailable
|
||||
self.report.py3o_server_id = False
|
||||
self.assertTrue(self.report.is_py3o_report_not_available)
|
||||
self.assertTrue(self.report.msg_py3o_report_not_available)
|
||||
|
||||
# if we set a libreffice runtime, the report is available again
|
||||
self.env['ir.config_parameter'].set_param(
|
||||
PY3O_CONVERSION_COMMAND_PARAMETER, "libreoffice")
|
||||
self.report.refresh()
|
||||
self.assertTrue(self.report.lo_bin_path)
|
||||
self.assertFalse(self.report.is_py3o_report_not_available)
|
||||
self.assertFalse(self.report.msg_py3o_report_not_available)
|
||||
|
||||
Reference in New Issue
Block a user