bug #11691 [Validator] Fixed Constraint class to not destroy custom groups upon serialization (webmozart)

This PR was merged into the 2.6-dev branch.

Discussion
----------

[Validator] Fixed Constraint class to not destroy custom groups upon serialization

| Q             | A
| ------------- | ---
| Bug fix?      | yes
| New feature?  | no
| BC breaks?    | no
| Deprecations? | no
| Tests pass?   | yes
| Fixed tickets | #11638
| License       | MIT
| Doc PR        | -

Commits
-------

d405f43 [Validator] Fixed Constraint class to not destroy custom groups upon serialization
This commit is contained in:
Bernhard Schussek 2014-08-19 10:15:39 +02:00
commit a6beede7d7
2 changed files with 19 additions and 7 deletions

View File

@ -274,7 +274,7 @@ abstract class Constraint
public function __sleep()
{
// Initialize "groups" option if it is not set
$this->__get('groups');
$this->groups;
return array_keys(get_object_vars($this));
}

View File

@ -167,22 +167,34 @@ class ConstraintTest extends \PHPUnit_Framework_TestCase
$this->assertEquals($constraint, $restoredConstraint);
}
public function testSerializeInitializesGroupsOption()
public function testSerializeInitializesGroupsOptionToDefault()
{
$constraintWithExplicitGroup = new ConstraintA(array(
$constraint = new ConstraintA(array(
'property1' => 'foo',
'property2' => 'bar',
));
$constraint = unserialize(serialize($constraint));
$expected = new ConstraintA(array(
'property1' => 'foo',
'property2' => 'bar',
'groups' => 'Default',
));
$constraintWithoutExplicitGroup = new ConstraintA(array(
$this->assertEquals($expected, $constraint);
}
public function testSerializeKeepsCustomGroups()
{
$constraint = new ConstraintA(array(
'property1' => 'foo',
'property2' => 'bar',
'groups' => 'MyGroup',
));
$constraintWithExplicitGroup = unserialize(serialize($constraintWithExplicitGroup));
$constraintWithoutExplicitGroup = unserialize(serialize($constraintWithoutExplicitGroup));
$constraint = unserialize(serialize($constraint));
$this->assertEquals($constraintWithExplicitGroup, $constraintWithoutExplicitGroup);
$this->assertSame(array('MyGroup'), $constraint->groups);
}
}