From 19694721bc9f957cdfb545b18aaf86d44e03b1ad Mon Sep 17 00:00:00 2001 From: kenjis Date: Wed, 8 May 2024 15:22:10 +0900 Subject: [PATCH 1/3] test: add test cases for finding returns null --- .../system/Models/DataConverterModelTest.php | 30 +++++++++++++++++++ 1 file changed, 30 insertions(+) diff --git a/tests/system/Models/DataConverterModelTest.php b/tests/system/Models/DataConverterModelTest.php index cd50df0d8b00..4dd6da072f5e 100644 --- a/tests/system/Models/DataConverterModelTest.php +++ b/tests/system/Models/DataConverterModelTest.php @@ -43,6 +43,16 @@ public function testFindAsArray(): void $this->seeInDatabase('user', ['name' => 'Sm9obiBTbWl0aA==']); } + public function testFindAsArrayReturnsNull(): void + { + $this->createModel(UserCastsTimestampModel::class); + $this->db->table('user')->truncate(); + + $user = $this->model->find(1); + + $this->assertNull($user); + } + /** * @return int|string Insert ID */ @@ -102,6 +112,16 @@ public function testFindAllAsArray(): void $this->assertInstanceOf(Time::class, $users[1]['created_at']); } + public function testFindAllAsArrayReturnsNull(): void + { + $this->createModel(UserCastsTimestampModel::class); + $this->db->table('user')->truncate(); + + $users = $this->model->findAll(); + + $this->assertSame([], $users); + } + private function prepareTwoRecords(): void { $this->prepareOneRecord(); @@ -170,6 +190,16 @@ public function testFirstAsArray(): void $this->assertInstanceOf(Time::class, $user['created_at']); } + public function testFirstAsArrayReturnsNull(): void + { + $this->createModel(UserCastsTimestampModel::class); + $this->db->table('user')->truncate(); + + $user = $this->model->first(); + + $this->assertNull($user); + } + public function testFirstAsObject(): void { $this->prepareTwoRecords(); From 5c05447288f7c02a26d306f75c934b0a10ff3ee9 Mon Sep 17 00:00:00 2001 From: Aleksey Grunin <49051631+avegacms@users.noreply.github.com> Date: Fri, 19 Apr 2024 11:19:59 +0600 Subject: [PATCH 2/3] Fix bug #8806 Bug: when the query ($this->first()) result returns NULL we get TypeError --- system/Model.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/system/Model.php b/system/Model.php index b3ecfc653943..c4ca9b6cc6e9 100644 --- a/system/Model.php +++ b/system/Model.php @@ -318,7 +318,7 @@ protected function doFirst() $row = $builder->limit(1, 0)->get()->getFirstRow($this->tempReturnType); - if ($useCast) { + if ($useCast && $row !== null) { $row = $this->convertToReturnType($row, $returnType); $this->tempReturnType = $returnType; From 4639608862523fb2b042ee13d4d54c0eca3b5b10 Mon Sep 17 00:00:00 2001 From: Aleksey Grunin <49051631+avegacms@users.noreply.github.com> Date: Fri, 19 Apr 2024 21:21:27 +0600 Subject: [PATCH 3/3] Update Model.php Fix TypeError error in the methods: doFind and doFirst when using casts --- system/Model.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/system/Model.php b/system/Model.php index c4ca9b6cc6e9..03ca7525ec76 100644 --- a/system/Model.php +++ b/system/Model.php @@ -210,7 +210,7 @@ protected function doFind(bool $singleton, $id = null) $row = $builder->get()->getResult($this->tempReturnType); } - if ($useCast) { + if ($useCast && $row !== null) { $row = $this->convertToReturnType($row, $returnType); $this->tempReturnType = $returnType;