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:
commit
a6beede7d7
@ -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));
|
||||
}
|
||||
|
@ -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);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user