2016-07-25 14:07:14 +03:00
|
|
|
<?php
|
|
|
|
namespace codeception\api\unit\validators;
|
|
|
|
|
2019-02-23 02:11:57 +03:00
|
|
|
use api\tests\unit\TestCase;
|
2016-07-25 14:07:14 +03:00
|
|
|
use api\validators\PasswordRequiredValidator;
|
2018-04-17 23:47:25 +03:00
|
|
|
use common\helpers\Error as E;
|
2016-07-25 14:07:14 +03:00
|
|
|
use common\models\Account;
|
2017-09-30 00:44:05 +03:00
|
|
|
use common\rbac\Permissions as P;
|
2019-02-20 22:58:52 +03:00
|
|
|
use common\tests\_support\ProtectedCaller;
|
2017-09-30 00:44:05 +03:00
|
|
|
use yii\web\User;
|
2016-07-25 14:07:14 +03:00
|
|
|
|
2016-10-29 00:47:31 +03:00
|
|
|
class PasswordRequiredValidatorTest extends TestCase {
|
2016-07-25 14:07:14 +03:00
|
|
|
use ProtectedCaller;
|
|
|
|
|
|
|
|
public function testValidateValue() {
|
|
|
|
$account = new Account(['password' => '12345678']);
|
2017-09-30 00:44:05 +03:00
|
|
|
$model = new PasswordRequiredValidator(['account' => $account]);
|
|
|
|
|
|
|
|
// Get error.password_required if password is empty
|
|
|
|
$this->assertEquals([E::PASSWORD_REQUIRED, []], $this->callProtected($model, 'validateValue', ''));
|
|
|
|
|
|
|
|
// Get error.password_incorrect if password is incorrect
|
|
|
|
$this->assertEquals([E::PASSWORD_INCORRECT, []], $this->callProtected($model, 'validateValue', '87654321'));
|
|
|
|
|
|
|
|
// No errors, if password is correct for provided account
|
|
|
|
$this->assertNull($this->callProtected($model, 'validateValue', '12345678'));
|
|
|
|
|
|
|
|
// Skip validation if user can skip identity verification
|
|
|
|
/** @var User|\Mockery\MockInterface $component */
|
|
|
|
$component = mock(User::class . '[can]', [['identityClass' => '']]);
|
|
|
|
$component->shouldReceive('can')->withArgs([P::ESCAPE_IDENTITY_VERIFICATION])->andReturn(true);
|
|
|
|
$model->user = $component;
|
|
|
|
$this->assertNull($this->callProtected($model, 'validateValue', ''));
|
2016-07-25 14:07:14 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|