flatrr/tests/SelfReferencingFlatArrayTest.php

121 lines
3.7 KiB
PHP
Raw Permalink Normal View History

2018-08-17 21:02:50 +00:00
<?php
2022-12-06 18:25:59 +00:00
/* Flatrr | https://github.com/jobyone/flatrr | MIT License */
2018-08-17 21:02:50 +00:00
declare(strict_types=1);
2022-12-06 18:25:59 +00:00
2018-08-17 22:09:45 +00:00
namespace Flatrr;
2018-08-17 21:02:50 +00:00
use PHPUnit\Framework\TestCase;
class SelfReferencingFlatArrayTest extends TestCase
{
public function testVariables()
{
$f = new SelfReferencingFlatArray([
'foo' => 'bar',
2022-12-06 18:25:59 +00:00
'bar' => ['baz' => 'qux'],
2018-08-17 21:02:50 +00:00
'test' => [
'foo' => '${foo}',
'bar' => '${bar.baz}',
'none' => '${foo.none}',
'escaped' => [
'full' => '$\\{foo\\}',
'left' => '$\\{foo}',
'right' => '${foo\\}'
],
],
'nested' => [
'foo' => '${test.foo}',
'bar' => '${test.bar}',
'none' => '${test.none}',
'escaped' => [
'full' => '${test.escaped.full}',
'left' => '${test.escaped.left}',
'right' => '${test.escaped.right}'
]
]
]);
//basic references
$this->assertEquals('bar', $f['test.foo']);
$this->assertEquals('qux', $f['test.bar']);
$this->assertEquals('${foo.none}', $f['test.none']);
//nested references
$this->assertEquals('bar', $f['nested.foo']);
$this->assertEquals('qux', $f['nested.bar']);
$this->assertEquals('${foo.none}', $f['nested.none']);
//escaped
$this->assertEquals('${foo}', $f['test.escaped.full']);
$this->assertEquals('${foo}', $f['test.escaped.left']);
$this->assertEquals('${foo}', $f['test.escaped.right']);
//nested and escaped
$this->assertEquals('${foo}', $f['nested.escaped.full']);
$this->assertEquals('${foo}', $f['nested.escaped.left']);
$this->assertEquals('${foo}', $f['nested.escaped.right']);
2022-12-06 18:25:59 +00:00
//raw
$this->assertEquals('${foo}', $f->get('test.foo', true));
2018-08-17 21:02:50 +00:00
}
public function testSettingFalseyValues()
{
2022-12-06 18:25:59 +00:00
$a = new SelfReferencingFlatArray(['foo' => ['bar' => 'baz']]);
$a['foo.bar'] = false;
$this->assertFalse($a['foo.bar']);
$a['foo.bar'] = 0;
$this->assertSame(0, $a['foo.bar']);
$a['foo.bar'] = '';
$this->assertSame('', $a['foo.bar']);
$a['foo.bar'] = [];
$this->assertSame([], $a['foo.bar']);
}
2022-12-06 18:25:59 +00:00
public function testMergingFalseyValues()
{
2022-12-06 18:25:59 +00:00
$a = new SelfReferencingFlatArray(['foo' => ['bar' => 'baz']]);
$a->merge(['foo' => ['bar' => false]], null, true);
$this->assertFalse($a['foo.bar']);
2022-12-06 18:25:59 +00:00
$a->merge(['foo' => ['bar' => 0]], null, true);
$this->assertSame(0, $a['foo.bar']);
2022-12-06 18:25:59 +00:00
$a->merge(['foo' => ['bar' => '']], null, true);
$this->assertSame('', $a['foo.bar']);
2022-12-06 18:25:59 +00:00
$a->merge(['foo' => ['bar' => []]], null, true);
$this->assertSame([], $a['foo.bar']);
}
2022-12-06 18:25:59 +00:00
public function testForeach()
{
$reference = [
'a' => 'b',
'b' => '${a}',
'd' => '${b}'
];
$arr = new SelfReferencingFlatArray($reference);
foreach ($arr as $key => $value) {
$this->assertEquals('b', $value);
}
}
public function testPop()
{
$f = new SelfReferencingFlatArray([
'a' => 'b',
'c' => [
'${a}'
]
]);
$this->assertEquals('b', $f->pop('c'));
$this->assertNull($f->pop('c'));
}
public function testShift()
{
$f = new SelfReferencingFlatArray([
'a' => 'b',
'c' => [
'${a}'
]
]);
$this->assertEquals('b', $f->shift('c'));
$this->assertNull($f->shift('c'));
}
2018-08-17 21:02:50 +00:00
}