mirror of
https://github.com/OCA/reporting-engine.git
synced 2025-02-16 16:30:38 +02:00
[ENH] Add option to auto encrypt password based on python syntax
This commit is contained in:
1
report_qweb_encrypt/tests/__init__.py
Normal file
1
report_qweb_encrypt/tests/__init__.py
Normal file
@@ -0,0 +1 @@
|
||||
from . import test_report_qweb_encrypt
|
||||
33
report_qweb_encrypt/tests/test_report_qweb_encrypt.py
Normal file
33
report_qweb_encrypt/tests/test_report_qweb_encrypt.py
Normal file
@@ -0,0 +1,33 @@
|
||||
# © 2016 Therp BV <http://therp.nl>
|
||||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl.html).
|
||||
from odoo.exceptions import ValidationError
|
||||
from odoo.tests.common import HttpCase
|
||||
|
||||
|
||||
class TestReportQwebEncrypt(HttpCase):
|
||||
|
||||
def test_report_qweb_no_encrypt(self):
|
||||
ctx = {"force_report_rendering": True}
|
||||
report = self.env.ref("web.action_report_internalpreview")
|
||||
report.encrypt = False
|
||||
pdf, _ = report.with_context(ctx).render_qweb_pdf([1])
|
||||
self.assertFalse(pdf.count(b"/Encrypt"))
|
||||
|
||||
def test_report_qweb_auto_encrypt(self):
|
||||
ctx = {"force_report_rendering": True}
|
||||
report = self.env.ref("web.action_report_internalpreview")
|
||||
report.encrypt = "auto"
|
||||
report.encrypt_password = False
|
||||
# If no encrypt_password, still not encrypted
|
||||
pdf, _ = report.with_context(ctx).render_qweb_pdf([1])
|
||||
self.assertFalse(pdf.count(b"/Encrypt"))
|
||||
# If invalid encrypt_password, show error
|
||||
report.encrypt_password = "invalid python syntax"
|
||||
with self.assertRaises(ValidationError):
|
||||
pdf, _ = report.with_context(ctx).render_qweb_pdf([1])
|
||||
# Valid python string for password
|
||||
report.encrypt_password = "'secretcode'"
|
||||
pdf, _ = report.with_context(ctx).render_qweb_pdf([1])
|
||||
self.assertTrue(pdf.count(b"/Encrypt"))
|
||||
|
||||
# TODO: test_report_qweb_manual_encrypt, require JS test?
|
||||
Reference in New Issue
Block a user