2017-10-16 05:43:12 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace SilverStripe\Core\Tests;
|
|
|
|
|
2024-09-11 02:16:59 +02:00
|
|
|
use ReflectionClass;
|
2017-10-16 05:43:12 +02:00
|
|
|
use SilverStripe\Core\Environment;
|
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2024-09-18 03:53:44 +02:00
|
|
|
use PHPUnit\Framework\Attributes\DataProvider;
|
2017-10-16 05:43:12 +02:00
|
|
|
|
|
|
|
class EnvironmentTest extends SapphireTest
|
|
|
|
{
|
2024-09-18 03:53:44 +02:00
|
|
|
public static function providerTestPutEnv()
|
2017-10-16 05:43:12 +02:00
|
|
|
{
|
|
|
|
return [
|
|
|
|
['_ENVTEST_BOOL=true', '_ENVTEST_BOOL', true],
|
|
|
|
['_ENVTEST_BOOL_QUOTED="true"', '_ENVTEST_BOOL_QUOTED', 'true'],
|
|
|
|
['_ENVTEST_NUMBER=1', '_ENVTEST_NUMBER', 1],
|
|
|
|
['_ENVTEST_NUMBER_QUOTED="1"', '_ENVTEST_NUMBER_QUOTED', '1'],
|
|
|
|
['_ENVTEST_NUMBER_SPECIAL="value=4"', '_ENVTEST_NUMBER_SPECIAL', 'value=4'],
|
|
|
|
['_ENVTEST_BLANK', '_ENVTEST_BLANK', false],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2024-09-18 03:53:44 +02:00
|
|
|
#[DataProvider('providerTestPutenv')]
|
2017-10-16 05:43:12 +02:00
|
|
|
public function testPutEnv($put, $var, $value)
|
|
|
|
{
|
|
|
|
Environment::putEnv($put);
|
|
|
|
$this->assertEquals($value, Environment::getEnv($var));
|
|
|
|
}
|
|
|
|
|
2024-09-18 03:53:44 +02:00
|
|
|
#[DataProvider('providerTestPutEnv')]
|
2017-10-16 05:43:12 +02:00
|
|
|
public function testSetEnv($put, $var, $value)
|
|
|
|
{
|
|
|
|
Environment::setEnv($var, $value);
|
|
|
|
$this->assertEquals($value, Environment::getEnv($var));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRestoreEnv()
|
|
|
|
{
|
|
|
|
// Set and backup original vars
|
|
|
|
Environment::putEnv('_ENVTEST_RESTORED=initial');
|
|
|
|
$vars = Environment::getVariables();
|
|
|
|
$this->assertEquals('initial', Environment::getEnv('_ENVTEST_RESTORED'));
|
|
|
|
|
2021-12-13 09:05:33 +01:00
|
|
|
// Modify environment
|
2017-10-16 05:43:12 +02:00
|
|
|
Environment::putEnv('_ENVTEST_RESTORED=new');
|
|
|
|
$this->assertEquals('initial', $vars['env']['_ENVTEST_RESTORED']);
|
|
|
|
$this->assertEquals('new', Environment::getEnv('_ENVTEST_RESTORED'));
|
|
|
|
|
|
|
|
// Restore
|
|
|
|
Environment::setVariables($vars);
|
|
|
|
$this->assertEquals('initial', Environment::getEnv('_ENVTEST_RESTORED'));
|
|
|
|
}
|
2018-02-23 04:25:41 +01:00
|
|
|
|
|
|
|
public function testGetVariables()
|
|
|
|
{
|
|
|
|
$GLOBALS['test'] = 'global';
|
|
|
|
$vars = Environment::getVariables();
|
|
|
|
$this->assertArrayHasKey('test', $vars);
|
|
|
|
$this->assertEquals('global', $vars['test']);
|
|
|
|
$this->assertEquals('global', $GLOBALS['test']);
|
|
|
|
|
|
|
|
$vars['test'] = 'fail';
|
|
|
|
$this->assertEquals('fail', $vars['test']);
|
|
|
|
$this->assertEquals('global', $GLOBALS['test']);
|
|
|
|
}
|
2023-03-02 01:47:13 +01:00
|
|
|
|
2024-09-18 03:53:44 +02:00
|
|
|
public static function provideHasEnv()
|
2023-03-02 01:47:13 +01:00
|
|
|
{
|
|
|
|
$setAsOptions = [
|
|
|
|
'.env',
|
|
|
|
'_ENV',
|
|
|
|
'_SERVER',
|
|
|
|
'putenv',
|
|
|
|
];
|
|
|
|
$valueOptions = [
|
|
|
|
true,
|
|
|
|
false,
|
|
|
|
0,
|
|
|
|
1,
|
|
|
|
1.75,
|
|
|
|
'',
|
|
|
|
'0',
|
|
|
|
'some-value',
|
|
|
|
];
|
|
|
|
$scenarios = [];
|
|
|
|
foreach ($setAsOptions as $setAs) {
|
|
|
|
foreach ($valueOptions as $value) {
|
|
|
|
$scenarios[] = [
|
|
|
|
'setAs' => $setAs,
|
|
|
|
'value' => $value,
|
|
|
|
'expected' => true,
|
|
|
|
];
|
|
|
|
}
|
|
|
|
}
|
2023-03-21 23:06:23 +01:00
|
|
|
// `null` isn't a supported value outside of using the `.env` option.
|
|
|
|
$scenarios[] = [
|
|
|
|
'setAs' => '.env',
|
|
|
|
'value' => null,
|
|
|
|
'expected' => true,
|
|
|
|
];
|
2023-03-02 01:47:13 +01:00
|
|
|
$scenarios[] = [
|
|
|
|
'setAs' => null,
|
|
|
|
'value' => null,
|
|
|
|
'expected' => false,
|
|
|
|
];
|
|
|
|
return $scenarios;
|
|
|
|
}
|
|
|
|
|
2024-09-18 03:53:44 +02:00
|
|
|
#[DataProvider('provideHasEnv')]
|
2023-03-02 01:47:13 +01:00
|
|
|
public function testHasEnv(?string $setAs, $value, bool $expected)
|
|
|
|
{
|
|
|
|
$name = '_ENVTEST_HAS_ENV';
|
|
|
|
|
|
|
|
// Set the value
|
|
|
|
switch ($setAs) {
|
|
|
|
case '.env':
|
|
|
|
Environment::setEnv($name, $value);
|
|
|
|
break;
|
|
|
|
case '_ENV':
|
|
|
|
$_ENV[$name] = $value;
|
|
|
|
break;
|
|
|
|
case '_SERVER':
|
|
|
|
$_SERVER[$name] = $value;
|
|
|
|
break;
|
|
|
|
case 'putenv':
|
2023-02-21 02:41:02 +01:00
|
|
|
$val = is_string($value) ? $value : json_encode($value);
|
2023-03-02 01:47:13 +01:00
|
|
|
putenv("$name=$val");
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// null is no-op, to validate not setting it works as expected.
|
|
|
|
if ($setAs !== null) {
|
|
|
|
$this->fail("setAs value $setAs isn't taken into account correctly for this test.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->assertSame($expected, Environment::hasEnv($name));
|
|
|
|
|
|
|
|
// unset the value
|
2024-09-11 02:16:59 +02:00
|
|
|
$reflectionEnv = new ReflectionClass(Environment::class);
|
|
|
|
$reflectionEnv->setStaticPropertyValue('env', array_diff($reflectionEnv->getStaticPropertyValue('env'), [$name => $value]));
|
2023-03-02 01:47:13 +01:00
|
|
|
unset($_ENV[$name]);
|
|
|
|
unset($_SERVER[$name]);
|
|
|
|
putenv("$name");
|
|
|
|
}
|
2017-10-16 05:43:12 +02:00
|
|
|
}
|