When pending approval check MSS key state every hour
[MAILPOET-2806]
This commit is contained in:
@@ -4,11 +4,13 @@ namespace MailPoet\Test\Cron\Workers\KeyCheck;
|
||||
|
||||
use Codeception\Stub;
|
||||
use Codeception\Stub\Expected;
|
||||
use MailPoet\Config\ServicesChecker;
|
||||
use MailPoet\Cron\Workers\KeyCheck\SendingServiceKeyCheck;
|
||||
use MailPoet\Mailer\Mailer;
|
||||
use MailPoet\Services\Bridge;
|
||||
use MailPoet\Settings\SettingsController;
|
||||
use MailPoet\Settings\SettingsRepository;
|
||||
use MailPoetVendor\Carbon\Carbon;
|
||||
use PHPUnit\Framework\MockObject\MockObject;
|
||||
|
||||
class SendingServiceKeyCheckTest extends \MailPoetTest {
|
||||
@@ -18,7 +20,10 @@ class SendingServiceKeyCheckTest extends \MailPoetTest {
|
||||
public function _before() {
|
||||
parent::_before();
|
||||
$this->mssKey = 'some_key';
|
||||
$this->worker = new SendingServiceKeyCheck($this->diContainer->get(SettingsController::class));
|
||||
$this->worker = new SendingServiceKeyCheck(
|
||||
$this->diContainer->get(SettingsController::class),
|
||||
$this->diContainer->get(ServicesChecker::class)
|
||||
);
|
||||
}
|
||||
|
||||
public function testItRequiresMailPoetMethodToBeSetUp() {
|
||||
@@ -27,6 +32,24 @@ class SendingServiceKeyCheckTest extends \MailPoetTest {
|
||||
expect($this->worker->checkProcessingRequirements())->true();
|
||||
}
|
||||
|
||||
public function testItRunsEveryHourWhenKeyPendingApproval() {
|
||||
// normally next run is scheduled at a start of next day
|
||||
expect($this->worker->getNextRunDate())->equals(Carbon::now()->startOfDay()->addDay());
|
||||
|
||||
// when pending key approval, next run is scheduled in an hour
|
||||
$settings = $this->diContainer->get(SettingsController::class);
|
||||
$settings->set(Mailer::MAILER_CONFIG_SETTING_NAME, ['method' => Mailer::METHOD_MAILPOET]);
|
||||
$settings->set(Bridge::API_KEY_SETTING_NAME, 'key');
|
||||
$settings->set(Bridge::API_KEY_STATE_SETTING_NAME, [
|
||||
'state' => Bridge::KEY_VALID,
|
||||
'data' => ['is_approved' => false],
|
||||
]);
|
||||
|
||||
$nextRunDate = $this->worker->getNextRunDate();
|
||||
expect($nextRunDate)->greaterThan(Carbon::now()->addMinutes(55));
|
||||
expect($nextRunDate)->lessThan(Carbon::now()->addMinutes(65));
|
||||
}
|
||||
|
||||
public function testItChecksMSSKey() {
|
||||
$response = ['code' => Bridge::KEY_VALID];
|
||||
/** @var MockObject $bridge */
|
||||
|
Reference in New Issue
Block a user