From ce428fa0dd287d91268423812c26471d2da44785 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Wojciech=20=C5=9Alawski?= Date: Tue, 4 Apr 2017 15:35:47 +0200 Subject: [PATCH] Fixes #12766 --- CHANGELOG.md | 1 + phalcon/mvc/model.zep | 6 ++- tests/_data/models/DynamicUpdate/Robots.php | 43 ++++++++++++++++++ tests/unit/Mvc/Model/DynamicUpdateTest.php | 48 +++++++++++++++++++++ 4 files changed, 97 insertions(+), 1 deletion(-) create mode 100644 tests/_data/models/DynamicUpdate/Robots.php create mode 100644 tests/unit/Mvc/Model/DynamicUpdateTest.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 9c4d10d96d7..1491f1549f1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,6 @@ # [3.1.2](https://github.com/phalcon/cphalcon/releases/tag/v3.1.2) (2017-XX-XX) - Fixed PHP 7.1 issues [#12055](https://github.com/phalcon/cphalcon/issues/12055) +- Fixed `Phalcon\Mvc\Model::__doLowInsert` to properly set snapshot when having default values and public properties [#12766](https://github.com/phalcon/cphalcon/issues/12766) # [3.1.1](https://github.com/phalcon/cphalcon/releases/tag/v3.1.1) (2017-03-25) - Fixed undefined index warning on existing cached resultsets diff --git a/phalcon/mvc/model.zep b/phalcon/mvc/model.zep index f7bcde283dc..65b77e16339 100644 --- a/phalcon/mvc/model.zep +++ b/phalcon/mvc/model.zep @@ -2301,7 +2301,11 @@ abstract class Model implements EntityInterface, ModelInterface, ResultInterface } let fields[] = field, values[] = value, bindTypes[] = bindType; - let snapshot[attributeField] = value; + if isset defaultValues[field] { + let snapshot[attributeField] = null; + } else { + let snapshot[attributeField] = value; + } } else { if isset defaultValues[field] { diff --git a/tests/_data/models/DynamicUpdate/Robots.php b/tests/_data/models/DynamicUpdate/Robots.php new file mode 100644 index 00000000000..753e82ccfe2 --- /dev/null +++ b/tests/_data/models/DynamicUpdate/Robots.php @@ -0,0 +1,43 @@ + + * @author Serghei Iakovlev + * @package Phalcon\Test\Models\Snapshot + * + * @property int $id + * @property string $name + * @property string $type + * @property int $year + * @property string $datetime + * @property string $deleted + * @property string $text + * + * @method static Robots findFirst($parameters = null) + * @method static Robots[] find($parameters = null) + * + * The contents of this file are subject to the New BSD License that is + * bundled with this package in the file docs/LICENSE.txt + * + * If you did not receive a copy of the license and are unable to obtain it + * through the world-wide-web, please send an email to license@phalconphp.com + * so that we can send you a copy immediately. + */ +class Robots extends Model +{ + public function initialize() + { + $this->hasMany('id', RobotsParts::class, 'robots_id'); + + $this->useDynamicUpdate(true); + } +} diff --git a/tests/unit/Mvc/Model/DynamicUpdateTest.php b/tests/unit/Mvc/Model/DynamicUpdateTest.php new file mode 100644 index 00000000000..a02617e5c6c --- /dev/null +++ b/tests/unit/Mvc/Model/DynamicUpdateTest.php @@ -0,0 +1,48 @@ + + * @author Serghei Iakovlev + * @author Wojciech Ślawski + * @package Phalcon\Test\Unit\Mvc\Model + * + * The contents of this file are subject to the New BSD License that is + * bundled with this package in the file docs/LICENSE.txt + * + * If you did not receive a copy of the license and are unable to obtain it + * through the world-wide-web, please send an email to license@phalconphp.com + * so that we can send you a copy immediately. + */ +class DynamicUpdateTest extends UnitTest +{ + /** + * Tests dynamic update create then update + * + * @author Wojciech Ślawski + * @issue 12766 + * @since 2017-04-04 + */ + public function testIssue12766() + { + $robots = new Robots(); + $robots->name = 'Test'; + $robots->type = 'mechanical'; + $robots->datetime = (new \DateTime())->format('Y-m-d'); + $robots->text = 'text'; + + $robots->create(); + + $robots->year = 2017; + $robots->update(); + } +}