Compare commits
4 Commits
3.0.0-beta
...
3.0.0-beta
Author | SHA1 | Date | |
---|---|---|---|
18e2d26587 | |||
810a7bf544 | |||
1010c6f4f0 | |||
8dd698ec75 |
@ -43,10 +43,19 @@ class SendingQueue {
|
|||||||
self::BATCH_SIZE
|
self::BATCH_SIZE
|
||||||
);
|
);
|
||||||
foreach($subscriber_batches as $subscribers_to_process_ids) {
|
foreach($subscriber_batches as $subscribers_to_process_ids) {
|
||||||
|
if(!empty($newsletter_segments_ids[0])) {
|
||||||
|
// Check that subscribers are in segments
|
||||||
$found_subscribers = SubscriberModel::findSubscribersInSegments(
|
$found_subscribers = SubscriberModel::findSubscribersInSegments(
|
||||||
$subscribers_to_process_ids, $newsletter_segments_ids
|
$subscribers_to_process_ids, $newsletter_segments_ids
|
||||||
)->findMany();
|
)->findMany();
|
||||||
$found_subscribers_ids = SubscriberModel::extractSubscribersIds($found_subscribers);
|
$found_subscribers_ids = SubscriberModel::extractSubscribersIds($found_subscribers);
|
||||||
|
} else {
|
||||||
|
// No segments = Welcome emails
|
||||||
|
$found_subscribers = SubscriberModel::whereIn('id', $subscribers_to_process_ids)
|
||||||
|
->whereNull('deleted_at')
|
||||||
|
->findMany();
|
||||||
|
$found_subscribers_ids = SubscriberModel::extractSubscribersIds($found_subscribers);
|
||||||
|
}
|
||||||
// if some subscribers weren't found, remove them from the processing list
|
// if some subscribers weren't found, remove them from the processing list
|
||||||
if(count($found_subscribers_ids) !== count($subscribers_to_process_ids)) {
|
if(count($found_subscribers_ids) !== count($subscribers_to_process_ids)) {
|
||||||
$subscibers_to_remove = array_diff(
|
$subscibers_to_remove = array_diff(
|
||||||
|
@ -4,7 +4,7 @@ if(!defined('ABSPATH')) exit;
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Plugin Name: MailPoet
|
* Plugin Name: MailPoet
|
||||||
* Version: 3.0.0-beta.23.1
|
* Version: 3.0.0-beta.23.2
|
||||||
* Plugin URI: http://www.mailpoet.com
|
* Plugin URI: http://www.mailpoet.com
|
||||||
* Description: Create and send beautiful email newsletters, autoresponders, and post notifications without leaving WordPress. This is a beta version of our brand new plugin!
|
* Description: Create and send beautiful email newsletters, autoresponders, and post notifications without leaving WordPress. This is a beta version of our brand new plugin!
|
||||||
* Author: MailPoet
|
* Author: MailPoet
|
||||||
@ -21,7 +21,7 @@ if(!defined('ABSPATH')) exit;
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
$mailpoet_plugin = array(
|
$mailpoet_plugin = array(
|
||||||
'version' => '3.0.0-beta.23.1',
|
'version' => '3.0.0-beta.23.2',
|
||||||
'filename' => __FILE__,
|
'filename' => __FILE__,
|
||||||
'path' => dirname(__FILE__),
|
'path' => dirname(__FILE__),
|
||||||
'autoloader' => dirname(__FILE__) . '/vendor/autoload.php',
|
'autoloader' => dirname(__FILE__) . '/vendor/autoload.php',
|
||||||
|
@ -3,7 +3,7 @@ Contributors: mailpoet, wysija
|
|||||||
Tags: newsletter, email, welcome email, post notification, autoresponder, signup, smtp
|
Tags: newsletter, email, welcome email, post notification, autoresponder, signup, smtp
|
||||||
Requires at least: 4.6
|
Requires at least: 4.6
|
||||||
Tested up to: 4.7.3
|
Tested up to: 4.7.3
|
||||||
Stable tag: 3.0.0-beta.23.1
|
Stable tag: 3.0.0-beta.23.2
|
||||||
Create and send beautiful emails and newsletters from WordPress.
|
Create and send beautiful emails and newsletters from WordPress.
|
||||||
|
|
||||||
== Description ==
|
== Description ==
|
||||||
@ -84,7 +84,7 @@ Our [support site](https://docs.mailpoet.com/) has plenty of articles. You can w
|
|||||||
|
|
||||||
== Changelog ==
|
== Changelog ==
|
||||||
|
|
||||||
= 3.0.0-beta.23.1 - 2017-03-14 =
|
= 3.0.0-beta.23.2 - 2017-03-14 =
|
||||||
* Improved: added plugin translations to Dutch, English (UK), French, German, Italian, Portuguese (Brazil), Portuguese (Portugal), Russian and Spanish languages. Thank you translators!
|
* Improved: added plugin translations to Dutch, English (UK), French, German, Italian, Portuguese (Brazil), Portuguese (Portugal), Russian and Spanish languages. Thank you translators!
|
||||||
* Fixed: unsubscribed subscriber will no longer receive newsletters (woops!). Thanks, Oskar;
|
* Fixed: unsubscribed subscriber will no longer receive newsletters (woops!). Thanks, Oskar;
|
||||||
* Fixed: previously scheduled send tasks are rescheduled when post notifications' scheduling options change. Thanks, Karen and Eric!
|
* Fixed: previously scheduled send tasks are rescheduled when post notifications' scheduling options change. Thanks, Karen and Eric!
|
||||||
|
@ -282,6 +282,54 @@ class SendingQueueTest extends MailPoetTest {
|
|||||||
expect($statistics)->notEquals(false);
|
expect($statistics)->notEquals(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function testItCanProcessWelcomeNewsletters() {
|
||||||
|
$this->newsletter->type = Newsletter::TYPE_WELCOME;
|
||||||
|
$this->newsletter_segment->delete();
|
||||||
|
|
||||||
|
$sending_queue_worker = new SendingQueueWorker(
|
||||||
|
$timer = false,
|
||||||
|
Stub::make(
|
||||||
|
new MailerTask(),
|
||||||
|
array(
|
||||||
|
'send' => Stub::exactly(1, function($newsletter, $subscriber) {
|
||||||
|
// newsletter body should not be empty
|
||||||
|
expect(!empty($newsletter['body']['html']))->true();
|
||||||
|
expect(!empty($newsletter['body']['text']))->true();
|
||||||
|
return true;
|
||||||
|
})
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
$sending_queue_worker->process();
|
||||||
|
|
||||||
|
// newsletter status is set to sent
|
||||||
|
$updated_newsletter = Newsletter::findOne($this->newsletter->id);
|
||||||
|
expect($updated_newsletter->status)->equals(Newsletter::STATUS_SENT);
|
||||||
|
|
||||||
|
// queue status is set to completed
|
||||||
|
$updated_queue = SendingQueue::findOne($this->queue->id);
|
||||||
|
expect($updated_queue->status)->equals(SendingQueue::STATUS_COMPLETED);
|
||||||
|
|
||||||
|
// queue subscriber processed/to process count is updated
|
||||||
|
$updated_queue->subscribers = $updated_queue->getSubscribers();
|
||||||
|
expect($updated_queue->subscribers)->equals(
|
||||||
|
array(
|
||||||
|
'to_process' => array(),
|
||||||
|
'processed' => array($this->subscriber->id)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
expect($updated_queue->count_total)->equals(1);
|
||||||
|
expect($updated_queue->count_processed)->equals(1);
|
||||||
|
expect($updated_queue->count_to_process)->equals(0);
|
||||||
|
|
||||||
|
// statistics entry should be created
|
||||||
|
$statistics = StatisticsNewsletters::where('newsletter_id', $this->newsletter->id)
|
||||||
|
->where('subscriber_id', $this->subscriber->id)
|
||||||
|
->where('queue_id', $this->queue->id)
|
||||||
|
->findOne();
|
||||||
|
expect($statistics)->notEquals(false);
|
||||||
|
}
|
||||||
|
|
||||||
function testItRemovesNonexistentSubscribersFromProcessingList() {
|
function testItRemovesNonexistentSubscribersFromProcessingList() {
|
||||||
$queue = $this->queue;
|
$queue = $this->queue;
|
||||||
$queue->subscribers = serialize(
|
$queue->subscribers = serialize(
|
||||||
|
Reference in New Issue
Block a user