2013-08-06 16:28:26 +02:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-10 10:32:50 +02:00
|
|
|
namespace Tests\Icinga\Config;
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-10-31 10:54:53 +01:00
|
|
|
use Icinga\File\Ini\IniWriter;
|
2014-04-10 10:32:50 +02:00
|
|
|
use Icinga\Test\BaseTestCase;
|
2014-11-07 13:53:03 +01:00
|
|
|
use Icinga\Application\Config;
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-10-31 10:54:53 +01:00
|
|
|
class IniWriterTest extends BaseTestCase
|
2014-04-10 10:32:50 +02:00
|
|
|
{
|
2014-04-23 13:48:43 +02:00
|
|
|
protected $tempFile;
|
2014-08-26 18:24:31 +02:00
|
|
|
protected $tempFile2;
|
2013-08-06 16:28:26 +02:00
|
|
|
|
|
|
|
public function setUp()
|
|
|
|
{
|
2014-04-11 15:31:29 +02:00
|
|
|
parent::setUp();
|
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
$this->tempFile = tempnam(sys_get_temp_dir(), 'icinga-ini-writer-test');
|
2014-08-26 18:24:31 +02:00
|
|
|
$this->tempFile2 = tempnam(sys_get_temp_dir(), 'icinga-ini-writer-test-2');
|
2014-04-23 13:48:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function tearDown()
|
|
|
|
{
|
|
|
|
parent::tearDown();
|
|
|
|
|
|
|
|
unlink($this->tempFile);
|
2014-08-26 18:24:31 +02:00
|
|
|
unlink($this->tempFile2);
|
2014-04-23 13:48:43 +02:00
|
|
|
}
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-11-11 14:59:34 +01:00
|
|
|
public function testWhetherPointInSectionIsNotNormalized()
|
|
|
|
{
|
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'section' => array(
|
|
|
|
'foo.bar' => 1337
|
2014-11-11 14:59:34 +01:00
|
|
|
),
|
2015-08-05 14:21:46 +02:00
|
|
|
'section.with.multiple.dots' => array(
|
|
|
|
'some more.nested stuff' => 'With more values'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
$this->tempFile
|
2014-11-11 14:59:34 +01:00
|
|
|
);
|
|
|
|
$writer->write();
|
|
|
|
$config = Config::fromIni($this->tempFile)->toArray();
|
|
|
|
$this->assertTrue(array_key_exists('section.with.multiple.dots', $config), 'Section names not normalized');
|
|
|
|
}
|
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
public function testWhetherNestedPropertiesAreInserted()
|
|
|
|
{
|
|
|
|
$target = $this->writeConfigToTemporaryFile('');
|
2014-11-18 13:11:52 +01:00
|
|
|
$config = Config::fromArray(array('a' => array('b' => 'c')));
|
2015-08-05 14:21:46 +02:00
|
|
|
$writer = new IniWriter($config, $target);
|
2014-04-23 13:48:43 +02:00
|
|
|
$writer->write();
|
|
|
|
|
2014-11-07 13:53:03 +01:00
|
|
|
$newConfig = Config::fromIni($target);
|
2014-04-23 13:48:43 +02:00
|
|
|
$this->assertInstanceOf(
|
2014-11-18 13:11:52 +01:00
|
|
|
'Icinga\Data\ConfigObject',
|
|
|
|
$newConfig->getSection('a'),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not insert nested properties'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
'c',
|
2014-11-18 13:11:52 +01:00
|
|
|
$newConfig->getSection('a')->get('b'),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not insert nested properties'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
2013-08-06 16:28:26 +02:00
|
|
|
}
|
|
|
|
|
2014-07-04 11:35:00 +02:00
|
|
|
public function testWhetherSectionOrderIsUpdated()
|
2014-04-23 13:48:43 +02:00
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
[one]
|
2015-08-05 14:21:46 +02:00
|
|
|
key1 = "1"
|
|
|
|
key2 = "2"
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
[two]
|
2015-08-05 14:21:46 +02:00
|
|
|
a.b = "c"
|
|
|
|
d.e = "f"
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
[three]
|
2015-08-05 14:21:46 +02:00
|
|
|
key = "value"
|
|
|
|
foo.bar = "raboof"
|
2014-07-03 17:22:51 +02:00
|
|
|
EOD;
|
|
|
|
|
|
|
|
$reverted = <<<'EOD'
|
|
|
|
[three]
|
2015-08-05 14:21:46 +02:00
|
|
|
key = "value"
|
|
|
|
foo.bar = "raboof"
|
2014-07-03 17:22:51 +02:00
|
|
|
|
|
|
|
[two]
|
2015-08-05 14:21:46 +02:00
|
|
|
a.b = "c"
|
|
|
|
d.e = "f"
|
2014-07-03 17:22:51 +02:00
|
|
|
|
|
|
|
[one]
|
2015-08-05 14:21:46 +02:00
|
|
|
key1 = "1"
|
|
|
|
key2 = "2"
|
2014-04-23 13:48:43 +02:00
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2014-10-31 10:54:53 +01:00
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'three' => array(
|
|
|
|
'foo.bar' => 'raboof',
|
|
|
|
'key' => 'value'
|
|
|
|
),
|
|
|
|
'two' => array(
|
|
|
|
'd.e' => 'f',
|
|
|
|
'a.b' => 'c'
|
|
|
|
),
|
|
|
|
'one' => array(
|
|
|
|
'key2' => '2',
|
|
|
|
'key1' => '1'
|
2014-04-23 13:48:43 +02:00
|
|
|
)
|
2015-08-05 14:21:46 +02:00
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
$this->assertEquals(
|
2014-07-03 17:22:51 +02:00
|
|
|
trim($reverted),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve section and/or property order'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
}
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-07-04 11:35:00 +02:00
|
|
|
public function testWhetherCommentOrderIsUpdated()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
; comment 1
|
|
|
|
[one]
|
|
|
|
|
|
|
|
; comment 2
|
|
|
|
[two]
|
|
|
|
EOD;
|
|
|
|
|
|
|
|
$reverted = <<<'EOD'
|
|
|
|
; comment 2
|
|
|
|
[two]
|
|
|
|
|
|
|
|
; comment 1
|
|
|
|
[one]
|
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2014-10-31 10:54:53 +01:00
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'two' => array(),
|
|
|
|
'one' => array()
|
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
2014-07-04 11:35:00 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
trim($reverted),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve section and/or property order'
|
2014-07-04 11:35:00 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
public function testWhetherCommentsOnEmptyLinesArePreserved()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
; some interesting comment
|
2015-08-05 14:21:46 +02:00
|
|
|
[blarg]
|
|
|
|
key = "value"
|
|
|
|
|
|
|
|
; some dangling comment
|
2014-04-23 13:48:43 +02:00
|
|
|
; boring comment
|
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2015-08-05 14:21:46 +02:00
|
|
|
$writer = new IniWriter(Config::fromArray(array('blarg' => array('key' => 'value'))), $target);
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
$this->assertEquals(
|
2015-06-01 16:46:52 +02:00
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve comments on empty lines'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
}
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
public function testWhetherCommentsOnPropertyLinesArePreserved()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
2015-08-05 14:21:46 +02:00
|
|
|
[blarg]
|
|
|
|
foo = "1337" ; I know what a " and a ' is
|
|
|
|
bar = "7331" ; I; tend; to; overact; !1!1!!11!111! ;
|
|
|
|
key = "value" ; some comment for a small sized property
|
|
|
|
xxl = "very loooooooooooooooooooooong" ; my value is very lo...
|
2014-04-23 13:48:43 +02:00
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2014-10-31 10:54:53 +01:00
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array('blarg' => array(
|
|
|
|
'foo' => 1337,
|
|
|
|
'bar' => 7331,
|
|
|
|
'key' => 'value',
|
|
|
|
'xxl' => 'very loooooooooooooooooooooong'
|
|
|
|
))
|
|
|
|
),
|
|
|
|
$target
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
$this->assertEquals(
|
2015-06-01 16:46:52 +02:00
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve comments on property lines'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
}
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
public function testWhetherCommentsOnEmptySectionLinesArePreserved()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
[section]
|
|
|
|
; some interesting comment, in a section
|
2015-08-05 14:21:46 +02:00
|
|
|
key = "value"
|
2014-04-23 13:48:43 +02:00
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2015-08-05 14:21:46 +02:00
|
|
|
$writer = new IniWriter(Config::fromArray(array('section' => array('key' => 'value'))), $target);
|
2013-08-06 16:28:26 +02:00
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
$this->assertEquals(
|
2015-06-01 16:46:52 +02:00
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve comments on empty section lines'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
2013-08-06 16:28:26 +02:00
|
|
|
}
|
|
|
|
|
2014-04-23 13:48:43 +02:00
|
|
|
public function testWhetherCommentsOnSectionPropertyLinesArePreserved()
|
2013-08-06 16:28:26 +02:00
|
|
|
{
|
2014-04-23 13:48:43 +02:00
|
|
|
$config = <<<'EOD'
|
|
|
|
[section]
|
2015-08-05 14:21:46 +02:00
|
|
|
foo = "1337" ; I know what a " and a ' is
|
|
|
|
bar = "7331" ; I; tend; to; overact; !1!1!!11!111! ;
|
|
|
|
key = "value" ; some comment for a small sized property
|
|
|
|
xxl = "very loooooooooooooooooooooong" ; my value is very lo...
|
2014-04-23 13:48:43 +02:00
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
2014-10-31 10:54:53 +01:00
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'section' => array(
|
|
|
|
'foo' => 1337,
|
|
|
|
'bar' => 7331,
|
|
|
|
'key' => 'value',
|
|
|
|
'xxl' => 'very loooooooooooooooooooooong'
|
2014-04-23 13:48:43 +02:00
|
|
|
)
|
2015-08-05 14:21:46 +02:00
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
2015-06-01 16:46:52 +02:00
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
2014-10-31 10:54:53 +01:00
|
|
|
'IniWriter does not preserve comments on property lines'
|
2014-04-23 13:48:43 +02:00
|
|
|
);
|
2013-08-06 16:28:26 +02:00
|
|
|
}
|
|
|
|
|
2015-08-10 14:49:27 +02:00
|
|
|
public function testWhetherLinebreaksAreProcessed()
|
2015-06-08 13:10:21 +02:00
|
|
|
{
|
|
|
|
$target = $this->writeConfigToTemporaryFile('');
|
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'section' => array(
|
|
|
|
'foo' => 'linebreak
|
2015-06-08 13:10:21 +02:00
|
|
|
in line',
|
2015-08-05 14:21:46 +02:00
|
|
|
'linebreak
|
2015-06-08 13:10:21 +02:00
|
|
|
inkey' => 'blarg'
|
|
|
|
)
|
2015-08-05 14:21:46 +02:00
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
2015-06-08 13:10:21 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
$rendered = $writer->render();
|
|
|
|
$this->assertEquals(
|
|
|
|
count(explode("\n", $rendered)),
|
2015-08-10 14:49:27 +02:00
|
|
|
5,
|
2015-06-08 13:10:21 +02:00
|
|
|
'generated config should not contain more than three line breaks'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-08-04 13:14:46 +02:00
|
|
|
public function testSectionNameEscaping()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
2015-08-07 12:55:19 +02:00
|
|
|
[section [brackets\]]
|
|
|
|
foo = "bar"
|
|
|
|
|
|
|
|
[section \;comment]
|
|
|
|
foo = "bar"
|
2015-08-04 13:14:46 +02:00
|
|
|
|
2015-08-07 12:55:19 +02:00
|
|
|
[section \"quotes\"]
|
|
|
|
foo = "bar"
|
2015-08-04 13:14:46 +02:00
|
|
|
|
2015-08-07 12:55:19 +02:00
|
|
|
[section with \\]
|
|
|
|
foo = "bar"
|
2015-08-04 13:14:46 +02:00
|
|
|
|
2015-08-07 12:55:19 +02:00
|
|
|
[section with newline]
|
2015-08-05 14:21:46 +02:00
|
|
|
foo = "bar"
|
2015-08-04 13:14:46 +02:00
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
|
|
|
$writer = new IniWriter(
|
2015-08-05 14:21:46 +02:00
|
|
|
Config::fromArray(
|
|
|
|
array(
|
2015-08-07 12:55:19 +02:00
|
|
|
'section [brackets]' => array('foo' => 'bar'),
|
|
|
|
'section ;comment' => array('foo' => 'bar'),
|
|
|
|
'section "quotes"' => array('foo' => 'bar'),
|
|
|
|
'section with \\' => array('foo' => 'bar'),
|
|
|
|
'section with' . PHP_EOL . 'newline' => array('foo' => 'bar')
|
2015-08-05 14:21:46 +02:00
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
2015-08-04 13:14:46 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
|
|
|
'IniWriter does not handle special chars in section names properly.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-08-07 12:55:19 +02:00
|
|
|
public function testDirectiveValueEscaping()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
[section]
|
|
|
|
key1 = "value with \"quotes\""
|
|
|
|
key2 = "value with \\"
|
|
|
|
|
|
|
|
EOD;
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
|
|
|
$writer = new IniWriter(
|
|
|
|
Config::fromArray(
|
|
|
|
array(
|
|
|
|
'section' => array(
|
|
|
|
'key1' => 'value with "quotes"',
|
2015-08-10 14:49:27 +02:00
|
|
|
'key2' => 'value with \\'
|
2015-08-07 12:55:19 +02:00
|
|
|
)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
$target
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
trim($config),
|
|
|
|
trim($writer->render()),
|
|
|
|
'IniWriter does not handle special chars in directives properly.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-08-05 14:21:46 +02:00
|
|
|
public function testSectionDeleted()
|
|
|
|
{
|
|
|
|
$config = <<<'EOD'
|
|
|
|
[section 1]
|
|
|
|
guarg = "1"
|
|
|
|
|
|
|
|
[section 2]
|
|
|
|
foo = "1337"
|
|
|
|
foo2 = "baz"
|
|
|
|
foo3 = "nope"
|
|
|
|
foo4 = "bar"
|
|
|
|
|
|
|
|
[section 3]
|
|
|
|
guard = "2"
|
|
|
|
EOD;
|
|
|
|
$deleted = <<<'EOD'
|
|
|
|
[section 1]
|
|
|
|
guarg = "1"
|
|
|
|
|
|
|
|
[section 3]
|
|
|
|
guard = "2"
|
|
|
|
EOD;
|
|
|
|
|
|
|
|
$target = $this->writeConfigToTemporaryFile($config);
|
|
|
|
$writer = new IniWriter(
|
|
|
|
Config::fromArray(array(
|
|
|
|
'section 1' => array('guarg' => 1),
|
|
|
|
'section 3' => array('guard' => 2)
|
|
|
|
)),
|
|
|
|
$target
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
trim($deleted),
|
|
|
|
trim($writer->render()),
|
|
|
|
'IniWriter does not delete sections properly'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2013-08-06 16:28:26 +02:00
|
|
|
/**
|
2015-03-08 14:39:53 +01:00
|
|
|
* Write a INI-configuration string to a temporary file and return its path
|
2014-04-23 13:48:43 +02:00
|
|
|
*
|
|
|
|
* @param string $config The config string to write
|
|
|
|
*
|
|
|
|
* @return string The path to the temporary file
|
2013-08-06 16:28:26 +02:00
|
|
|
*/
|
2014-04-23 13:48:43 +02:00
|
|
|
protected function writeConfigToTemporaryFile($config)
|
2013-08-06 16:28:26 +02:00
|
|
|
{
|
2014-04-23 13:48:43 +02:00
|
|
|
file_put_contents($this->tempFile, $config);
|
|
|
|
return $this->tempFile;
|
2013-08-06 16:28:26 +02:00
|
|
|
}
|
|
|
|
}
|