When pending approval check MSS key state every hour
[MAILPOET-2806]
This commit is contained in:
@ -2,9 +2,11 @@
|
|||||||
|
|
||||||
namespace MailPoet\Cron\Workers\KeyCheck;
|
namespace MailPoet\Cron\Workers\KeyCheck;
|
||||||
|
|
||||||
|
use MailPoet\Config\ServicesChecker;
|
||||||
use MailPoet\Mailer\Mailer;
|
use MailPoet\Mailer\Mailer;
|
||||||
use MailPoet\Services\Bridge;
|
use MailPoet\Services\Bridge;
|
||||||
use MailPoet\Settings\SettingsController;
|
use MailPoet\Settings\SettingsController;
|
||||||
|
use MailPoetVendor\Carbon\Carbon;
|
||||||
|
|
||||||
class SendingServiceKeyCheck extends KeyCheckWorker {
|
class SendingServiceKeyCheck extends KeyCheckWorker {
|
||||||
const TASK_TYPE = 'sending_service_key_check';
|
const TASK_TYPE = 'sending_service_key_check';
|
||||||
@ -12,8 +14,12 @@ class SendingServiceKeyCheck extends KeyCheckWorker {
|
|||||||
/** @var SettingsController */
|
/** @var SettingsController */
|
||||||
private $settings;
|
private $settings;
|
||||||
|
|
||||||
public function __construct(SettingsController $settings) {
|
/** @var ServicesChecker */
|
||||||
|
private $servicesChecker;
|
||||||
|
|
||||||
|
public function __construct(SettingsController $settings, ServicesChecker $servicesChecker) {
|
||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
|
$this->servicesChecker = $servicesChecker;
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -21,6 +27,15 @@ class SendingServiceKeyCheck extends KeyCheckWorker {
|
|||||||
return Bridge::isMPSendingServiceEnabled();
|
return Bridge::isMPSendingServiceEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getNextRunDate() {
|
||||||
|
// when key pending approval, check key sate every hour
|
||||||
|
if ($this->servicesChecker->isMailPoetAPIKeyPendingApproval()) {
|
||||||
|
$date = Carbon::createFromTimestamp($this->wp->currentTime('timestamp'));
|
||||||
|
return $date->addHour();
|
||||||
|
}
|
||||||
|
return parent::getNextRunDate();
|
||||||
|
}
|
||||||
|
|
||||||
public function checkKey() {
|
public function checkKey() {
|
||||||
$mssKey = $this->settings->get(Mailer::MAILER_CONFIG_SETTING_NAME)['mailpoet_api_key'];
|
$mssKey = $this->settings->get(Mailer::MAILER_CONFIG_SETTING_NAME)['mailpoet_api_key'];
|
||||||
$result = $this->bridge->checkMSSKey($mssKey);
|
$result = $this->bridge->checkMSSKey($mssKey);
|
||||||
|
@ -4,11 +4,13 @@ namespace MailPoet\Test\Cron\Workers\KeyCheck;
|
|||||||
|
|
||||||
use Codeception\Stub;
|
use Codeception\Stub;
|
||||||
use Codeception\Stub\Expected;
|
use Codeception\Stub\Expected;
|
||||||
|
use MailPoet\Config\ServicesChecker;
|
||||||
use MailPoet\Cron\Workers\KeyCheck\SendingServiceKeyCheck;
|
use MailPoet\Cron\Workers\KeyCheck\SendingServiceKeyCheck;
|
||||||
use MailPoet\Mailer\Mailer;
|
use MailPoet\Mailer\Mailer;
|
||||||
use MailPoet\Services\Bridge;
|
use MailPoet\Services\Bridge;
|
||||||
use MailPoet\Settings\SettingsController;
|
use MailPoet\Settings\SettingsController;
|
||||||
use MailPoet\Settings\SettingsRepository;
|
use MailPoet\Settings\SettingsRepository;
|
||||||
|
use MailPoetVendor\Carbon\Carbon;
|
||||||
use PHPUnit\Framework\MockObject\MockObject;
|
use PHPUnit\Framework\MockObject\MockObject;
|
||||||
|
|
||||||
class SendingServiceKeyCheckTest extends \MailPoetTest {
|
class SendingServiceKeyCheckTest extends \MailPoetTest {
|
||||||
@ -18,7 +20,10 @@ class SendingServiceKeyCheckTest extends \MailPoetTest {
|
|||||||
public function _before() {
|
public function _before() {
|
||||||
parent::_before();
|
parent::_before();
|
||||||
$this->mssKey = 'some_key';
|
$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() {
|
public function testItRequiresMailPoetMethodToBeSetUp() {
|
||||||
@ -27,6 +32,24 @@ class SendingServiceKeyCheckTest extends \MailPoetTest {
|
|||||||
expect($this->worker->checkProcessingRequirements())->true();
|
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() {
|
public function testItChecksMSSKey() {
|
||||||
$response = ['code' => Bridge::KEY_VALID];
|
$response = ['code' => Bridge::KEY_VALID];
|
||||||
/** @var MockObject $bridge */
|
/** @var MockObject $bridge */
|
||||||
|
Reference in New Issue
Block a user