From aedd19e4bff50680b728053ca1979d49b322fc53 Mon Sep 17 00:00:00 2001 From: Gabriel Sosa Date: Tue, 27 Oct 2020 13:22:33 -0300 Subject: [PATCH] Backport of issue #2127 to tree 3.7 --- src/Jenssegers/Mongodb/Query/Builder.php | 2 +- tests/QueryTest.php | 32 +++++++++++++----------- 2 files changed, 19 insertions(+), 15 deletions(-) diff --git a/src/Jenssegers/Mongodb/Query/Builder.php b/src/Jenssegers/Mongodb/Query/Builder.php index 86526ed53..e466ea411 100644 --- a/src/Jenssegers/Mongodb/Query/Builder.php +++ b/src/Jenssegers/Mongodb/Query/Builder.php @@ -1040,7 +1040,7 @@ protected function compileWhereBasic(array $where) if (!isset($operator) || $operator == '=') { if ($is_numeric) { - $query = ['$where' => '/^'.$value->getPattern().'/.test(this.'.$column.')']; + $query = ['$where' => '/^'.$value->getPattern().'/.test(this["'.$column.'"])']; } else { $query = [$column => $value]; } diff --git a/tests/QueryTest.php b/tests/QueryTest.php index 5e6261b52..c486691ec 100644 --- a/tests/QueryTest.php +++ b/tests/QueryTest.php @@ -16,6 +16,7 @@ public function setUp(): void User::create(['name' => 'Brett Boe', 'age' => 35, 'title' => 'user']); User::create(['name' => 'Tommy Toe', 'age' => 33, 'title' => 'user']); User::create(['name' => 'Yvonne Yoe', 'age' => 35, 'title' => 'admin']); + User::create(['name' => 'John Smith', 'user-age' => 28, 'title' => 'member']); User::create(['name' => 'Error', 'age' => null, 'title' => null]); } @@ -41,10 +42,10 @@ public function testWhere(): void $this->assertCount(1, $users); $users = User::where('age', '!=', 35)->get(); - $this->assertCount(6, $users); + $this->assertCount(7, $users); $users = User::where('age', '<>', 35)->get(); - $this->assertCount(6, $users); + $this->assertCount(7, $users); } public function testAndWhere(): void @@ -78,21 +79,24 @@ public function testLike(): void $users = User::where('age', 'like', '%3')->get(); $this->assertCount(4, $users); + + $users = User::where('user-age', 'like', '%28')->get(); + $this->assertCount(1, $users); } public function testNotLike(): void { $users = User::where('name', 'not like', '%doe')->get(); - $this->assertCount(7, $users); + $this->assertCount(8, $users); $users = User::where('name', 'not like', '%y%')->get(); - $this->assertCount(6, $users); + $this->assertCount(7, $users); $users = User::where('name', 'not LIKE', '%y%')->get(); - $this->assertCount(6, $users); + $this->assertCount(7, $users); $users = User::where('name', 'not like', 't%')->get(); - $this->assertCount(8, $users); + $this->assertCount(9, $users); } public function testSelect(): void @@ -152,7 +156,7 @@ public function testIn(): void $this->assertCount(6, $users); $users = User::whereNotIn('age', [33, 35])->get(); - $this->assertCount(4, $users); + $this->assertCount(5, $users); $users = User::whereNotNull('age') ->whereNotIn('age', [33, 35])->get(); @@ -162,7 +166,7 @@ public function testIn(): void public function testWhereNull(): void { $users = User::whereNull('age')->get(); - $this->assertCount(1, $users); + $this->assertCount(2, $users); } public function testWhereNotNull(): void @@ -195,7 +199,7 @@ public function testOrder(): void public function testGroupBy(): void { $users = User::groupBy('title')->get(); - $this->assertCount(3, $users); + $this->assertCount(4, $users); $users = User::groupBy('age')->get(); $this->assertCount(6, $users); @@ -225,11 +229,11 @@ public function testGroupBy(): void public function testCount(): void { $count = User::where('age', '<>', 35)->count(); - $this->assertEquals(6, $count); + $this->assertEquals(7, $count); // Test for issue #165 $count = User::select('_id', 'age', 'title')->where('age', '<>', 35)->count(); - $this->assertEquals(6, $count); + $this->assertEquals(7, $count); } public function testExists(): void @@ -327,12 +331,12 @@ public function testPaginate(): void $results = User::paginate(2); $this->assertEquals(2, $results->count()); $this->assertNotNull($results->first()->title); - $this->assertEquals(9, $results->total()); + $this->assertEquals(10, $results->total()); $results = User::paginate(2, ['name', 'age']); $this->assertEquals(2, $results->count()); $this->assertNull($results->first()->title); - $this->assertEquals(9, $results->total()); + $this->assertEquals(10, $results->total()); $this->assertEquals(1, $results->currentPage()); } @@ -399,4 +403,4 @@ public function testMultipleSortOrder(): void $this->assertEquals('John Doe', $subset[1]->name); $this->assertEquals('Brett Boe', $subset[2]->name); } -} +} \ No newline at end of file