123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461 |
- <?php
- namespace Doctrine\Tests\ORM\Performance;
- require_once __DIR__ . '/../../TestInit.php';
- use Doctrine\Tests\Mocks\HydratorMockStatement,
- Doctrine\ORM\Query\ResultSetMapping,
- Doctrine\ORM\Query;
- /**
- * Tests to prevent serious performance regressions.
- *
- * IMPORTANT: Be sure to run these tests withoug xdebug or similar tools that
- * seriously degrade performance.
- *
- * @author robo
- * @group performance
- */
- class HydrationPerformanceTest extends \Doctrine\Tests\OrmPerformanceTestCase
- {
- /**
- * Times for comparison:
- *
- * [romanb: 10000 rows => 0.7 seconds]
- *
- * MAXIMUM TIME: 1 second
- */
- public function testSimpleQueryScalarHydrationPerformance10000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '2',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- )
- );
- for ($i = 4; $i < 10000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ScalarHydrator($this->_em);
- $this->setMaxRunningTime(1);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm);
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * Times for comparison:
- *
- * [romanb: 10000 rows => 1 second]
- *
- * MAXIMUM TIME: 2 seconds
- */
- public function testSimpleQueryArrayHydrationPerformance10000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '2',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- )
- );
- for ($i = 4; $i < 10000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ArrayHydrator($this->_em);
- $this->setMaxRunningTime(2);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm);
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * Times for comparison:
- *
- * [romanb: 10000 rows => 1.4 seconds]
- *
- * MAXIMUM TIME: 3 seconds
- */
- public function testMixedQueryFetchJoinArrayHydrationPerformance10000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addJoinedEntityResult(
- 'Doctrine\Tests\Models\CMS\CmsPhonenumber',
- 'p',
- 'u',
- 'phonenumbers'
- );
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- $rsm->addScalarResult('sclr0', 'nameUpper');
- $rsm->addFieldResult('p', 'p__phonenumber', 'phonenumber');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'ROMANB',
- 'p__phonenumber' => '42',
- ),
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'ROMANB',
- 'p__phonenumber' => '43',
- ),
- array(
- 'u__id' => '2',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'JWAGE',
- 'p__phonenumber' => '91'
- )
- );
- for ($i = 4; $i < 10000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- 'sclr0' => 'JWAGE' . $i,
- 'p__phonenumber' => '91'
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ArrayHydrator($this->_em);
- $this->setMaxRunningTime(3);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm);
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * [romanb: 10000 rows => 1.5 seconds]
- *
- * MAXIMUM TIME: 3 seconds
- */
- public function testSimpleQueryPartialObjectHydrationPerformance10000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- ),
- array(
- 'u__id' => '2',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- )
- );
- for ($i = 4; $i < 10000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ObjectHydrator($this->_em);
- $this->setMaxRunningTime(3);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm, array(Query::HINT_FORCE_PARTIAL_LOAD => true));
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * [romanb: 10000 rows => 3 seconds]
- *
- * MAXIMUM TIME: 4.5 seconds
- */
- public function testSimpleQueryFullObjectHydrationPerformance10000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- $rsm->addJoinedEntityResult(
- 'Doctrine\Tests\Models\CMS\CmsAddress',
- 'a',
- 'u',
- 'address'
- );
- $rsm->addFieldResult('a', 'a__id', 'id');
- //$rsm->addFieldResult('a', 'a__country', 'country');
- //$rsm->addFieldResult('a', 'a__zip', 'zip');
- //$rsm->addFieldResult('a', 'a__city', 'city');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'a__id' => '1'
- )
- );
- for ($i = 2; $i < 10000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- 'a__id' => $i
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ObjectHydrator($this->_em);
- $this->setMaxRunningTime(5);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm);
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * [romanb: 2000 rows => 0.4 seconds]
- *
- * MAXIMUM TIME: 1 second
- */
- public function testMixedQueryFetchJoinPartialObjectHydrationPerformance2000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addJoinedEntityResult(
- 'Doctrine\Tests\Models\CMS\CmsPhonenumber',
- 'p',
- 'u',
- 'phonenumbers'
- );
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- $rsm->addScalarResult('sclr0', 'nameUpper');
- $rsm->addFieldResult('p', 'p__phonenumber', 'phonenumber');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'ROMANB',
- 'p__phonenumber' => '42',
- ),
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'ROMANB',
- 'p__phonenumber' => '43',
- ),
- array(
- 'u__id' => '2',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'JWAGE',
- 'p__phonenumber' => '91'
- )
- );
- for ($i = 4; $i < 2000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- 'sclr0' => 'JWAGE' . $i,
- 'p__phonenumber' => '91'
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ObjectHydrator($this->_em);
- $this->setMaxRunningTime(1);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm, array(Query::HINT_FORCE_PARTIAL_LOAD => true));
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- /**
- * [romanb: 2000 rows => 0.6 seconds]
- *
- * MAXIMUM TIME: 1 second
- */
- public function testMixedQueryFetchJoinFullObjectHydrationPerformance2000Rows()
- {
- $rsm = new ResultSetMapping;
- $rsm->addEntityResult('Doctrine\Tests\Models\CMS\CmsUser', 'u');
- $rsm->addJoinedEntityResult(
- 'Doctrine\Tests\Models\CMS\CmsPhonenumber',
- 'p',
- 'u',
- 'phonenumbers'
- );
- $rsm->addFieldResult('u', 'u__id', 'id');
- $rsm->addFieldResult('u', 'u__status', 'status');
- $rsm->addFieldResult('u', 'u__username', 'username');
- $rsm->addFieldResult('u', 'u__name', 'name');
- $rsm->addScalarResult('sclr0', 'nameUpper');
- $rsm->addFieldResult('p', 'p__phonenumber', 'phonenumber');
- $rsm->addJoinedEntityResult(
- 'Doctrine\Tests\Models\CMS\CmsAddress',
- 'a',
- 'u',
- 'address'
- );
- $rsm->addFieldResult('a', 'a__id', 'id');
- // Faked result set
- $resultSet = array(
- //row1
- array(
- 'u__id' => '1',
- 'u__status' => 'developer',
- 'u__username' => 'romanb',
- 'u__name' => 'Roman',
- 'sclr0' => 'ROMANB',
- 'p__phonenumber' => '42',
- 'a__id' => '1'
- )
- );
- for ($i = 2; $i < 2000; ++$i) {
- $resultSet[] = array(
- 'u__id' => $i,
- 'u__status' => 'developer',
- 'u__username' => 'jwage',
- 'u__name' => 'Jonathan',
- 'sclr0' => 'JWAGE' . $i,
- 'p__phonenumber' => '91',
- 'a__id' => $i
- );
- }
- $stmt = new HydratorMockStatement($resultSet);
- $hydrator = new \Doctrine\ORM\Internal\Hydration\ObjectHydrator($this->_em);
- $this->setMaxRunningTime(1);
- $s = microtime(true);
- $result = $hydrator->hydrateAll($stmt, $rsm);
- $e = microtime(true);
- echo __FUNCTION__ . " - " . ($e - $s) . " seconds" . PHP_EOL;
- }
- }
|