2009-05-14 14:57:08 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests;
|
|
|
|
|
|
|
|
/**
|
2012-12-14 18:55:49 +00:00
|
|
|
* Description of DoctrinePerformanceTestCase.
|
2009-05-14 14:57:08 +00:00
|
|
|
*
|
|
|
|
* @author robo
|
|
|
|
*/
|
2009-05-19 16:11:08 +00:00
|
|
|
class OrmPerformanceTestCase extends OrmFunctionalTestCase
|
2009-05-14 14:57:08 +00:00
|
|
|
{
|
|
|
|
/**
|
2012-12-14 18:55:49 +00:00
|
|
|
* @var integer
|
2009-05-14 14:57:08 +00:00
|
|
|
*/
|
|
|
|
protected $maxRunningTime = 0;
|
|
|
|
|
|
|
|
/**
|
2012-12-14 18:55:49 +00:00
|
|
|
* @return void
|
2009-05-14 14:57:08 +00:00
|
|
|
*/
|
|
|
|
protected function runTest()
|
|
|
|
{
|
|
|
|
$s = microtime(true);
|
|
|
|
parent::runTest();
|
|
|
|
$time = microtime(true) - $s;
|
|
|
|
|
|
|
|
if ($this->maxRunningTime != 0 && $time > $this->maxRunningTime) {
|
|
|
|
$this->fail(
|
|
|
|
sprintf(
|
|
|
|
'expected running time: <= %s but was: %s',
|
|
|
|
|
|
|
|
$this->maxRunningTime,
|
|
|
|
$time
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2012-12-14 18:55:49 +00:00
|
|
|
* @param integer $maxRunningTime
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*
|
|
|
|
* @throws \InvalidArgumentException
|
|
|
|
*
|
|
|
|
* @since Method available since Release 2.3.0
|
2009-05-14 14:57:08 +00:00
|
|
|
*/
|
|
|
|
public function setMaxRunningTime($maxRunningTime)
|
|
|
|
{
|
|
|
|
if (is_integer($maxRunningTime) && $maxRunningTime >= 0) {
|
|
|
|
$this->maxRunningTime = $maxRunningTime;
|
|
|
|
} else {
|
|
|
|
throw new \InvalidArgumentException;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return integer
|
2012-12-14 18:55:49 +00:00
|
|
|
*
|
|
|
|
* @since Method available since Release 2.3.0
|
2009-05-14 14:57:08 +00:00
|
|
|
*/
|
|
|
|
public function getMaxRunningTime()
|
|
|
|
{
|
|
|
|
return $this->maxRunningTime;
|
|
|
|
}
|
|
|
|
}
|