2016-02-28 13:25:49 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Tests\Icinga\Module\Director\IcingaConfig;
|
|
|
|
|
|
|
|
use Icinga\Module\Director\IcingaConfig\IcingaConfigHelper as c;
|
|
|
|
use Icinga\Module\Director\Test\BaseTestCase;
|
|
|
|
|
|
|
|
class IcingaConfigHelperTest extends BaseTestCase
|
|
|
|
{
|
|
|
|
public function testWhetherIntervalStringIsCorrectlyParsed()
|
|
|
|
{
|
2016-02-28 16:25:15 +01:00
|
|
|
$this->assertEquals(c::parseInterval('0'), 0);
|
|
|
|
$this->assertEquals(c::parseInterval('0s'), 0);
|
2016-02-28 13:25:49 +01:00
|
|
|
$this->assertEquals(c::parseInterval('10'), 10);
|
|
|
|
$this->assertEquals(c::parseInterval('70s'), 70);
|
|
|
|
$this->assertEquals(c::parseInterval('5m 10s'), 310);
|
|
|
|
$this->assertEquals(c::parseInterval('5m 60s'), 360);
|
|
|
|
$this->assertEquals(c::parseInterval('1h 5m 60s'), 3960);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @expectedException \Icinga\Exception\ProgrammingError
|
|
|
|
*/
|
|
|
|
public function testWhetherInvalidIntervalStringRaisesException()
|
|
|
|
{
|
|
|
|
c::parseInterval('1h 5m 60x');
|
|
|
|
}
|
|
|
|
|
2016-02-28 16:25:15 +01:00
|
|
|
public function testWhetherAnEmptyValueGivesNull()
|
|
|
|
{
|
|
|
|
$this->assertNull(c::parseInterval(''));
|
|
|
|
$this->assertNull(c::parseInterval(null));
|
|
|
|
}
|
|
|
|
|
2016-02-28 13:25:49 +01:00
|
|
|
public function testWhetherIntervalStringIsCorrectlyRendered()
|
|
|
|
{
|
|
|
|
$this->assertEquals(c::renderInterval(10), '10s');
|
|
|
|
$this->assertEquals(c::renderInterval(60), '1m');
|
2016-02-28 13:55:16 +01:00
|
|
|
$this->assertEquals(c::renderInterval(121), '121s');
|
|
|
|
$this->assertEquals(c::renderInterval(3600), '1h');
|
2016-02-28 13:25:49 +01:00
|
|
|
$this->assertEquals(c::renderInterval(86400), '1d');
|
2016-02-28 13:55:16 +01:00
|
|
|
$this->assertEquals(c::renderInterval(86459), '86459s');
|
2016-02-28 13:25:49 +01:00
|
|
|
}
|
2016-08-30 14:15:48 +02:00
|
|
|
|
|
|
|
public function testCorrectlyIdentifiesReservedWords()
|
|
|
|
{
|
|
|
|
$this->assertTrue(c::isReserved('include'), 'include is a reserved word');
|
|
|
|
$this->assertFalse(c::isReserved(0), '(int) 0 is not a reserved word');
|
|
|
|
$this->assertFalse(c::isReserved(1), '(int) 1 is not a reserved word');
|
|
|
|
$this->assertFalse(c::isReserved(true), '(boolean) true is not a reserved word');
|
|
|
|
$this->assertTrue(c::isReserved('true'), '(string) true is a reserved word');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testWhetherDictionaryRendersCorrectly()
|
|
|
|
{
|
|
|
|
$dict = (object) array(
|
|
|
|
'key1' => 'bla',
|
|
|
|
'include' => 'reserved',
|
|
|
|
'spe cial' => 'value',
|
|
|
|
'0' => 'numeric',
|
|
|
|
);
|
|
|
|
$this->assertEquals(
|
|
|
|
c::renderDictionary($dict),
|
|
|
|
rtrim($this->loadRendered('dict1'))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function loadRendered($name)
|
|
|
|
{
|
|
|
|
return file_get_contents(__DIR__ . '/rendered/' . $name . '.out');
|
|
|
|
}
|
2016-07-29 21:58:15 +02:00
|
|
|
|
|
|
|
public function testRenderStringIsCorrectlyRendered()
|
|
|
|
{
|
|
|
|
$this->assertEquals(c::renderString('val1\\\val2'), '"val1\\\\\\\\val2"');
|
|
|
|
$this->assertEquals(c::renderString('"val1"'), '"\"val1\""');
|
|
|
|
$this->assertEquals(c::renderString('\$val\$'), '"\\\\$val\\\\$"');
|
|
|
|
$this->assertEquals(c::renderString('\t'), '"\\\\t"');
|
|
|
|
$this->assertEquals(c::renderString('\r'), '"\\\\r"');
|
|
|
|
$this->assertEquals(c::renderString('\n'), '"\\\\n"');
|
|
|
|
$this->assertEquals(c::renderString('\f'), '"\\\\f"');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRenderStringWithVariables()
|
|
|
|
{
|
2016-10-22 07:48:09 +02:00
|
|
|
$this->assertEquals(c::renderStringWithVariables('Before $var$'), '"Before " + var');
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('$var$ After'), 'var + " After"');
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('$var$'), 'var');
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('$$var$$'), '"$$var$$"');
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('Before $$var$$ After'), '"Before $$var$$ After"');
|
2016-07-29 21:58:15 +02:00
|
|
|
$this->assertEquals(
|
2016-10-22 07:48:09 +02:00
|
|
|
c::renderStringWithVariables('Before $name$ $name$ After'),
|
|
|
|
'"Before " + name + " " + name + " After"'
|
|
|
|
);
|
2016-07-29 21:58:15 +02:00
|
|
|
$this->assertEquals(
|
2016-10-22 07:48:09 +02:00
|
|
|
c::renderStringWithVariables('Before $var1$ $var2$ After'),
|
|
|
|
'"Before " + var1 + " " + var2 + " After"'
|
|
|
|
);
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('$host.vars.custom$'), 'host.vars.custom');
|
|
|
|
$this->assertEquals(c::renderStringWithVariables('$var"$'), '"$var\"$"');
|
2016-07-29 21:58:15 +02:00
|
|
|
$this->assertEquals(
|
2016-10-22 07:48:09 +02:00
|
|
|
c::renderStringWithVariables('\tI am\rrendering\nproperly\fand I $support$ "multiple" $variables$\$'),
|
|
|
|
'"\\\\tI am\\\\rrendering\\\\nproperly\\\\fand I " + support + " \"multiple\" " + variables + "\\\\$"'
|
|
|
|
);
|
2016-07-29 21:58:15 +02:00
|
|
|
}
|
2016-02-28 13:25:49 +01:00
|
|
|
}
|