merged branch hhamon/user_password_validator_unit_test (PR #6947)

This PR was merged into the 2.2 branch.

Commits
-------

a433ba2 [Security] [Tests] added unit tests for the UserPasswordValidator class and made the validator service for the UserPassword constraint configurable.

Discussion
----------

[Security] [Tests] added unit tests for the UserPasswordValidator class ...

...and made the validator service for the UserPassword constraint configurable.

| Q             | A
| ------------- | ---
| Bug fix?      | no
| New feature?  | no
| BC breaks?    | no
| Deprecations? | no
| Tests pass?   | yes
| Fixed tickets | -
| License       | MIT
| Doc PR        | -
This commit is contained in:
Fabien Potencier 2013-02-04 12:35:48 +01:00
commit df4188a921
2 changed files with 163 additions and 1 deletions

View File

@ -19,9 +19,10 @@ use Symfony\Component\Validator\Constraint;
class UserPassword extends Constraint
{
public $message = 'This value should be the user current password.';
public $service = 'security.validator.user_password';
public function validatedBy()
{
return 'security.validator.user_password';
return $this->service;
}
}

View File

@ -0,0 +1,161 @@
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Security\Tests\Core\Validator\Constraint;
use Symfony\Component\Security\Core\Validator\Constraint\UserPassword;
use Symfony\Component\Security\Core\Validator\Constraint\UserPasswordValidator;
class UserPasswordValidatorTest extends \PHPUnit_Framework_TestCase
{
const PASSWORD_VALID = true;
const PASSWORD_INVALID = false;
protected $context;
protected function setUp()
{
if (false === class_exists('Symfony\Component\Validator\Validator')) {
$this->markTestSkipped('The Validator component is required for this test.');
}
$this->context = $this->getMock('Symfony\Component\Validator\ExecutionContext', array(), array(), '', false);
}
protected function tearDown()
{
$this->context = null;
}
public function testPasswordIsValid()
{
$user = $this->createUser();
$securityContext = $this->createSecurityContext($user);
$encoder = $this->createPasswordEncoder(static::PASSWORD_VALID);
$encoderFactory = $this->createEncoderFactory($encoder);
$validator = new UserPasswordValidator($securityContext, $encoderFactory);
$validator->initialize($this->context);
$this
->context
->expects($this->never())
->method('addViolation')
;
$validator->validate('secret', new UserPassword());
}
public function testPasswordIsNotValid()
{
$user = $this->createUser();
$securityContext = $this->createSecurityContext($user);
$encoder = $this->createPasswordEncoder(static::PASSWORD_INVALID);
$encoderFactory = $this->createEncoderFactory($encoder);
$validator = new UserPasswordValidator($securityContext, $encoderFactory);
$validator->initialize($this->context);
$this
->context
->expects($this->once())
->method('addViolation')
;
$validator->validate('secret', new UserPassword());
}
public function testUserIsNotValid()
{
$this->setExpectedException('Symfony\Component\Validator\Exception\ConstraintDefinitionException');
$user = $this->getMock('Foo\Bar\User');
$encoderFactory = $this->getMock('Symfony\Component\Security\Core\Encoder\EncoderFactoryInterface');
$securityContext = $this->createSecurityContext($user);
$validator = new UserPasswordValidator($securityContext, $encoderFactory);
$validator->initialize($this->context);
$validator->validate('secret', new UserPassword());
}
protected function createUser()
{
$mock = $this->getMock('Symfony\Component\Security\Core\User\UserInterface');
$mock
->expects($this->once())
->method('getPassword')
->will($this->returnValue('s3Cr3t'))
;
$mock
->expects($this->once())
->method('getSalt')
->will($this->returnValue('^S4lt$'))
;
return $mock;
}
protected function createPasswordEncoder($isPasswordValid = true)
{
$mock = $this->getMock('Symfony\Component\Security\Core\Encoder\PasswordEncoderInterface');
$mock
->expects($this->once())
->method('isPasswordValid')
->will($this->returnValue($isPasswordValid))
;
return $mock;
}
protected function createEncoderFactory($encoder = null)
{
$mock = $this->getMock('Symfony\Component\Security\Core\Encoder\EncoderFactoryInterface');
$mock
->expects($this->once())
->method('getEncoder')
->will($this->returnValue($encoder))
;
return $mock;
}
protected function createSecurityContext($user = null)
{
$token = $this->createAuthenticationToken($user);
$mock = $this->getMock('Symfony\Component\Security\Core\SecurityContextInterface');
$mock
->expects($this->once())
->method('getToken')
->will($this->returnValue($token))
;
return $mock;
}
protected function createAuthenticationToken($user = null)
{
$mock = $this->getMock('Symfony\Component\Security\Core\Authentication\Token\TokenInterface');
$mock
->expects($this->once())
->method('getUser')
->will($this->returnValue($user))
;
return $mock;
}
}