Skip to content

Commit

Permalink
Merge pull request #12713 from Jurigag/3.2.x-model-haschanged
Browse files Browse the repository at this point in the history
3.2.x Model hasChanged array
  • Loading branch information
sergeyklay authored May 8, 2017
2 parents aee575e + 7394bcc commit 2323309
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@
- Fixed `Phalcon\Mvc\Micro:handle` to correctly handle `before` handlers [#10931](https://github.com/phalcon/cphalcon/pull/10931)
- Fixed `Phalcon\Mvc\Micro:handle` to correctly handle `afterBinding` handlers
- Added way to disable setters in `Phalcon\Mvc\Model::assign` by using `Phalcon\Mvc\Model::setup` or ini option
- Fixed `Phalcon\Mvc\Model::hasChanged` to correctly use it with arrays [#12669](https://github.com/phalcon/cphalcon/issues/12669)

# [3.1.2](https://github.com/phalcon/cphalcon/releases/tag/v3.1.2) (2017-04-05)
- Fixed PHP 7.1 issues [#12055](https://github.com/phalcon/cphalcon/issues/12055)
Expand Down
23 changes: 22 additions & 1 deletion phalcon/mvc/model.zep
Original file line number Diff line number Diff line change
Expand Up @@ -3886,9 +3886,24 @@ abstract class Model implements EntityInterface, ModelInterface, ResultInterface
* Check if a specific attribute has changed
* This only works if the model is keeping data snapshots
*
*<code>
* $robot = new Robots();
*
* $robot->type = "mechanical";
* $robot->name = "Astro Boy";
* $robot->year = 1952;
*
* $robot->create();
* $robot->type = "hydraulic";
* $hasChanged = $robot->hasChanged("type"); // returns true
* $hasChanged = $robot->hasChanged(["type", "name"]); // returns true
* $hasChanged = $robot->hasChanged(["type", "name", true]); // returns false
*</code>
*
* @param string|array fieldName
* @param boolean allFields
*/
public function hasChanged(var fieldName = null) -> boolean
public function hasChanged(var fieldName = null, boolean allFields = false) -> boolean
{
var changedFields;

Expand All @@ -3899,6 +3914,12 @@ abstract class Model implements EntityInterface, ModelInterface, ResultInterface
*/
if typeof fieldName == "string" {
return in_array(fieldName, changedFields);
} elseif typeof fieldName == "array" {
if allFields {
return array_intersect(fieldName, changedFields) == fieldName;
}

return count(array_intersect(fieldName, changedFields)) > 0;
}

return count(changedFields) > 0;
Expand Down
33 changes: 33 additions & 0 deletions tests/unit/Mvc/Model/SnapshotTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -439,4 +439,37 @@ function () {
}
);
}

/**
* When model is refreshed snapshot should be updated
*
* @issue 12669
* @author Wojciech Ślawski <[email protected]>
* @since 2017-03-15
*/
public function testIssue12669()
{
$this->specify(
'hasChanged method for array argument is not working correctly',
function () {
$this->setUpModelsManager();
$robots = new Robots(
[
'name' => 'test',
'year' => 2017,
'datetime' => (new \DateTime())->format('Y-m-d'),
'text' => 'asd',
]
);

expect($robots->create())->true();
$robots->name = 'test2';
expect($robots->hasChanged(['name', 'year']))->equals(true);
expect($robots->hasChanged(['text', 'year']))->equals(false);
expect($robots->hasChanged(['name', 'year'], true))->equals(false);
$robots->year = 2018;
expect($robots->hasChanged(['name', 'year'], true))->equals(true);
}
);
}
}

0 comments on commit 2323309

Please sign in to comment.