Browse Source
Merge pull request #273 from simahawk/11-imp-mail_digest
Merge pull request #273 from simahawk/11-imp-mail_digest
[11.0] mail_digest: fwd port improvements from v10pull/294/head
Pedro M. Baeza
7 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 313 additions and 8 deletions
-
8mail_digest/README.rst
-
1mail_digest/__init__.py
-
3mail_digest/__manifest__.py
-
1mail_digest/controllers/__init__.py
-
139mail_digest/controllers/digest_layout_preview.py
-
BINmail_digest/images/digest_layout_preview.png
-
24mail_digest/models/mail_digest.py
-
33mail_digest/templates/digest_default.xml
-
18mail_digest/templates/digest_layout_preview.xml
-
1mail_digest/tests/__init__.py
-
29mail_digest/tests/test_digest.py
-
62mail_digest/tests/test_preview.py
@ -1 +1,2 @@ |
|||
from . import controllers |
|||
from . import models |
@ -0,0 +1 @@ |
|||
from . import digest_layout_preview |
@ -0,0 +1,139 @@ |
|||
# Copyright 2018 Simone Orsi <simone.orsi@camptocamp.com> |
|||
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). |
|||
|
|||
from odoo import http |
|||
from odoo.http import request |
|||
import random |
|||
|
|||
|
|||
FAKE_NAMES = [ |
|||
'Madison Castillo', |
|||
'Destiny Frost', |
|||
'Dennis Parrish', |
|||
'Christy Moore', |
|||
'Larry James', |
|||
'David Simmons', |
|||
'Dr. Francis Ramos', |
|||
'Michelle Williams', |
|||
'Allison Montgomery', |
|||
'Michelle Rodriguez', |
|||
'Gina Patel', |
|||
'Corey Ray', |
|||
'Brent Myers', |
|||
'Sydney Hicks', |
|||
'Austin Buckley', |
|||
'Patricia Jones DDS', |
|||
'Dylan Davila', |
|||
'Christopher Bolton', |
|||
'James Cline', |
|||
'Gary Johnson', |
|||
'Jennifer Reese', |
|||
'Kevin Davis', |
|||
'Sandra Robinson', |
|||
'Sara Warner', |
|||
'Jaime Dunn', |
|||
'Mark Austin', |
|||
'Kendra Nelson', |
|||
'Matthew White', |
|||
'Rebecca Berger', |
|||
'Amanda Thornton', |
|||
'Lorraine Schultz', |
|||
'Chelsea Daniel', |
|||
'Kayla Jackson', |
|||
'Melanie Grant', |
|||
'Oscar Jones', |
|||
'Jon Sanchez', |
|||
'Kevin Anderson', |
|||
'Yvonne Mullen', |
|||
'Jonathan King', |
|||
'Wendy Hernandez' |
|||
] |
|||
|
|||
FAKE_NUMBERS = range(1, 30) |
|||
|
|||
|
|||
class DigestPreview(http.Controller): |
|||
|
|||
digest_test_template = 'mail_digest.digest_layout_preview' |
|||
|
|||
@http.route([ |
|||
'/digest/layout-preview', |
|||
], type='http', auth='user') |
|||
def digest_test(self): |
|||
digest = self._fake_digest() |
|||
mail_values = digest._get_email_values() |
|||
values = { |
|||
'env': request.env, |
|||
'digest_html': mail_values['body_html'], |
|||
} |
|||
return request.render(self.digest_test_template, values) |
|||
|
|||
def _fake_digest(self): |
|||
user = request.env.user |
|||
digest_model = request.env['mail.digest'].sudo() |
|||
digest = digest_model.new() |
|||
digest.partner_id = user.partner_id |
|||
digest.digest_template_id = digest._default_digest_template_id() |
|||
digest.message_ids = self._fake_messages() |
|||
digest.sanitize_msg_body = True |
|||
return digest |
|||
|
|||
def _fake_messages(self): |
|||
messages = request.env['mail.message'].sudo() |
|||
subtype_model = request.env['mail.message.subtype'].sudo() |
|||
subtypes = subtype_model.search([]) |
|||
records = request.env['res.partner'].sudo().search([]) |
|||
# TODO: filter subtypes? |
|||
for i, subtype in enumerate(subtypes): |
|||
# generate a couple of messages for each type |
|||
for x in range(1, 3): |
|||
msg = messages.new() |
|||
msg.subtype_id = subtype |
|||
subject, body = self._fake_content(subtype, i, x) |
|||
msg.subject = subject |
|||
msg.message_type = random.choice( |
|||
('email', 'comment', 'notification')) |
|||
msg.email_from = 'random@user%d.com' % i |
|||
msg.partner_ids = [(6, 0, request.env.user.partner_id.ids)] |
|||
if i + x % 2 == 0: |
|||
# relate a document |
|||
msg.model = records._name |
|||
msg.res_id = random.choice(records.ids) |
|||
# simulate messages w/ no body but tracking values |
|||
if x == random.choice([1, 2]): |
|||
msg.tracking_value_ids = self._fake_tracking_vals() |
|||
else: |
|||
msg.body = body |
|||
messages += msg |
|||
return messages |
|||
|
|||
def _fake_content(self, subtype, i, x): |
|||
subject = 'Lorem ipsum %d / %d' % (i, x) |
|||
body = 'Random text here lorem ipsum %d / %d' % (i, x) |
|||
if i % 2 == 0 and x > 1: |
|||
# simulate also random styles that are goin to be stripped |
|||
body = """ |
|||
<p style="font-size: 13px; font-family: "Lucida Grande", Helvetica, Verdana, Arial, sans-serif; margin: 0px 0px 9px 0px">Lorem ipsum dolor sit amet, cetero menandri mel id.</p> |
|||
|
|||
<p>Ad modus tantas qui, quo choro facete delicata te. |
|||
Epicurei accusata vix eu, prima erant graeci sit te, |
|||
vivendum molestiae an mel.</p> |
|||
|
|||
<p>Sed apeirian atomorum id, no ius possit antiopam molestiae.</p> |
|||
""" # noqa |
|||
return subject, body.strip() |
|||
|
|||
def _fake_tracking_vals(self): |
|||
tracking_model = request.env['mail.tracking.value'].sudo() |
|||
track_vals1 = tracking_model.create_tracking_values( |
|||
random.choice(FAKE_NAMES), random.choice(FAKE_NAMES), |
|||
'name', {'type': 'char', 'string': 'Name'}, |
|||
) |
|||
track_vals2 = tracking_model.create_tracking_values( |
|||
random.choice(FAKE_NUMBERS), random.choice(FAKE_NUMBERS), |
|||
'count', {'type': 'integer', 'string': 'Count'}, |
|||
) |
|||
return [ |
|||
(0, 0, track_vals1), |
|||
(0, 0, track_vals2), |
|||
] |
After Width: 691 | Height: 1022 | Size: 69 KiB |
@ -0,0 +1,18 @@ |
|||
<?xml version="1.0" encoding="UTF-8"?> |
|||
<odoo> |
|||
|
|||
<template id="digest_layout_preview" name="Mail digest layout preview"> |
|||
<style> |
|||
#digest_layout_wrapper { |
|||
max-width: 600px; |
|||
margin: 0 auto; |
|||
border: 1px dashed #ddd; |
|||
padding: 4em; |
|||
} |
|||
</style> |
|||
<div id="digest_layout_wrapper"> |
|||
<t t-raw="digest_html" /> |
|||
</div> |
|||
</template> |
|||
|
|||
</odoo> |
@ -1,3 +1,4 @@ |
|||
from . import test_digest |
|||
from . import test_partner_domains |
|||
from . import test_subtypes_conf |
|||
from . import test_preview |
@ -0,0 +1,62 @@ |
|||
# Copyright 2017 Simone Orsi <simone.orsi@camptocamp.com> |
|||
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl). |
|||
|
|||
from odoo.tests.common import SavepointCase |
|||
import mock |
|||
from ..controllers.digest_layout_preview import DigestPreview |
|||
|
|||
REQUEST_PATH = 'odoo.addons.mail_digest.controllers.digest_layout_preview' |
|||
|
|||
|
|||
class PreviewCase(SavepointCase): |
|||
"""Easy tests for preview controller to make codecov happy.""" |
|||
|
|||
@classmethod |
|||
def setUpClass(cls): |
|||
super(PreviewCase, cls).setUpClass() |
|||
cls.ctrl = DigestPreview() |
|||
|
|||
@mock.patch(REQUEST_PATH + '.request') |
|||
def test_fake_digest(self, patched_req): |
|||
patched_req.env = self.env |
|||
digest = self.ctrl._fake_digest() |
|||
self.assertEqual( |
|||
digest.partner_id, self.env.user.partner_id, |
|||
) |
|||
self.assertEqual( |
|||
digest.digest_template_id, digest._default_digest_template_id(), |
|||
) |
|||
self.assertTrue(digest.message_ids) |
|||
self.assertTrue(digest.sanitize_msg_body) |
|||
|
|||
@mock.patch(REQUEST_PATH + '.request') |
|||
def test_fake_messages(self, patched_req): |
|||
patched_req.env = self.env |
|||
all_types = self.env['mail.message.subtype'].search([]) |
|||
messages = self.ctrl._fake_messages() |
|||
self.assertEqual( |
|||
len(messages), len(all_types) * 2 |
|||
) |
|||
|
|||
@mock.patch(REQUEST_PATH + '.request') |
|||
def test_fake_content(self, patched_req): |
|||
patched_req.env = self.env |
|||
subj, body = self.ctrl._fake_content(None, 1, 2) |
|||
body = 'Random text here lorem ipsum 1 / 2' |
|||
self.assertEqual(subj, 'Lorem ipsum 1 / 2') |
|||
self.assertEqual(body, 'Random text here lorem ipsum 1 / 2') |
|||
subj, body = self.ctrl._fake_content(None, 2, 2) |
|||
self.assertEqual(subj, 'Lorem ipsum 2 / 2') |
|||
self.assertTrue(body.startswith('<p style="font-size: 13px;')) |
|||
|
|||
@mock.patch(REQUEST_PATH + '.request') |
|||
def test_fake_tracking_vals(self, patched_req): |
|||
patched_req.env = self.env |
|||
vals = self.ctrl._fake_tracking_vals() |
|||
self.assertEqual(len(vals), 2) |
|||
|
|||
@mock.patch(REQUEST_PATH + '.request') |
|||
def test_render(self, patched_req): |
|||
patched_req.env = self.env |
|||
html = self.ctrl.digest_test() |
|||
self.assertTrue(html) |
Write
Preview
Loading…
Cancel
Save
Reference in new issue