From d8a2918ed42c44cf9a109ae8b8b816db975deeb5 Mon Sep 17 00:00:00 2001 From: Kevin NGUYEN Date: Tue, 14 May 2024 16:20:52 +0200 Subject: [PATCH 1/4] :zap: Avoid systematic count query --- src/PageIterator.php | 4 +--- tests/AbstractTDBMObjectTest.php | 17 ----------------- 2 files changed, 1 insertion(+), 20 deletions(-) diff --git a/src/PageIterator.php b/src/PageIterator.php index cd1da899..ab811179 100644 --- a/src/PageIterator.php +++ b/src/PageIterator.php @@ -121,9 +121,7 @@ public static function createEmpyIterator(ResultIterator $parentResult): self public function getIterator() { if ($this->innerResultIterator === null) { - if ($this->parentResult->count() === 0) { - $this->innerResultIterator = new EmptyInnerResultIterator(); - } elseif ($this->mode === TDBMService::MODE_CURSOR) { + if ($this->mode === TDBMService::MODE_CURSOR) { $this->innerResultIterator = InnerResultIterator::createInnerResultIterator($this->magicSql, $this->parameters, $this->limit, $this->offset, $this->columnDescriptors, $this->objectStorage, $this->className, $this->tdbmService, $this->magicQuery, $this->logger); } else { $this->innerResultIterator = InnerResultArray::createInnerResultIterator($this->magicSql, $this->parameters, $this->limit, $this->offset, $this->columnDescriptors, $this->objectStorage, $this->className, $this->tdbmService, $this->magicQuery, $this->logger); diff --git a/tests/AbstractTDBMObjectTest.php b/tests/AbstractTDBMObjectTest.php index 3a79559d..1e60a610 100644 --- a/tests/AbstractTDBMObjectTest.php +++ b/tests/AbstractTDBMObjectTest.php @@ -42,21 +42,4 @@ public function testEmptyResultIterator() $this->assertEquals(0, $d->count()); } - public function testEmptyPageIterator() - { - $a = ResultIterator::createEmpyIterator(); - $b = $a->take(0, 10); - foreach ($b as $empty) { - throw new \LogicException("Not supposed to iterate on an empty page iterator."); - } - $this->assertEquals(0, $b->count()); - $this->assertEquals([], $b->toArray()); - $this->assertEquals(0, $b->totalCount()); - $c = $b->map(function ($foo) { - }); - foreach ($c as $empty) { - throw new \LogicException("Not supposed to iterate on an empty iterator."); - } - $this->assertEquals([], $c->toArray()); - } } From e7e17564e9393f0e651d5005c443d73bad3b9f7e Mon Sep 17 00:00:00 2001 From: Kevin NGUYEN Date: Tue, 14 May 2024 17:12:16 +0200 Subject: [PATCH 2/4] fix CI --- src/EmptyResultIterator.php | 16 ++++++++++++++++ src/PageIterator.php | 4 +++- .../FindObjectsFromRawSqlQueryFactory.php | 2 +- src/ResultIterator.php | 11 ++++------- src/Utils/BeanDescriptor.php | 4 ++-- tests/AbstractTDBMObjectTest.php | 17 +++++++++++++++++ tests/NativeWeakrefObjectStorageTest.php | 2 +- tests/Performance/ManyToOneBench.php | 6 +++--- tests/TDBMAbstractServiceTest.php | 8 ++++---- tests/Utils/Annotation/AnnotationParserTest.php | 12 ++++++------ tests/Utils/DbalUtilsTest.php | 2 +- tests/Utils/DefaultNamingStrategyTest.php | 2 +- 12 files changed, 59 insertions(+), 27 deletions(-) create mode 100644 src/EmptyResultIterator.php diff --git a/src/EmptyResultIterator.php b/src/EmptyResultIterator.php new file mode 100644 index 00000000..d590e304 --- /dev/null +++ b/src/EmptyResultIterator.php @@ -0,0 +1,16 @@ +totalCount = 0; + $this->logger = new NullLogger(); + } + +} diff --git a/src/PageIterator.php b/src/PageIterator.php index ab811179..c5d27b52 100644 --- a/src/PageIterator.php +++ b/src/PageIterator.php @@ -121,7 +121,9 @@ public static function createEmpyIterator(ResultIterator $parentResult): self public function getIterator() { if ($this->innerResultIterator === null) { - if ($this->mode === TDBMService::MODE_CURSOR) { + if ($this->parentResult instanceof EmptyResultIterator) { + $this->innerResultIterator = new EmptyInnerResultIterator(); + } elseif ($this->mode === TDBMService::MODE_CURSOR) { $this->innerResultIterator = InnerResultIterator::createInnerResultIterator($this->magicSql, $this->parameters, $this->limit, $this->offset, $this->columnDescriptors, $this->objectStorage, $this->className, $this->tdbmService, $this->magicQuery, $this->logger); } else { $this->innerResultIterator = InnerResultArray::createInnerResultIterator($this->magicSql, $this->parameters, $this->limit, $this->offset, $this->columnDescriptors, $this->objectStorage, $this->className, $this->tdbmService, $this->magicQuery, $this->logger); diff --git a/src/QueryFactory/FindObjectsFromRawSqlQueryFactory.php b/src/QueryFactory/FindObjectsFromRawSqlQueryFactory.php index 457b7bd4..b04398b0 100644 --- a/src/QueryFactory/FindObjectsFromRawSqlQueryFactory.php +++ b/src/QueryFactory/FindObjectsFromRawSqlQueryFactory.php @@ -403,7 +403,7 @@ private function generateGroupedSqlCount(array $parsedSql): array $item['delim'] = ','; $innerColumns[] = $item; } - $innerColumns[count($innerColumns)-1]['delim'] = false; + $innerColumns[count($innerColumns) - 1]['delim'] = false; $parsedSql['SELECT'] = $innerColumns; $parsedSql = [ diff --git a/src/ResultIterator.php b/src/ResultIterator.php index 595c37a3..c4c16795 100644 --- a/src/ResultIterator.php +++ b/src/ResultIterator.php @@ -65,15 +65,15 @@ class ResultIterator implements Result, \ArrayAccess, \JsonSerializable private $innerResultIterator; /** @var int|null */ - private $totalCount; + protected $totalCount; /** @var int */ private $mode; /** @var LoggerInterface */ - private $logger; + protected $logger; - final private function __construct() + protected function __construct() { } @@ -101,10 +101,7 @@ public static function createResultIterator(QueryFactory $queryFactory, array $p public static function createEmpyIterator(): self { - $iterator = new static(); - $iterator->totalCount = 0; - $iterator->logger = new NullLogger(); - return $iterator; + return new EmptyResultIterator(); } protected function executeCountQuery(): void diff --git a/src/Utils/BeanDescriptor.php b/src/Utils/BeanDescriptor.php index cb092208..fb30d023 100644 --- a/src/Utils/BeanDescriptor.php +++ b/src/Utils/BeanDescriptor.php @@ -1333,7 +1333,7 @@ private function generateFindByDaoCodeForIndex(Index $index, string $beanNamespa $parameter = new ParameterGenerator(ltrim($element->getSafeVariableName(), '$')); if (!$first && !($element->isCompulsory() && $index->isUnique())) { $parameterType = '?'; - //$functionParameter = '?'; + //$functionParameter = '?'; } else { $parameterType = ''; //$functionParameter = ''; @@ -1765,7 +1765,7 @@ private function generateGetForeignKeys(array $fks): MethodGenerator * @param string $indent * @return string */ - private function psr2VarExport($var, string $indent=''): string + private function psr2VarExport($var, string $indent = ''): string { if (is_array($var)) { $indexed = array_keys($var) === range(0, count($var) - 1); diff --git a/tests/AbstractTDBMObjectTest.php b/tests/AbstractTDBMObjectTest.php index 1e60a610..3a79559d 100644 --- a/tests/AbstractTDBMObjectTest.php +++ b/tests/AbstractTDBMObjectTest.php @@ -42,4 +42,21 @@ public function testEmptyResultIterator() $this->assertEquals(0, $d->count()); } + public function testEmptyPageIterator() + { + $a = ResultIterator::createEmpyIterator(); + $b = $a->take(0, 10); + foreach ($b as $empty) { + throw new \LogicException("Not supposed to iterate on an empty page iterator."); + } + $this->assertEquals(0, $b->count()); + $this->assertEquals([], $b->toArray()); + $this->assertEquals(0, $b->totalCount()); + $c = $b->map(function ($foo) { + }); + foreach ($c as $empty) { + throw new \LogicException("Not supposed to iterate on an empty iterator."); + } + $this->assertEquals([], $c->toArray()); + } } diff --git a/tests/NativeWeakrefObjectStorageTest.php b/tests/NativeWeakrefObjectStorageTest.php index e6f6730a..86344e99 100644 --- a/tests/NativeWeakrefObjectStorageTest.php +++ b/tests/NativeWeakrefObjectStorageTest.php @@ -30,7 +30,7 @@ public function testDanglingPointers(): void $objectStorage = new NativeWeakrefObjectStorage(); $dbRow = $this->createMock(DbRow::class); - for ($i=0; $i<10001; $i++) { + for ($i = 0; $i < 10001; $i++) { $objectStorage->set('foo', $i, clone $dbRow); } $this->assertNull($objectStorage->get('foo', 42)); diff --git a/tests/Performance/ManyToOneBench.php b/tests/Performance/ManyToOneBench.php index 07d1ec70..aaf485c6 100644 --- a/tests/Performance/ManyToOneBench.php +++ b/tests/Performance/ManyToOneBench.php @@ -73,18 +73,18 @@ private static function initSchema(Connection $connection): void $connection->exec($sqlStmt); } - for ($i = 1; $i<200; $i++) { + for ($i = 1; $i < 200; $i++) { TDBMAbstractServiceTest::insert($connection, 'countries', [ 'id' => $i, 'label' => 'Country '.$i, ]); } - for ($i = 1; $i<1000; $i++) { + for ($i = 1; $i < 1000; $i++) { TDBMAbstractServiceTest::insert($connection, 'users', [ 'id' => $i, 'name' => 'User '.$i, - 'country_id' => ($i%199) +1, + 'country_id' => ($i % 199) + 1, ]); } } diff --git a/tests/TDBMAbstractServiceTest.php b/tests/TDBMAbstractServiceTest.php index 25ac2675..ff275e82 100644 --- a/tests/TDBMAbstractServiceTest.php +++ b/tests/TDBMAbstractServiceTest.php @@ -211,9 +211,9 @@ private static function initSchema(Connection $connection): void ->column('manager_id')->references('contact')->null(); $db->table('users') - ->addAnnotation('AddTrait', ['name'=>TestUserTrait::class], false) - ->addAnnotation('AddTrait', ['name'=>TestOtherUserTrait::class, 'modifiers'=>['\\'.TestOtherUserTrait::class.'::method1 insteadof \\'.TestUserTrait::class, '\\'.TestUserTrait::class.'::method1 as method1renamed']], false) - ->addAnnotation('AddTraitOnDao', ['name'=>TestUserDaoTrait::class], false) + ->addAnnotation('AddTrait', ['name' => TestUserTrait::class], false) + ->addAnnotation('AddTrait', ['name' => TestOtherUserTrait::class, 'modifiers' => ['\\'.TestOtherUserTrait::class.'::method1 insteadof \\'.TestUserTrait::class, '\\'.TestUserTrait::class.'::method1 as method1renamed']], false) + ->addAnnotation('AddTraitOnDao', ['name' => TestUserDaoTrait::class], false) ->implementsInterface(TestUserInterface::class) ->implementsInterfaceOnDao(TestUserDaoInterface::class) ->extends('contact') @@ -721,7 +721,7 @@ private static function initSchema(Connection $connection): void self::insert($connection, 'tracks', [ 'album_id' => 1, - 'title' =>'Pigs on the Wing 1', + 'title' => 'Pigs on the Wing 1', // Note: Oracle does not have a TIME column type 'duration' => $timeType->convertToDatabaseValue(new DateTimeImmutable('1970-01-01 00:01:25'), $connection->getDatabasePlatform()), ]); diff --git a/tests/Utils/Annotation/AnnotationParserTest.php b/tests/Utils/Annotation/AnnotationParserTest.php index 35428302..35c934e5 100644 --- a/tests/Utils/Annotation/AnnotationParserTest.php +++ b/tests/Utils/Annotation/AnnotationParserTest.php @@ -19,7 +19,7 @@ public function testParse(): void 'UUID' => UUID::class, 'Autoincrement' => Autoincrement::class ]); - $column = new Column('foo', Type::getType(Type::STRING), ['comment'=>'@UUID']); + $column = new Column('foo', Type::getType(Type::STRING), ['comment' => '@UUID']); $table = new Table('bar'); $annotations = $parser->getColumnAnnotations($column, $table); @@ -40,7 +40,7 @@ public function testParseMultiLine(): void 'UUID' => UUID::class, 'Autoincrement' => Autoincrement::class ]); - $column = new Column('foo', Type::getType(Type::STRING), ['comment'=>"\n@UUID"]); + $column = new Column('foo', Type::getType(Type::STRING), ['comment' => "\n@UUID"]); $table = new Table('bar'); $annotations = $parser->getColumnAnnotations($column, $table); @@ -54,7 +54,7 @@ public function testParseMultiAnnotations(): void 'UUID' => UUID::class, 'Autoincrement' => Autoincrement::class ]); - $column = new Column('foo', Type::getType(Type::STRING), ['comment'=>"\n@UUID\n@Autoincrement"]); + $column = new Column('foo', Type::getType(Type::STRING), ['comment' => "\n@UUID\n@Autoincrement"]); $table = new Table('bar'); $annotations = $parser->getColumnAnnotations($column, $table); @@ -68,7 +68,7 @@ public function testException(): void 'UUID' => UUID::class, 'Autoincrement' => Autoincrement::class ]); - $table = new Table('bar', [], [], [], 0, ['comment'=>"@UUID\n@UUID"]); + $table = new Table('bar', [], [], [], 0, ['comment' => "@UUID\n@UUID"]); $annotations = $parser->getTableAnnotations($table); $this->expectException(TDBMException::class); @@ -81,7 +81,7 @@ public function testParseParameters(): void 'UUID' => UUID::class, 'Autoincrement' => Autoincrement::class ]); - $table = new Table('bar', [], [], [], 0, ['comment'=>'@UUID("v4")']); + $table = new Table('bar', [], [], [], 0, ['comment' => '@UUID("v4")']); $annotations = $parser->getTableAnnotations($table); $annotation = $annotations->findAnnotation(UUID::class); @@ -94,7 +94,7 @@ public function testParseOldUUID(): void 'UUID' => UUID::class, ]); // First generation UUID did not use the Doctrine syntax. - $table = new Table('bar', [], [], [], 0, ['comment'=>'@UUID v4']); + $table = new Table('bar', [], [], [], 0, ['comment' => '@UUID v4']); $annotations = $parser->getTableAnnotations($table); $annotation = $annotations->findAnnotation(UUID::class); diff --git a/tests/Utils/DbalUtilsTest.php b/tests/Utils/DbalUtilsTest.php index 14dbb74b..7f39b50c 100644 --- a/tests/Utils/DbalUtilsTest.php +++ b/tests/Utils/DbalUtilsTest.php @@ -17,6 +17,6 @@ public function testGenerateTypes(): void 'key4' => 1, ]; - $this->assertSame(['key2'=>Connection::PARAM_INT_ARRAY, 'key3'=>Connection::PARAM_STR_ARRAY, 'key4'=>ParameterType::INTEGER], DbalUtils::generateTypes($params)); + $this->assertSame(['key2' => Connection::PARAM_INT_ARRAY, 'key3' => Connection::PARAM_STR_ARRAY, 'key4' => ParameterType::INTEGER], DbalUtils::generateTypes($params)); } } diff --git a/tests/Utils/DefaultNamingStrategyTest.php b/tests/Utils/DefaultNamingStrategyTest.php index 20318a92..58e7163e 100644 --- a/tests/Utils/DefaultNamingStrategyTest.php +++ b/tests/Utils/DefaultNamingStrategyTest.php @@ -131,7 +131,7 @@ public function testExceptions(): void public function testBeanAnnotation(): void { - $table = new Table('chevaux', [], [], [], 0, ['comment'=>'@Bean(name="Cheval")']); + $table = new Table('chevaux', [], [], [], 0, ['comment' => '@Bean(name="Cheval")']); $strategy = $this->getDefaultNamingStrategyWithStubTables([$table]); $this->assertSame('ChevalDao', $strategy->getDaoClassName('chevaux')); } From 0b07f61af6e95fc1e70462bf06dde74da956f09d Mon Sep 17 00:00:00 2001 From: Kevin NGUYEN Date: Tue, 14 May 2024 17:51:05 +0200 Subject: [PATCH 3/4] Fix PHPStan --- src/ResultIterator.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/ResultIterator.php b/src/ResultIterator.php index c4c16795..0b200dbc 100644 --- a/src/ResultIterator.php +++ b/src/ResultIterator.php @@ -83,7 +83,7 @@ protected function __construct() */ public static function createResultIterator(QueryFactory $queryFactory, array $parameters, ObjectStorageInterface $objectStorage, ?string $className, TDBMService $tdbmService, MagicQuery $magicQuery, int $mode, LoggerInterface $logger): self { - $iterator = new static(); + $iterator = new self(); if ($mode !== TDBMService::MODE_CURSOR && $mode !== TDBMService::MODE_ARRAY) { throw new TDBMException("Unknown fetch mode: '".$mode."'"); } From 3a8c20cf334159aab6fbb3988346299122ef0a7c Mon Sep 17 00:00:00 2001 From: Kevin NGUYEN Date: Tue, 14 May 2024 18:38:05 +0200 Subject: [PATCH 4/4] fix CI again --- src/EmptyResultIterator.php | 9 --------- src/ResultIterator.php | 13 ++++++++----- tests/AbstractTDBMObjectTest.php | 2 +- 3 files changed, 9 insertions(+), 15 deletions(-) diff --git a/src/EmptyResultIterator.php b/src/EmptyResultIterator.php index d590e304..662a09f6 100644 --- a/src/EmptyResultIterator.php +++ b/src/EmptyResultIterator.php @@ -2,15 +2,6 @@ namespace TheCodingMachine\TDBM; -use Psr\Log\NullLogger; -use TheCodingMachine\TDBM\ResultIterator; - class EmptyResultIterator extends ResultIterator { - protected function __construct() - { - $this->totalCount = 0; - $this->logger = new NullLogger(); - } - } diff --git a/src/ResultIterator.php b/src/ResultIterator.php index 0b200dbc..595c37a3 100644 --- a/src/ResultIterator.php +++ b/src/ResultIterator.php @@ -65,15 +65,15 @@ class ResultIterator implements Result, \ArrayAccess, \JsonSerializable private $innerResultIterator; /** @var int|null */ - protected $totalCount; + private $totalCount; /** @var int */ private $mode; /** @var LoggerInterface */ - protected $logger; + private $logger; - protected function __construct() + final private function __construct() { } @@ -83,7 +83,7 @@ protected function __construct() */ public static function createResultIterator(QueryFactory $queryFactory, array $parameters, ObjectStorageInterface $objectStorage, ?string $className, TDBMService $tdbmService, MagicQuery $magicQuery, int $mode, LoggerInterface $logger): self { - $iterator = new self(); + $iterator = new static(); if ($mode !== TDBMService::MODE_CURSOR && $mode !== TDBMService::MODE_ARRAY) { throw new TDBMException("Unknown fetch mode: '".$mode."'"); } @@ -101,7 +101,10 @@ public static function createResultIterator(QueryFactory $queryFactory, array $p public static function createEmpyIterator(): self { - return new EmptyResultIterator(); + $iterator = new static(); + $iterator->totalCount = 0; + $iterator->logger = new NullLogger(); + return $iterator; } protected function executeCountQuery(): void diff --git a/tests/AbstractTDBMObjectTest.php b/tests/AbstractTDBMObjectTest.php index 3a79559d..a0e79532 100644 --- a/tests/AbstractTDBMObjectTest.php +++ b/tests/AbstractTDBMObjectTest.php @@ -44,7 +44,7 @@ public function testEmptyResultIterator() public function testEmptyPageIterator() { - $a = ResultIterator::createEmpyIterator(); + $a = EmptyResultIterator::createEmpyIterator(); $b = $a->take(0, 10); foreach ($b as $empty) { throw new \LogicException("Not supposed to iterate on an empty page iterator.");