187 lines
6.8 KiB
PHP
187 lines
6.8 KiB
PHP
<?php
|
|
|
|
namespace MailPoet\Test\Cron\Workers;
|
|
|
|
use MailPoet\Cron\Workers\Bounce;
|
|
use MailPoet\Cron\Workers\Bounce\BounceTestMockAPI as MockAPI;
|
|
use MailPoet\Entities\NewsletterEntity;
|
|
use MailPoet\Entities\ScheduledTaskEntity;
|
|
use MailPoet\Entities\ScheduledTaskSubscriberEntity;
|
|
use MailPoet\Entities\SendingQueueEntity;
|
|
use MailPoet\Entities\StatisticsBounceEntity;
|
|
use MailPoet\Entities\SubscriberEntity;
|
|
use MailPoet\Mailer\Mailer;
|
|
use MailPoet\Models\ScheduledTask;
|
|
use MailPoet\Models\ScheduledTaskSubscriber;
|
|
use MailPoet\Newsletter\Sending\ScheduledTasksRepository;
|
|
use MailPoet\Newsletter\Sending\SendingQueuesRepository;
|
|
use MailPoet\Services\Bridge;
|
|
use MailPoet\Services\Bridge\API;
|
|
use MailPoet\Settings\SettingsController;
|
|
use MailPoet\Settings\SettingsRepository;
|
|
use MailPoet\Statistics\StatisticsBouncesRepository;
|
|
use MailPoet\Subscribers\SubscribersRepository;
|
|
use MailPoet\WP\Functions as WPFunctions;
|
|
use MailPoetVendor\Carbon\Carbon;
|
|
|
|
require_once('BounceTestMockAPI.php');
|
|
|
|
class BounceTest extends \MailPoetTest {
|
|
|
|
/** @var Bounce */
|
|
private $worker;
|
|
|
|
/** @var string[] */
|
|
private $emails;
|
|
|
|
/** @var SubscribersRepository */
|
|
private $subscribersRepository;
|
|
|
|
public function _before() {
|
|
parent::_before();
|
|
$this->cleanup();
|
|
$this->emails = [
|
|
'soft_bounce@example.com',
|
|
'hard_bounce@example.com',
|
|
'good_address@example.com',
|
|
];
|
|
$this->subscribersRepository = $this->diContainer->get(SubscribersRepository::class);
|
|
|
|
foreach ($this->emails as $email) {
|
|
$subscriber = new SubscriberEntity();
|
|
$subscriber->setStatus(SubscriberEntity::STATUS_SUBSCRIBED);
|
|
$subscriber->setEmail($email);
|
|
$this->subscribersRepository->persist($subscriber);
|
|
}
|
|
|
|
$this->worker = new Bounce(
|
|
$this->diContainer->get(SettingsController::class),
|
|
$this->subscribersRepository,
|
|
$this->diContainer->get(ScheduledTasksRepository::class),
|
|
$this->diContainer->get(SendingQueuesRepository::class),
|
|
$this->diContainer->get(StatisticsBouncesRepository::class),
|
|
$this->diContainer->get(Bridge::class)
|
|
);
|
|
|
|
$this->worker->api = new MockAPI();
|
|
$this->subscribersRepository->flush();
|
|
$this->entityManager->clear();
|
|
}
|
|
|
|
public function testItDefinesConstants() {
|
|
expect(Bounce::BATCH_SIZE)->equals(100);
|
|
}
|
|
|
|
public function testItCanInitializeBridgeAPI() {
|
|
$this->setMailPoetSendingMethod();
|
|
$worker = new Bounce(
|
|
$this->diContainer->get(SettingsController::class),
|
|
$this->subscribersRepository,
|
|
$this->diContainer->get(ScheduledTasksRepository::class),
|
|
$this->diContainer->get(SendingQueuesRepository::class),
|
|
$this->diContainer->get(StatisticsBouncesRepository::class),
|
|
$this->diContainer->get(Bridge::class)
|
|
);
|
|
$worker->init();
|
|
expect($worker->api instanceof API)->true();
|
|
}
|
|
|
|
public function testItRequiresMailPoetMethodToBeSetUp() {
|
|
expect($this->worker->checkProcessingRequirements())->false();
|
|
$this->setMailPoetSendingMethod();
|
|
expect($this->worker->checkProcessingRequirements())->true();
|
|
}
|
|
|
|
public function testItDeletesAllSubscribersIfThereAreNoSubscribersToProcessWhenPreparingTask() {
|
|
// 1st run - subscribers will be processed
|
|
$task = $this->createScheduledTask();
|
|
$this->worker->prepareTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::where('task_id', $task->id)->findMany())->notEmpty();
|
|
|
|
// 2nd run - nothing more to process, ScheduledTaskSubscriber will be cleaned up
|
|
$this->truncateEntity(SubscriberEntity::class);
|
|
$task = $this->createScheduledTask();
|
|
$this->worker->prepareTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::where('task_id', $task->id)->findMany())->isEmpty();
|
|
}
|
|
|
|
public function testItPreparesTask() {
|
|
$task = $this->createScheduledTask();
|
|
expect(ScheduledTaskSubscriber::getUnprocessedCount($task->id))->isEmpty();
|
|
$result = $this->worker->prepareTaskStrategy($task, microtime(true));
|
|
expect($result)->true();
|
|
expect(ScheduledTaskSubscriber::getUnprocessedCount($task->id))->notEmpty();
|
|
}
|
|
|
|
public function testItDeletesAllSubscribersIfThereAreNoSubscribersToProcessWhenProcessingTask() {
|
|
// prepare subscribers
|
|
$task = $this->createScheduledTask();
|
|
$this->worker->prepareTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::where('task_id', $task->id)->findMany())->notEmpty();
|
|
|
|
// process - no subscribers found, ScheduledTaskSubscriber will be cleaned up
|
|
$this->truncateEntity(SubscriberEntity::class);
|
|
$task = $this->createScheduledTask();
|
|
$this->worker->processTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::where('task_id', $task->id)->findMany())->isEmpty();
|
|
}
|
|
|
|
public function testItProcessesTask() {
|
|
$task = $this->createRunningTask();
|
|
$this->worker->prepareTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::getUnprocessedCount($task->id))->notEmpty();
|
|
$this->worker->processTaskStrategy($task, microtime(true));
|
|
expect(ScheduledTaskSubscriber::getProcessedCount($task->id))->notEmpty();
|
|
}
|
|
|
|
public function testItSetsSubscriberStatusAsBounced() {
|
|
$task = $this->createRunningTask();
|
|
$this->worker->processEmails($task, $this->emails);
|
|
|
|
$subscribers = $this->subscribersRepository->findAll();
|
|
|
|
expect($subscribers[0]->getStatus())->equals(SubscriberEntity::STATUS_SUBSCRIBED);
|
|
expect($subscribers[1]->getStatus())->equals(SubscriberEntity::STATUS_BOUNCED);
|
|
expect($subscribers[2]->getStatus())->equals(SubscriberEntity::STATUS_SUBSCRIBED);
|
|
}
|
|
|
|
private function setMailPoetSendingMethod() {
|
|
$settings = SettingsController::getInstance();
|
|
$settings->set(
|
|
Mailer::MAILER_CONFIG_SETTING_NAME,
|
|
[
|
|
'method' => 'MailPoet',
|
|
'mailpoet_api_key' => 'some_key',
|
|
]
|
|
);
|
|
}
|
|
|
|
private function createScheduledTask() {
|
|
$task = ScheduledTask::create();
|
|
$task->type = 'bounce';
|
|
$task->status = ScheduledTask::STATUS_SCHEDULED;
|
|
$task->scheduledAt = Carbon::createFromTimestamp(WPFunctions::get()->currentTime('timestamp'));
|
|
$task->save();
|
|
return $task;
|
|
}
|
|
|
|
private function createRunningTask() {
|
|
$task = ScheduledTask::create();
|
|
$task->type = 'bounce';
|
|
$task->status = null;
|
|
$task->scheduledAt = Carbon::createFromTimestamp(WPFunctions::get()->currentTime('timestamp'));
|
|
$task->save();
|
|
return $task;
|
|
}
|
|
|
|
public function cleanup() {
|
|
$this->diContainer->get(SettingsRepository::class)->truncate();
|
|
$this->truncateEntity(SubscriberEntity::class);
|
|
$this->truncateEntity(ScheduledTaskEntity::class);
|
|
$this->truncateEntity(ScheduledTaskSubscriberEntity::class);
|
|
$this->truncateEntity(StatisticsBounceEntity::class);
|
|
$this->truncateEntity(NewsletterEntity::class);
|
|
$this->truncateEntity(SendingQueueEntity::class);
|
|
}
|
|
}
|