- Updates Sending Queue worker/tasks/unit tests use model's method to get/save rendered newsletter body
This commit is contained in:
@ -35,10 +35,6 @@ class SendingQueue {
|
||||
$queue->delete();
|
||||
continue;
|
||||
}
|
||||
if(is_null($queue->newsletter_rendered_body)) {
|
||||
$queue->newsletter_rendered_body = json_encode($newsletter->_transient->rendered_body);
|
||||
$queue->save();
|
||||
}
|
||||
// configure mailer
|
||||
$this->mailer_task->configureMailer($newsletter);
|
||||
// get subscribers
|
||||
|
@ -7,23 +7,22 @@ use MailPoet\Util\Helpers;
|
||||
if(!defined('ABSPATH')) exit;
|
||||
|
||||
class Links {
|
||||
static function process($newsletter, $queue) {
|
||||
list($rendered_body, $links) =
|
||||
self::hashAndReplaceLinks($newsletter->_transient->rendered_body);
|
||||
static function process($rendered_newsletter, $newsletter, $queue) {
|
||||
list($rendered_newsletter, $links) =
|
||||
self::hashAndReplaceLinks($rendered_newsletter);
|
||||
self::saveLinks($links, $newsletter, $queue);
|
||||
$newsletter->_transient->rendered_body = $rendered_body;
|
||||
return $newsletter;
|
||||
return $rendered_newsletter;
|
||||
}
|
||||
|
||||
static function hashAndReplaceLinks($newsletter_rendered_body) {
|
||||
static function hashAndReplaceLinks($rendered_newsletter) {
|
||||
// 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);
|
||||
// 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);
|
||||
return array(
|
||||
$newsletter_rendered_body,
|
||||
$rendered_newsletter,
|
||||
$links
|
||||
);
|
||||
}
|
||||
|
@ -29,39 +29,42 @@ class Newsletter {
|
||||
// if the newsletter was previously rendered, return it
|
||||
// otherwise, process/render it
|
||||
if(!is_null($queue->newsletter_rendered_body)) {
|
||||
$newsletter->_transient->rendered_body = $queue->getRenderedNewsletterBody();
|
||||
return $newsletter;
|
||||
}
|
||||
// if tracking is enabled, do additional processing
|
||||
if($this->tracking_enabled) {
|
||||
// hook to the newsletter post-processing filter and add tracking image
|
||||
$this->tracking_image_inserted = OpenTracking::addTrackingImage();
|
||||
// render newsletter
|
||||
$newsletter->_transient->rendered_body = $newsletter->render();
|
||||
// render newsletter and save its
|
||||
$rendered_newsletter = $newsletter->render();
|
||||
// hash and save all links
|
||||
$newsletter = LinksTask::process($newsletter, $queue);
|
||||
$rendered_newsletter = LinksTask::process($rendered_newsletter, $newsletter, $queue);
|
||||
} else {
|
||||
// render newsletter
|
||||
$newsletter->_transient->rendered_body = $newsletter->render();
|
||||
$rendered_newsletter = $newsletter->render();
|
||||
}
|
||||
// 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) {
|
||||
return false;
|
||||
}
|
||||
// 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;
|
||||
}
|
||||
|
||||
function prepareNewsletterForSending($newsletter, $subscriber, $queue) {
|
||||
// shortcodes and links will be replaced in the subject, html and text body
|
||||
// to speed the processing, join content into a continuous string
|
||||
$rendered_newsletter = $queue->getNewsletterRenderedBody();
|
||||
$prepared_newsletter = Helpers::joinObject(
|
||||
array(
|
||||
$newsletter->subject,
|
||||
$newsletter->_transient->rendered_body['html'],
|
||||
$newsletter->_transient->rendered_body['text']
|
||||
$rendered_newsletter['html'],
|
||||
$rendered_newsletter['text']
|
||||
)
|
||||
);
|
||||
$prepared_newsletter = ShortcodesTask::process(
|
||||
|
@ -7,13 +7,10 @@ use MailPoet\Models\NewsletterPost;
|
||||
if(!defined('ABSPATH')) exit;
|
||||
|
||||
class Posts {
|
||||
static function extractAndSave($newsletter) {
|
||||
if(empty($newsletter->_transient->rendered_body['html']) || empty($newsletter->id)) {
|
||||
return false;
|
||||
}
|
||||
static function extractAndSave($rendered_newsletter, $newsletter) {
|
||||
preg_match_all(
|
||||
'/data-post-id="(\d+)"/ism',
|
||||
$newsletter->_transient->rendered_body['html'],
|
||||
$rendered_newsletter['html'],
|
||||
$matched_posts_ids);
|
||||
$matched_posts_ids = $matched_posts_ids[1];
|
||||
if(!count($matched_posts_ids)) {
|
||||
|
@ -24,11 +24,11 @@ class LinkTaskTest extends MailPoetTest {
|
||||
}
|
||||
|
||||
function testItCanHashAndReplaceLinks() {
|
||||
$rendered_newsletter_body = array(
|
||||
$rendered_newsletter = array(
|
||||
'html' => '<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_and_hashed_links = $result[1];
|
||||
expect($processed_rendered_newsletter_body['html'])
|
||||
@ -42,15 +42,15 @@ class LinkTaskTest extends MailPoetTest {
|
||||
$newsletter = Newsletter::create();
|
||||
$newsletter->type = Newsletter::TYPE_STANDARD;
|
||||
$newsletter->save();
|
||||
$newsletter->_transient->rendered_body = array(
|
||||
$rendered_newsletter = array(
|
||||
'html' => '<a href="http://example.com">Example Link</a>',
|
||||
'text' => '<a href="http://example.com">Example Link</a>'
|
||||
);
|
||||
$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)
|
||||
->findOne();
|
||||
expect($result->_transient->rendered_body['html'])->contains($newsletter_link->hash);
|
||||
expect($result['html'])->contains($newsletter_link->hash);
|
||||
}
|
||||
|
||||
function _after() {
|
||||
|
@ -64,35 +64,39 @@ class NewsletterTaskTest extends MailPoetTest {
|
||||
expect($this->newsletter_task->getAndPreProcess($queue))->false();
|
||||
}
|
||||
|
||||
function testItReturnsRenderedNewsletterBodyWhenItExists() {
|
||||
function testItReturnsNewsletterObjectWhenRenderedNewssletterBodyExistsInTheQueue() {
|
||||
$queue = $this->queue;
|
||||
$queue->newsletter_rendered_body = json_encode('Sample newsletter');
|
||||
$queue->newsletter_rendered_body = true;
|
||||
$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() {
|
||||
$newsletter_task = $this->newsletter_task;
|
||||
$newsletter_task->tracking_enabled = true;
|
||||
$result = $newsletter_task->getAndPreProcess($this->queue);
|
||||
$newsletter_task->getAndPreProcess($this->queue);
|
||||
$link = NewsletterLink::where('newsletter_id', $this->newsletter->id)
|
||||
->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);
|
||||
expect($result->_transient->rendered_body['html'])
|
||||
expect($rendered_newsletter['html'])
|
||||
->contains('[mailpoet_open_data]');
|
||||
}
|
||||
|
||||
function testItDoesNotHashLinksAndInsertTrackingCodeWhenTrackingIsDisabled() {
|
||||
$newsletter_task = $this->newsletter_task;
|
||||
$newsletter_task->tracking_enabled = false;
|
||||
$result = $newsletter_task->getAndPreProcess($this->queue);
|
||||
$newsletter_task->getAndPreProcess($this->queue);
|
||||
$link = NewsletterLink::where('newsletter_id', $this->newsletter->id)
|
||||
->findOne();
|
||||
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]');
|
||||
expect($result->_transient->rendered_body['html'])
|
||||
expect($rendered_newsletter['html'])
|
||||
->notContains('[mailpoet_open_data]');
|
||||
}
|
||||
|
||||
|
@ -7,34 +7,26 @@ use MailPoet\Models\NewsletterPost;
|
||||
if(!defined('ABSPATH')) exit;
|
||||
|
||||
class PostsTaskTest extends MailPoetTest {
|
||||
function testItFailsWhenNewsletterDoesNotExist() {
|
||||
expect(PostsTask::extractAndSave($newsletter = false))->equals(false);
|
||||
}
|
||||
|
||||
function testItFailsWhenNoPostsArePresent() {
|
||||
$newsletter = (object)array(
|
||||
'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() {
|
||||
$post_id = 10;
|
||||
$newsletter = (object)array(
|
||||
'id' => 1,
|
||||
'type' => Newsletter::TYPE_STANDARD,
|
||||
'_transient' => (object)array(
|
||||
'rendered_body' => array(
|
||||
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
|
||||
)
|
||||
)
|
||||
'type' => Newsletter::TYPE_STANDARD
|
||||
);
|
||||
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)
|
||||
->findOne();
|
||||
expect($newsletter_post->post_id)->equals($post_id);
|
||||
@ -45,14 +37,12 @@ class PostsTaskTest extends MailPoetTest {
|
||||
$newsletter = (object)array(
|
||||
'id' => 2,
|
||||
'parent_id' => 1,
|
||||
'type' => Newsletter::TYPE_NOTIFICATION_HISTORY,
|
||||
'_transient' => (object)array(
|
||||
'rendered_body' => array(
|
||||
'html' => '<a data-post-id="' . $post_id . '" href="#">sample post</a>'
|
||||
)
|
||||
)
|
||||
'type' => Newsletter::TYPE_NOTIFICATION_HISTORY
|
||||
);
|
||||
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)
|
||||
->findOne();
|
||||
expect($newsletter_post->post_id)->equals($post_id);
|
||||
|
Reference in New Issue
Block a user