2009-04-03 11:06:58 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Functional;
|
|
|
|
|
|
|
|
require_once __DIR__ . '/../../TestInit.php';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Description of SequenceGeneratorTest
|
|
|
|
*
|
|
|
|
* @author robo
|
|
|
|
*/
|
|
|
|
class SequenceGeneratorTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|
|
|
{
|
2010-03-20 17:04:46 +00:00
|
|
|
public function setUp()
|
2009-04-03 11:06:58 +00:00
|
|
|
{
|
2010-03-20 17:04:46 +00:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
if (!$this->_em->getConnection()->getDatabasePlatform()->supportsSequences()) {
|
|
|
|
$this->markTestSkipped('Only working for Databases that support sequences.');
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
$this->_schemaTool->createSchema(array(
|
|
|
|
$this->_em->getClassMetadata(__NAMESPACE__ . '\SequenceEntity'),
|
|
|
|
));
|
|
|
|
} catch(\Exception $e) {
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testHighAllocationSizeSequence()
|
|
|
|
{
|
|
|
|
for ($i = 0; $i < 11; $i++) {
|
|
|
|
$e = new SequenceEntity();
|
|
|
|
$this->_em->persist($e);
|
|
|
|
}
|
|
|
|
$this->_em->flush();
|
2009-04-03 11:06:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-05-29 10:23:13 +00:00
|
|
|
* @Entity
|
2009-04-03 11:06:58 +00:00
|
|
|
*/
|
2010-03-20 17:04:46 +00:00
|
|
|
class SequenceEntity
|
|
|
|
{
|
2009-04-03 11:06:58 +00:00
|
|
|
/**
|
2009-05-29 10:23:13 +00:00
|
|
|
* @Id
|
2010-03-20 17:04:46 +00:00
|
|
|
* @column(type="integer")
|
|
|
|
* @GeneratedValue(strategy="SEQUENCE")
|
|
|
|
* @SequenceGenerator(allocationSize=5,sequenceName="person_id_seq")
|
2009-04-03 11:06:58 +00:00
|
|
|
*/
|
2010-03-20 17:04:46 +00:00
|
|
|
public $id;
|
|
|
|
}
|