Use DI for Activator in Setup API

[MAILPOET-2014]
This commit is contained in:
Jan Jakeš
2019-07-05 17:42:56 +02:00
committed by M. Shull
parent 4cbc89368c
commit 80d0e7e0f7
2 changed files with 15 additions and 11 deletions

View File

@ -6,29 +6,29 @@ use MailPoet\API\JSON\Endpoint as APIEndpoint;
use MailPoet\WP\Functions as WPFunctions;
use MailPoet\Config\AccessControl;
use MailPoet\Config\Activator;
use MailPoet\Config\Populator;
use MailPoet\Settings\SettingsController;
use MailPoet\Subscription\Captcha;
if (!defined('ABSPATH')) exit;
class Setup extends APIEndpoint {
private $wp;
public $permissions = [
'global' => AccessControl::PERMISSION_MANAGE_SETTINGS,
];
function __construct(WPFunctions $wp) {
/** @var WPFunctions */
private $wp;
/** @var Activator */
private $activator;
function __construct(WPFunctions $wp, Activator $activator) {
$this->wp = $wp;
$this->activator = $activator;
}
function reset() {
try {
$settings = new SettingsController();
$captcha = new Captcha();
$activator = new Activator($settings, new Populator($settings, $this->wp, $captcha));
$activator->deactivate();
$activator->activate();
$this->activator->deactivate();
$this->activator->activate();
$this->wp->doAction('mailpoet_setup_reset');
return $this->successResponse();
} catch (\Exception $e) {

View File

@ -2,6 +2,8 @@
namespace MailPoet\Test\API\JSON\v1;
use Codeception\Stub;
use MailPoet\Config\Activator;
use MailPoet\Config\Populator;
use MailPoet\Models\Setting;
use MailPoet\API\JSON\v1\Setup;
use MailPoet\WP\Functions as WPFunctions;
@ -22,7 +24,9 @@ class SetupTest extends \MailPoetTest {
'doAction' => asCallable([WPHooksHelper::class, 'doAction']),
]);
$router = new Setup($wp);
$settings = new SettingsController();
$populator = new Populator($settings, $wp, new Captcha());
$router = new Setup($wp, new Activator($settings, $populator));
$response = $router->reset();
expect($response->status)->equals(APIResponse::STATUS_OK);