Files
piratepoet/mailpoet/tests/integration/Cron/Workers/InactiveSubscribersTest.php
2022-08-04 11:10:50 +02:00

142 lines
6.5 KiB
PHP

<?php
namespace MailPoet\Test\Cron\Workers;
use Codeception\Stub;
use MailPoet\Cron\CronHelper;
use MailPoet\Cron\Workers\InactiveSubscribers;
use MailPoet\DI\ContainerWrapper;
use MailPoet\Entities\ScheduledTaskEntity;
use MailPoet\Newsletter\Sending\ScheduledTasksRepository;
use MailPoet\Settings\SettingsController;
use MailPoet\Settings\TrackingConfig;
use MailPoet\Subscribers\InactiveSubscribersController;
use MailPoet\Subscribers\SubscribersRepository;
use MailPoetVendor\Carbon\Carbon;
class InactiveSubscribersTest extends \MailPoetTest {
public $cronHelper;
/** @var SettingsController */
private $settings;
/** @var ScheduledTasksRepository */
private $scheduledTasksRepository;
/** @var SubscribersRepository */
private $subscribersRepository;
public function _before() {
$this->settings = SettingsController::getInstance();
$this->scheduledTasksRepository = $this->diContainer->get(ScheduledTasksRepository::class);
$this->truncateEntity(ScheduledTaskEntity::class);
$this->settings->set('tracking.level', TrackingConfig::LEVEL_PARTIAL);
$this->cronHelper = ContainerWrapper::getInstance()->get(CronHelper::class);
$this->subscribersRepository = ContainerWrapper::getInstance()->get(SubscribersRepository::class);
parent::_before();
}
public function testItReactivateInactiveSubscribersWhenIntervalIsSetToNever() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 0);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub\Expected::never(),
'markActiveSubscribers' => Stub\Expected::never(),
'reactivateInactiveSubscribers' => Stub\Expected::once(),
], $this);
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$worker->processTaskStrategy(new ScheduledTaskEntity(), microtime(true));
$task = $this->scheduledTasksRepository->findOneBy(
['type' => InactiveSubscribers::TASK_TYPE, 'status' => ScheduledTaskEntity::STATUS_SCHEDULED]
);
assert($task instanceof ScheduledTaskEntity);
expect($task)->isInstanceOf(ScheduledTaskEntity::class);
expect($task->getScheduledAt())->greaterThan(new Carbon());
}
public function testItDoesNotRunWhenTrackingIsDisabled() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 10);
$this->settings->set('tracking.level', TrackingConfig::LEVEL_BASIC);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub\Expected::never(),
'markActiveSubscribers' => Stub\Expected::never(),
'reactivateInactiveSubscribers' => Stub\Expected::never(),
], $this);
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$worker->processTaskStrategy(new ScheduledTaskEntity(), microtime(true));
}
public function testItSchedulesNextRunWhenFinished() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 5);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub\Expected::once(1),
'markActiveSubscribers' => Stub\Expected::once(1),
'reactivateInactiveSubscribers' => Stub\Expected::never(),
], $this);
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$worker->processTaskStrategy(new ScheduledTaskEntity(), microtime(true));
$task = $this->scheduledTasksRepository->findOneBy(
['type' => InactiveSubscribers::TASK_TYPE, 'status' => ScheduledTaskEntity::STATUS_SCHEDULED]
);
assert($task instanceof ScheduledTaskEntity);
expect($task)->isInstanceOf(ScheduledTaskEntity::class);
expect($task->getScheduledAt())->greaterThan(new Carbon());
}
public function testRunBatchesUntilItIsFinished() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 5);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub::consecutive(InactiveSubscribers::BATCH_SIZE, InactiveSubscribers::BATCH_SIZE, 1, 0),
'markActiveSubscribers' => Stub::consecutive(InactiveSubscribers::BATCH_SIZE, 1, 0),
'reactivateInactiveSubscribers' => Stub\Expected::never(),
], $this);
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$task = new ScheduledTaskEntity();
$task->setMeta(['max_subscriber_id' => 2001 /* 3 iterations of BATCH_SIZE in markInactiveSubscribers */]);
$this->entityManager->persist($task);
$this->entityManager->flush();
$worker->processTaskStrategy($task, microtime(true));
expect($controllerMock->markInactiveSubscribers(5, 1000))->equals(0);
expect($controllerMock->markActiveSubscribers(5, 1000))->equals(0);
}
public function testItCanStopDeactivationIfMarkInactiveSubscribersReturnsFalse() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 5);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub\Expected::once(false),
'markActiveSubscribers' => Stub\Expected::once(1),
'reactivateInactiveSubscribers' => Stub\Expected::never(),
], $this);
$task = new ScheduledTaskEntity();
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$worker->processTaskStrategy($task, microtime(true));
$meta = $task->getMeta();
expect(isset($meta['last_subscriber_id']))->equals(false);
}
public function testThrowsAnExceptionWhenTimeIsOut() {
$this->settings->set('deactivate_subscriber_after_inactive_days', 5);
$controllerMock = Stub::make(InactiveSubscribersController::class, [
'markInactiveSubscribers' => Stub\Expected::once(InactiveSubscribers::BATCH_SIZE),
'markActiveSubscribers' => Stub\Expected::never(),
'reactivateInactiveSubscribers' => Stub\Expected::never(),
], $this);
$worker = new InactiveSubscribers($controllerMock, $this->settings, $this->diContainer->get(TrackingConfig::class), $this->subscribersRepository);
$this->expectException(\Exception::class);
$this->expectExceptionMessage('Maximum execution time has been reached.');
$worker->processTaskStrategy(new ScheduledTaskEntity(), microtime(true) - $this->cronHelper->getDaemonExecutionLimit());
}
}