mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
367 lines
14 KiB
PHP
367 lines
14 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\Core\Tests\Config;
|
|
|
|
use SilverStripe\Config\Collections\MutableConfigCollectionInterface;
|
|
use SilverStripe\Config\MergeStrategy\Priority;
|
|
use SilverStripe\Core\Config\Config;
|
|
use SilverStripe\Dev\SapphireTest;
|
|
|
|
class ConfigTest extends SapphireTest
|
|
{
|
|
|
|
public function testNest()
|
|
{
|
|
// Check basic config
|
|
$this->assertEquals(3, Config::inst()->get(ConfigTest\TestNest::class, 'foo'));
|
|
$this->assertEquals(5, Config::inst()->get(ConfigTest\TestNest::class, 'bar'));
|
|
|
|
// Test nest copies data
|
|
Config::nest();
|
|
$this->assertEquals(3, Config::inst()->get(ConfigTest\TestNest::class, 'foo'));
|
|
$this->assertEquals(5, Config::inst()->get(ConfigTest\TestNest::class, 'bar'));
|
|
|
|
// Test nested data can be updated
|
|
Config::modify()->merge(ConfigTest\TestNest::class, 'foo', [4]);
|
|
$this->assertEquals(4, Config::inst()->get(ConfigTest\TestNest::class, 'foo')[0]);
|
|
$this->assertEquals(5, Config::inst()->get(ConfigTest\TestNest::class, 'bar'));
|
|
|
|
// Test unnest restores data
|
|
Config::unnest();
|
|
$this->assertEquals(3, Config::inst()->get(ConfigTest\TestNest::class, 'foo'));
|
|
$this->assertEquals(5, Config::inst()->get(ConfigTest\TestNest::class, 'bar'));
|
|
}
|
|
|
|
public function testUpdateStatic()
|
|
{
|
|
// Test base state
|
|
$this->assertEquals(
|
|
['test_1'],
|
|
Config::inst()->get(ConfigTest\First::class, 'first')
|
|
);
|
|
$this->assertEquals(
|
|
[
|
|
'test_1',
|
|
'test_2'
|
|
],
|
|
Config::inst()->get(ConfigTest\Second::class, 'first')
|
|
);
|
|
$this->assertEquals(
|
|
[ 'test_2' ],
|
|
Config::inst()->get(ConfigTest\Second::class, 'first', Config::UNINHERITED)
|
|
);
|
|
$this->assertEquals(
|
|
[
|
|
'test_1',
|
|
'test_2',
|
|
'test_3'
|
|
],
|
|
Config::inst()->get(ConfigTest\Third::class, 'first')
|
|
);
|
|
$this->assertEquals(
|
|
[ 'test_3' ],
|
|
Config::inst()->get(ConfigTest\Third::class, 'first', true)
|
|
);
|
|
|
|
// Modify first param
|
|
Config::modify()->merge(ConfigTest\First::class, 'first', ['test_1_2']);
|
|
Config::modify()->merge(ConfigTest\Third::class, 'first', ['test_3_2']);
|
|
Config::modify()->merge(ConfigTest\Fourth::class, 'first', ['test_4']);
|
|
|
|
// Check base class
|
|
$this->assertEquals(
|
|
['test_1', 'test_1_2'],
|
|
Config::inst()->get(ConfigTest\First::class, 'first')
|
|
);
|
|
$this->assertEquals(
|
|
['test_1', 'test_1_2'],
|
|
Config::inst()->get(ConfigTest\First::class, 'first', Config::UNINHERITED)
|
|
);
|
|
$this->assertEquals(
|
|
['test_1'],
|
|
Config::inst()->get(ConfigTest\First::class, 'first', Config::NO_DELTAS)
|
|
);
|
|
$this->assertEquals(
|
|
['test_1'],
|
|
Config::inst()->get(ConfigTest\First::class, 'first', Config::NO_DELTAS | Config::UNINHERITED)
|
|
);
|
|
|
|
// Modify second param
|
|
Config::modify()->merge(ConfigTest\Fourth::class, 'second', ['test_4']);
|
|
Config::modify()->merge(ConfigTest\Third::class, 'second', ['test_3_2']);
|
|
|
|
// Check fourth class
|
|
$this->assertEquals(
|
|
['test_1', 'test_3', 'test_3_2', 'test_4'],
|
|
Config::inst()->get(ConfigTest\Fourth::class, 'second')
|
|
);
|
|
$this->assertEquals(
|
|
['test_4'],
|
|
Config::inst()->get(ConfigTest\Fourth::class, 'second', Config::UNINHERITED)
|
|
);
|
|
$this->assertEquals(
|
|
['test_1', 'test_3'],
|
|
Config::inst()->get(ConfigTest\Fourth::class, 'second', Config::NO_DELTAS)
|
|
);
|
|
$this->assertEquals(
|
|
null,
|
|
Config::inst()->get(ConfigTest\Fourth::class, 'second', Config::NO_DELTAS | Config::UNINHERITED)
|
|
);
|
|
|
|
// Check third class
|
|
$this->assertEquals(
|
|
['test_1', 'test_3', 'test_3_2'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second')
|
|
);
|
|
$this->assertEquals(
|
|
['test_3', 'test_3_2'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::UNINHERITED)
|
|
);
|
|
$this->assertEquals(
|
|
['test_1', 'test_3'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::NO_DELTAS)
|
|
);
|
|
$this->assertEquals(
|
|
['test_3'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::NO_DELTAS | Config::UNINHERITED)
|
|
);
|
|
|
|
// Test remove()
|
|
Config::modify()->remove(ConfigTest\Third::class, 'second');
|
|
|
|
// Check third class ->get()
|
|
$this->assertEquals(
|
|
null,
|
|
Config::inst()->get(ConfigTest\Third::class, 'second')
|
|
);
|
|
$this->assertEquals(
|
|
['test_1', 'test_3'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::NO_DELTAS)
|
|
);
|
|
$this->assertEquals(
|
|
null,
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::UNINHERITED)
|
|
);
|
|
|
|
// Check ->exists()
|
|
$this->assertFalse(
|
|
Config::inst()->exists(ConfigTest\Third::class, 'second')
|
|
);
|
|
$this->assertFalse(
|
|
Config::inst()->exists(ConfigTest\Third::class, 'second', Config::UNINHERITED)
|
|
);
|
|
$this->assertTrue(
|
|
Config::inst()->exists(ConfigTest\Third::class, 'second', Config::NO_DELTAS)
|
|
);
|
|
|
|
// Test merge()
|
|
Config::modify()->merge(ConfigTest\Third::class, 'second', ['test_3_2']);
|
|
$this->assertEquals(
|
|
['test_3_2'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second')
|
|
);
|
|
// No-deltas omits both above ->remove() as well as ->merge()
|
|
$this->assertEquals(
|
|
['test_1', 'test_3'],
|
|
Config::inst()->get(ConfigTest\Third::class, 'second', Config::NO_DELTAS)
|
|
);
|
|
}
|
|
|
|
public function testUpdateWithFalsyValues()
|
|
{
|
|
// Booleans
|
|
$this->assertTrue(Config::inst()->get(ConfigTest\First::class, 'bool'));
|
|
Config::modify()->merge(ConfigTest\First::class, 'bool', [false]);
|
|
$this->assertFalse(Config::inst()->get(ConfigTest\First::class, 'bool')[0]);
|
|
Config::modify()->merge(ConfigTest\First::class, 'bool', [true]);
|
|
$this->assertTrue(Config::inst()->get(ConfigTest\First::class, 'bool')[1]);
|
|
|
|
// Integers
|
|
$this->assertEquals(42, Config::inst()->get(ConfigTest\First::class, 'int'));
|
|
Config::modify()->merge(ConfigTest\First::class, 'int', [0]);
|
|
$this->assertEquals(0, Config::inst()->get(ConfigTest\First::class, 'int')[0]);
|
|
Config::modify()->merge(ConfigTest\First::class, 'int', [42]);
|
|
$this->assertEquals(42, Config::inst()->get(ConfigTest\First::class, 'int')[1]);
|
|
|
|
// Strings
|
|
$this->assertEquals('value', Config::inst()->get(ConfigTest\First::class, 'string'));
|
|
Config::modify()->merge(ConfigTest\First::class, 'string', ['']);
|
|
$this->assertEquals('', Config::inst()->get(ConfigTest\First::class, 'string')[0]);
|
|
Config::modify()->merge(ConfigTest\First::class, 'string', ['value']);
|
|
$this->assertEquals('value', Config::inst()->get(ConfigTest\First::class, 'string')[1]);
|
|
|
|
// Nulls
|
|
$this->assertEquals('value', Config::inst()->get(ConfigTest\First::class, 'nullable'));
|
|
Config::modify()->merge(ConfigTest\First::class, 'nullable', [null]);
|
|
$this->assertNull(Config::inst()->get(ConfigTest\First::class, 'nullable')[0]);
|
|
Config::modify()->merge(ConfigTest\First::class, 'nullable', ['value']);
|
|
$this->assertEquals('value', Config::inst()->get(ConfigTest\First::class, 'nullable')[1]);
|
|
}
|
|
|
|
public function testSetsFalsyDefaults()
|
|
{
|
|
$this->assertFalse(Config::inst()->get(ConfigTest\First::class, 'default_false'));
|
|
// Technically the same as an undefined config key
|
|
$this->assertNull(Config::inst()->get(ConfigTest\First::class, 'default_null'));
|
|
$this->assertEquals(0, Config::inst()->get(ConfigTest\First::class, 'default_zero'));
|
|
$this->assertEquals('', Config::inst()->get(ConfigTest\First::class, 'default_empty_string'));
|
|
}
|
|
|
|
public function testUninheritedStatic()
|
|
{
|
|
$this->assertEquals(Config::inst()->get(ConfigTest\First::class, 'third', Config::UNINHERITED), 'test_1');
|
|
$this->assertEquals(Config::inst()->get(ConfigTest\Fourth::class, 'third', Config::UNINHERITED), null);
|
|
|
|
Config::modify()->merge(ConfigTest\First::class, 'first', ['test_1b']);
|
|
Config::modify()->merge(ConfigTest\Second::class, 'first', ['test_2b']);
|
|
|
|
// Check that it can be applied to parent and subclasses, and queried directly
|
|
$this->assertContains(
|
|
'test_1b',
|
|
Config::inst()->get(ConfigTest\First::class, 'first', Config::UNINHERITED)
|
|
);
|
|
$this->assertContains(
|
|
'test_2b',
|
|
Config::inst()->get(ConfigTest\Second::class, 'first', Config::UNINHERITED)
|
|
);
|
|
|
|
// But it won't affect subclasses - this is *uninherited* static
|
|
$this->assertNotContains(
|
|
'test_2b',
|
|
Config::inst()->get(ConfigTest\Third::class, 'first', Config::UNINHERITED)
|
|
);
|
|
$this->assertNull(Config::inst()->get(ConfigTest\Fourth::class, 'first', Config::UNINHERITED));
|
|
|
|
// Subclasses that don't have the static explicitly defined should allow definition, also
|
|
// This also checks that set can be called after the first uninherited get()
|
|
// call (which can be buggy due to caching)
|
|
Config::modify()->merge(ConfigTest\Fourth::class, 'first', ['test_4b']);
|
|
$this->assertContains('test_4b', Config::inst()->get(ConfigTest\Fourth::class, 'first', Config::UNINHERITED));
|
|
}
|
|
|
|
public function testCombinedStatic()
|
|
{
|
|
$this->assertEquals(
|
|
['test_1', 'test_2', 'test_3'],
|
|
ConfigTest\Combined3::config()->get('first')
|
|
);
|
|
|
|
// Test that unset values are ignored
|
|
$this->assertEquals(
|
|
['test_1', 'test_3'],
|
|
ConfigTest\Combined3::config()->get('second')
|
|
);
|
|
}
|
|
|
|
public function testMerges()
|
|
{
|
|
$result = Priority::mergeArray(
|
|
['A' => 1, 'B' => 2, 'C' => 3],
|
|
['C' => 4, 'D' => 5]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => 3, 'D' => 5],
|
|
$result
|
|
);
|
|
|
|
$result = Priority::mergeArray(
|
|
['C' => 4, 'D' => 5],
|
|
['A' => 1, 'B' => 2, 'C' => 3]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => 4, 'D' => 5],
|
|
$result
|
|
);
|
|
|
|
$result = Priority::mergeArray(
|
|
[ 'C' => [4, 5, 6], 'D' => 5 ],
|
|
[ 'A' => 1, 'B' => 2, 'C' => [1, 2, 3] ]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => [1, 2, 3, 4, 5, 6], 'D' => 5],
|
|
$result
|
|
);
|
|
|
|
$result = Priority::mergeArray(
|
|
['A' => 1, 'B' => 2, 'C' => [1, 2, 3]],
|
|
['C' => [4, 5, 6], 'D' => 5]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => [4, 5, 6, 1, 2, 3], 'D' => 5],
|
|
$result
|
|
);
|
|
|
|
$result = Priority::mergeArray(
|
|
['A' => 1, 'B' => 2, 'C' => ['Foo' => 1, 'Bar' => 2], 'D' => 3],
|
|
['C' => ['Bar' => 3, 'Baz' => 4]]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => ['Foo' => 1, 'Bar' => 2, 'Baz' => 4], 'D' => 3],
|
|
$result
|
|
);
|
|
|
|
$result = Priority::mergeArray(
|
|
['C' => ['Bar' => 3, 'Baz' => 4]],
|
|
['A' => 1, 'B' => 2, 'C' => ['Foo' => 1, 'Bar' => 2], 'D' => 3]
|
|
);
|
|
$this->assertEquals(
|
|
['A' => 1, 'B' => 2, 'C' => ['Foo' => 1, 'Bar' => 3, 'Baz' => 4], 'D' => 3],
|
|
$result
|
|
);
|
|
}
|
|
|
|
public function testForClass()
|
|
{
|
|
$config = ConfigTest\DefinesFoo::config();
|
|
// Set values
|
|
$this->assertTrue(isset($config->not_foo));
|
|
$this->assertFalse(empty($config->not_foo));
|
|
$this->assertEquals(1, $config->not_foo);
|
|
|
|
// Unset values
|
|
$this->assertFalse(isset($config->bar));
|
|
$this->assertTrue(empty($config->bar));
|
|
$this->assertNull($config->bar);
|
|
}
|
|
|
|
public function testWithConfig()
|
|
{
|
|
$oldValue = 'test_1';
|
|
$newValue1 = 'new value 1';
|
|
$newValue2 = 'new value 2';
|
|
$property = 'third';
|
|
|
|
$this->assertEquals(
|
|
$oldValue,
|
|
Config::inst()->get(ConfigTest\First::class, $property)
|
|
);
|
|
|
|
Config::withConfig(function (MutableConfigCollectionInterface $config) use ($newValue1, $newValue2, $property) {
|
|
$config->set(ConfigTest\First::class, $property, $newValue1);
|
|
|
|
$this->assertEquals(
|
|
$newValue1,
|
|
Config::inst()->get(ConfigTest\First::class, $property)
|
|
);
|
|
|
|
$resultValue = Config::withConfig(function (MutableConfigCollectionInterface $config) use ($newValue2, $property) {
|
|
$config->set(ConfigTest\First::class, $property, $newValue2);
|
|
|
|
return Config::inst()->get(ConfigTest\First::class, $property);
|
|
});
|
|
|
|
$this->assertEquals($newValue2, $resultValue);
|
|
|
|
$this->assertEquals(
|
|
$newValue1,
|
|
Config::inst()->get(ConfigTest\First::class, $property)
|
|
);
|
|
});
|
|
|
|
$this->assertEquals(
|
|
$oldValue,
|
|
Config::inst()->get(ConfigTest\First::class, $property)
|
|
);
|
|
}
|
|
}
|