2009-06-17 13:36:49 +02:00
|
|
|
<?php
|
2016-08-19 00:51:35 +02:00
|
|
|
|
2016-10-14 03:30:05 +02:00
|
|
|
namespace SilverStripe\Core\Tests;
|
|
|
|
|
2017-06-20 05:34:34 +02:00
|
|
|
use SilverStripe\Core\Environment;
|
2016-08-19 00:51:35 +02:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2009-06-17 13:36:49 +02:00
|
|
|
|
2016-12-16 05:34:21 +01:00
|
|
|
class MemoryLimitTest extends SapphireTest
|
|
|
|
{
|
2017-06-20 05:34:34 +02:00
|
|
|
protected $origMemLimitMax;
|
|
|
|
protected $origTimeLimitMax;
|
|
|
|
protected $origMemLimit;
|
|
|
|
protected $origTimeLimit;
|
2016-12-16 05:34:21 +01:00
|
|
|
|
2017-06-20 05:34:34 +02:00
|
|
|
protected function setUp()
|
2016-12-16 05:34:21 +01:00
|
|
|
{
|
2017-06-20 05:34:34 +02:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
// see http://www.hardened-php.net/suhosin/configuration.html#suhosin.memory_limit
|
|
|
|
if (in_array('suhosin', get_loaded_extensions())) {
|
|
|
|
$this->markTestSkipped("This test cannot be run with suhosin installed");
|
|
|
|
} else {
|
|
|
|
$this->origMemLimit = ini_get('memory_limit');
|
|
|
|
$this->origTimeLimit = ini_get('max_execution_time');
|
|
|
|
$this->origMemLimitMax = Environment::getMemoryLimitMax();
|
|
|
|
$this->origTimeLimitMax = Environment::getTimeLimitMax();
|
|
|
|
Environment::setMemoryLimitMax(null);
|
|
|
|
Environment::setTimeLimitMax(null);
|
2016-12-16 05:34:21 +01:00
|
|
|
}
|
2017-06-20 05:34:34 +02:00
|
|
|
}
|
2016-12-16 05:34:21 +01:00
|
|
|
|
2017-06-20 05:34:34 +02:00
|
|
|
protected function tearDown()
|
|
|
|
{
|
|
|
|
if (!in_array('suhosin', get_loaded_extensions())) {
|
|
|
|
ini_set('memory_limit', $this->origMemLimit);
|
|
|
|
set_time_limit($this->origTimeLimit);
|
|
|
|
Environment::setMemoryLimitMax($this->origMemLimitMax);
|
|
|
|
Environment::setTimeLimitMax($this->origTimeLimitMax);
|
|
|
|
}
|
|
|
|
parent::tearDown();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIncreaseMemoryLimitTo()
|
|
|
|
{
|
2016-12-16 05:34:21 +01:00
|
|
|
ini_set('memory_limit', '64M');
|
|
|
|
|
|
|
|
// It can go up
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo('128M');
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals('128M', ini_get('memory_limit'));
|
|
|
|
|
|
|
|
// But not down
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo('64M');
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals('128M', ini_get('memory_limit'));
|
|
|
|
|
|
|
|
// Test the different kinds of syntaxes
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo(1024*1024*200);
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(1024*1024*200, ini_get('memory_limit'));
|
|
|
|
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo('409600K');
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals('409600K', ini_get('memory_limit'));
|
|
|
|
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo('1G');
|
2016-12-16 05:34:21 +01:00
|
|
|
|
|
|
|
// If memory limit was left at 409600K, that means that the current testbox doesn't have
|
|
|
|
// 1G of memory available. That's okay; let's not report a failure for that.
|
|
|
|
if (ini_get('memory_limit') != '409600K') {
|
|
|
|
$this->assertEquals('1G', ini_get('memory_limit'));
|
|
|
|
}
|
|
|
|
|
|
|
|
// No argument means unlimited
|
2017-06-20 05:34:34 +02:00
|
|
|
Environment::increaseMemoryLimitTo();
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(-1, ini_get('memory_limit'));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testIncreaseTimeLimitTo()
|
|
|
|
{
|
2017-02-22 04:15:08 +01:00
|
|
|
// Can't change time limit
|
|
|
|
if (!set_time_limit(6000)) {
|
2017-06-20 05:34:34 +02:00
|
|
|
$this->markTestSkipped("Cannot change time limit");
|
2017-02-22 04:15:08 +01:00
|
|
|
}
|
2016-12-16 05:34:21 +01:00
|
|
|
|
|
|
|
// It can go up
|
2017-06-20 05:34:34 +02:00
|
|
|
$this->assertTrue(Environment::increaseTimeLimitTo(7000));
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(7000, ini_get('max_execution_time'));
|
|
|
|
|
|
|
|
// But not down
|
2017-06-20 05:34:34 +02:00
|
|
|
$this->assertTrue(Environment::increaseTimeLimitTo(5000));
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(7000, ini_get('max_execution_time'));
|
|
|
|
|
|
|
|
// 0/nothing means infinity
|
2017-06-20 05:34:34 +02:00
|
|
|
$this->assertTrue(Environment::increaseTimeLimitTo());
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(0, ini_get('max_execution_time'));
|
|
|
|
|
|
|
|
// Can't go down from there
|
2017-06-20 05:34:34 +02:00
|
|
|
$this->assertTrue(Environment::increaseTimeLimitTo(10000));
|
2016-12-16 05:34:21 +01:00
|
|
|
$this->assertEquals(0, ini_get('max_execution_time'));
|
|
|
|
}
|
2012-03-24 04:04:52 +01:00
|
|
|
}
|