Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
##############################################################################
#
# Redner Odoo module
# Copyright (C) 2023 XCG Consulting <https://xcg-consulting.fr>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
##############################################################################
import base64
import mock
from .common import TestCommon
class Test(TestCommon):
"""Test redner integration into report generation."""
def setUp(self):
"""Override set-up to prepare a report used in tests."""
super().setUp()
self.report = self.env["ir.actions.report"].create(
{
"attachment": 'object.login + ".html"', # auto-save
"model": "res.users",
"name": "test-report",
"redner_filetype": "html",
"redner_tmpl_id": self._create_redner_template().id,
"report_name": "test-report",
"report_type": "redner",
}
)
@mock.patch("requests.sessions.Session.post")
def test_report_rendering(self, requests_post_mock):
"""Fill substitutions & render a redner report."""
# Fill the substitution table. We have 1 param: {{ login }}.
requests_post_mock.return_value = mock.Mock(
status_code=200, json=lambda: ["login"]
)
self.assertFalse(self.report.substitution_ids)
self.report.action_get_substitutions()
requests_post_mock.assert_called_once_with(
"https://test-redner-url/api/v1/varlist",
json={"account": "test-account", "name": "test-redner-id"},
headers={"Rednerd-API-Key": "test-api-key"},
timeout=20,
)
requests_post_mock.reset_mock()
substitution = self.report.substitution_ids
self.assertEqual(len(substitution), 1)
self.assertEqual(substitution.keyword, "login")
substitution.converter = "field"
substitution.value = "login"
# Render our test report for the demo user.
requests_post_mock.return_value = mock.Mock(
status_code=200,
json=lambda: [{"body": base64.b64encode(b"test-rendered-report")}],
)
demo_user = self.env.ref("base.user_demo")
render_ret = self.report._render([demo_user.id])
requests_post_mock.assert_called_once_with(
"https://test-redner-url/api/v1/render",
json={
"accept": "text/html",
"data": [{"login": "demo"}],
"template": {
"account": "test-account",
"name": "test-redner-id",
},
"body-format": "base64",
"metadata": {},
},
headers={"Rednerd-API-Key": "test-api-key"},
timeout=20,
)
self.assertEqual(len(render_ret), 2)
self.assertEqual(render_ret[0], b"test-rendered-report")
self.assertEqual(render_ret[1], "html")
# Check attachment linked to the record (auto-save feature).
attachment = self.env["ir.attachment"].search(
[
("name", "=", "demo.html"),
("res_id", "=", demo_user.id),
("res_model", "=", demo_user._name),
]
)
self.assertEqual(len(attachment), 1)
self.assertEqual(
base64.b64decode(attachment.datas), b"test-rendered-report"
)