- Updates Sending Queue worker/tasks/unit tests use model's method to get/save rendered newsletter body

This commit is contained in:
Vlad
2016-09-19 20:11:58 -04:00
parent e1caf49ea5
commit 1bf0988297
7 changed files with 54 additions and 65 deletions

View File

@ -35,10 +35,6 @@ class SendingQueue {
$queue->delete(); $queue->delete();
continue; continue;
} }
if(is_null($queue->newsletter_rendered_body)) {
$queue->newsletter_rendered_body = json_encode($newsletter->_transient->rendered_body);
$queue->save();
}
// configure mailer // configure mailer
$this->mailer_task->configureMailer($newsletter); $this->mailer_task->configureMailer($newsletter);
// get subscribers // get subscribers

View File

@ -7,23 +7,22 @@ use MailPoet\Util\Helpers;
if(!defined('ABSPATH')) exit; if(!defined('ABSPATH')) exit;
class Links { class Links {
static function process($newsletter, $queue) { static function process($rendered_newsletter, $newsletter, $queue) {
list($rendered_body, $links) = list($rendered_newsletter, $links) =
self::hashAndReplaceLinks($newsletter->_transient->rendered_body); self::hashAndReplaceLinks($rendered_newsletter);
self::saveLinks($links, $newsletter, $queue); self::saveLinks($links, $newsletter, $queue);
$newsletter->_transient->rendered_body = $rendered_body; return $rendered_newsletter;
return $newsletter;
} }
static function hashAndReplaceLinks($newsletter_rendered_body) { static function hashAndReplaceLinks($rendered_newsletter) {
// join HTML and TEXT rendered body into a text string // join HTML and TEXT rendered body into a text string
$content = Helpers::joinObject($newsletter_rendered_body); $content = Helpers::joinObject($rendered_newsletter);
list($content, $links) = NewsletterLinks::process($content); list($content, $links) = NewsletterLinks::process($content);
// split the processed body with hashed links back to HTML and TEXT // split the processed body with hashed links back to HTML and TEXT
list($newsletter_rendered_body['html'], $newsletter_rendered_body['text']) list($rendered_newsletter['html'], $rendered_newsletter['text'])
= Helpers::splitObject($content); = Helpers::splitObject($content);
return array( return array(
$newsletter_rendered_body, $rendered_newsletter,
$links $links
); );
} }

View File

@ -29,39 +29,42 @@ class Newsletter {
// if the newsletter was previously rendered, return it // if the newsletter was previously rendered, return it
// otherwise, process/render it // otherwise, process/render it
if(!is_null($queue->newsletter_rendered_body)) { if(!is_null($queue->newsletter_rendered_body)) {
$newsletter->_transient->rendered_body = $queue->getRenderedNewsletterBody();
return $newsletter; return $newsletter;
} }
// if tracking is enabled, do additional processing // if tracking is enabled, do additional processing
if($this->tracking_enabled) { if($this->tracking_enabled) {
// hook to the newsletter post-processing filter and add tracking image // hook to the newsletter post-processing filter and add tracking image
$this->tracking_image_inserted = OpenTracking::addTrackingImage(); $this->tracking_image_inserted = OpenTracking::addTrackingImage();
// render newsletter // render newsletter and save its
$newsletter->_transient->rendered_body = $newsletter->render(); $rendered_newsletter = $newsletter->render();
// hash and save all links // hash and save all links
$newsletter = LinksTask::process($newsletter, $queue); $rendered_newsletter = LinksTask::process($rendered_newsletter, $newsletter, $queue);
} else { } else {
// render newsletter // render newsletter
$newsletter->_transient->rendered_body = $newsletter->render(); $rendered_newsletter = $newsletter->render();
} }
// check if this is a post notification and if it contains posts // check if this is a post notification and if it contains posts
$newsletter_contains_posts = strpos($newsletter->_transient->rendered_body['html'], 'data-post-id'); $newsletter_contains_posts = strpos($rendered_newsletter['html'], 'data-post-id');
if($newsletter->type === 'notification' && !$newsletter_contains_posts) { if($newsletter->type === 'notification' && !$newsletter_contains_posts) {
return false; return false;
} }
// extract and save newsletter posts // extract and save newsletter posts
PostsTask::extractAndSave($newsletter); PostsTask::extractAndSave($rendered_newsletter, $newsletter);
// update queue with the rendered and pre-processed newsletter
$queue->newsletter_rendered_body = $rendered_newsletter;
$queue->save();
return $newsletter; return $newsletter;
} }
function prepareNewsletterForSending($newsletter, $subscriber, $queue) { function prepareNewsletterForSending($newsletter, $subscriber, $queue) {
// shortcodes and links will be replaced in the subject, html and text body // shortcodes and links will be replaced in the subject, html and text body
// to speed the processing, join content into a continuous string // to speed the processing, join content into a continuous string
$rendered_newsletter = $queue->getNewsletterRenderedBody();
$prepared_newsletter = Helpers::joinObject( $prepared_newsletter = Helpers::joinObject(
array( array(
$newsletter->subject, $newsletter->subject,
$newsletter->_transient->rendered_body['html'], $rendered_newsletter['html'],
$newsletter->_transient->rendered_body['text'] $rendered_newsletter['text']
) )
); );
$prepared_newsletter = ShortcodesTask::process( $prepared_newsletter = ShortcodesTask::process(

View File

@ -7,13 +7,10 @@ use MailPoet\Models\NewsletterPost;
if(!defined('ABSPATH')) exit; if(!defined('ABSPATH')) exit;
class Posts { class Posts {
static function extractAndSave($newsletter) { static function extractAndSave($rendered_newsletter, $newsletter) {
if(empty($newsletter->_transient->rendered_body['html']) || empty($newsletter->id)) {
return false;
}
preg_match_all( preg_match_all(
'/data-post-id="(\d+)"/ism', '/data-post-id="(\d+)"/ism',
$newsletter->_transient->rendered_body['html'], $rendered_newsletter['html'],
$matched_posts_ids); $matched_posts_ids);
$matched_posts_ids = $matched_posts_ids[1]; $matched_posts_ids = $matched_posts_ids[1];
if(!count($matched_posts_ids)) { if(!count($matched_posts_ids)) {

View File

@ -24,11 +24,11 @@ class LinkTaskTest extends MailPoetTest {
} }
function testItCanHashAndReplaceLinks() { function testItCanHashAndReplaceLinks() {
$rendered_newsletter_body = array( $rendered_newsletter = array(
'html' => '<a href="http://example.com">Example Link</a>', 'html' => '<a href="http://example.com">Example Link</a>',
'text' => '<a href="http://example.com">Example Link</a>' 'text' => '<a href="http://example.com">Example Link</a>'
); );
$result = Links::hashAndReplaceLinks($rendered_newsletter_body); $result = Links::hashAndReplaceLinks($rendered_newsletter);
$processed_rendered_newsletter_body = $result[0]; $processed_rendered_newsletter_body = $result[0];
$processed_and_hashed_links = $result[1]; $processed_and_hashed_links = $result[1];
expect($processed_rendered_newsletter_body['html']) expect($processed_rendered_newsletter_body['html'])
@ -42,15 +42,15 @@ class LinkTaskTest extends MailPoetTest {
$newsletter = Newsletter::create(); $newsletter = Newsletter::create();
$newsletter->type = Newsletter::TYPE_STANDARD; $newsletter->type = Newsletter::TYPE_STANDARD;
$newsletter->save(); $newsletter->save();
$newsletter->_transient->rendered_body = array( $rendered_newsletter = array(
'html' => '<a href="http://example.com">Example Link</a>', 'html' => '<a href="http://example.com">Example Link</a>',
'text' => '<a href="http://example.com">Example Link</a>' 'text' => '<a href="http://example.com">Example Link</a>'
); );
$queue = (object)array('id' => 2); $queue = (object)array('id' => 2);
$result = Links::process($newsletter, $queue); $result = Links::process($rendered_newsletter, $newsletter, $queue);
$newsletter_link = NewsletterLink::where('newsletter_id', $newsletter->id) $newsletter_link = NewsletterLink::where('newsletter_id', $newsletter->id)
->findOne(); ->findOne();
expect($result->_transient->rendered_body['html'])->contains($newsletter_link->hash); expect($result['html'])->contains($newsletter_link->hash);
} }
function _after() { function _after() {

View File

@ -64,35 +64,39 @@ class NewsletterTaskTest extends MailPoetTest {
expect($this->newsletter_task->getAndPreProcess($queue))->false(); expect($this->newsletter_task->getAndPreProcess($queue))->false();
} }
function testItReturnsRenderedNewsletterBodyWhenItExists() { function testItReturnsNewsletterObjectWhenRenderedNewssletterBodyExistsInTheQueue() {
$queue = $this->queue; $queue = $this->queue;
$queue->newsletter_rendered_body = json_encode('Sample newsletter'); $queue->newsletter_rendered_body = true;
$result = $this->newsletter_task->getAndPreProcess($queue); $result = $this->newsletter_task->getAndPreProcess($queue);
expect($result->_transient->rendered_body)->equals(json_decode($queue->newsletter_rendered_body)); expect($result instanceof \MailPoet\Models\Newsletter)->true();
} }
function testItHashesLinksAndInsertsTrackingImageWhenTrackingIsEnabled() { function testItHashesLinksAndInsertsTrackingImageWhenTrackingIsEnabled() {
$newsletter_task = $this->newsletter_task; $newsletter_task = $this->newsletter_task;
$newsletter_task->tracking_enabled = true; $newsletter_task->tracking_enabled = true;
$result = $newsletter_task->getAndPreProcess($this->queue); $newsletter_task->getAndPreProcess($this->queue);
$link = NewsletterLink::where('newsletter_id', $this->newsletter->id) $link = NewsletterLink::where('newsletter_id', $this->newsletter->id)
->findOne(); ->findOne();
expect($result->_transient->rendered_body['html']) $updated_queue = SendingQueue::findOne($this->queue->id);
$rendered_newsletter = $updated_queue->getNewsletterRenderedBody();
expect($rendered_newsletter['html'])
->contains('[mailpoet_click_data]-' . $link->hash); ->contains('[mailpoet_click_data]-' . $link->hash);
expect($result->_transient->rendered_body['html']) expect($rendered_newsletter['html'])
->contains('[mailpoet_open_data]'); ->contains('[mailpoet_open_data]');
} }
function testItDoesNotHashLinksAndInsertTrackingCodeWhenTrackingIsDisabled() { function testItDoesNotHashLinksAndInsertTrackingCodeWhenTrackingIsDisabled() {
$newsletter_task = $this->newsletter_task; $newsletter_task = $this->newsletter_task;
$newsletter_task->tracking_enabled = false; $newsletter_task->tracking_enabled = false;
$result = $newsletter_task->getAndPreProcess($this->queue); $newsletter_task->getAndPreProcess($this->queue);
$link = NewsletterLink::where('newsletter_id', $this->newsletter->id) $link = NewsletterLink::where('newsletter_id', $this->newsletter->id)
->findOne(); ->findOne();
expect($link)->false(); expect($link)->false();
expect($result->_transient->rendered_body['html']) $updated_queue = SendingQueue::findOne($this->queue->id);
$rendered_newsletter = $updated_queue->getNewsletterRenderedBody();
expect($rendered_newsletter['html'])
->notContains('[mailpoet_click_data]'); ->notContains('[mailpoet_click_data]');
expect($result->_transient->rendered_body['html']) expect($rendered_newsletter['html'])
->notContains('[mailpoet_open_data]'); ->notContains('[mailpoet_open_data]');
} }

View File

@ -7,34 +7,26 @@ use MailPoet\Models\NewsletterPost;
if(!defined('ABSPATH')) exit; if(!defined('ABSPATH')) exit;
class PostsTaskTest extends MailPoetTest { class PostsTaskTest extends MailPoetTest {
function testItFailsWhenNewsletterDoesNotExist() {
expect(PostsTask::extractAndSave($newsletter = false))->equals(false);
}
function testItFailsWhenNoPostsArePresent() { function testItFailsWhenNoPostsArePresent() {
$newsletter = (object)array( $newsletter = (object)array(
'id' => 1, 'id' => 1,
'_transient' => (object)array(
'rendered_body' => array(
'html' => 'Sample newsletter'
)
)
); );
expect(PostsTask::extractAndSave($newsletter))->equals(false); $rendered_newsletter = array(
'html' => 'Sample newsletter'
);
expect(PostsTask::extractAndSave($rendered_newsletter, $newsletter))->equals(false);
} }
function testItCanExtractAndSavePosts() { function testItCanExtractAndSavePosts() {
$post_id = 10; $post_id = 10;
$newsletter = (object)array( $newsletter = (object)array(
'id' => 1, 'id' => 1,
'type' => Newsletter::TYPE_STANDARD, 'type' => Newsletter::TYPE_STANDARD
'_transient' => (object)array(
'rendered_body' => array(
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
)
)
); );
expect(PostsTask::extractAndSave($newsletter))->equals(true); $rendered_newsletter = array(
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
);
expect(PostsTask::extractAndSave($rendered_newsletter, $newsletter))->equals(true);
$newsletter_post = NewsletterPost::where('newsletter_id', $newsletter->id) $newsletter_post = NewsletterPost::where('newsletter_id', $newsletter->id)
->findOne(); ->findOne();
expect($newsletter_post->post_id)->equals($post_id); expect($newsletter_post->post_id)->equals($post_id);
@ -45,14 +37,12 @@ class PostsTaskTest extends MailPoetTest {
$newsletter = (object)array( $newsletter = (object)array(
'id' => 2, 'id' => 2,
'parent_id' => 1, 'parent_id' => 1,
'type' => Newsletter::TYPE_NOTIFICATION_HISTORY, 'type' => Newsletter::TYPE_NOTIFICATION_HISTORY
'_transient' => (object)array(
'rendered_body' => array(
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
)
)
); );
expect(PostsTask::extractAndSave($newsletter))->equals(true); $rendered_newsletter = array(
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
);
expect(PostsTask::extractAndSave($rendered_newsletter, $newsletter))->equals(true);
$newsletter_post = NewsletterPost::where('newsletter_id', $newsletter->parent_id) $newsletter_post = NewsletterPost::where('newsletter_id', $newsletter->parent_id)
->findOne(); ->findOne();
expect($newsletter_post->post_id)->equals($post_id); expect($newsletter_post->post_id)->equals($post_id);