Use DI for Activator in Setup API
[MAILPOET-2014]
This commit is contained in:
@ -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) {
|
||||
|
@ -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);
|
||||
|
||||
|
Reference in New Issue
Block a user