icingaweb2/test/php/library/Icinga/Application/ConfigTest.php

285 lines
8.5 KiB
PHP

<?php
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
namespace Tests\Icinga\Application;
use Icinga\Test\BaseTestCase;
use Icinga\Application\Config;
class ConfigTest extends BaseTestCase
{
/**
* Set up config dir
*/
public function setUp(): void
{
parent::setUp();
$this->oldConfigDir = Config::$configDir;
Config::$configDir = dirname(__FILE__) . '/ConfigTest/files';
}
/**
* Reset config dir
*/
public function tearDown(): void
{
parent::tearDown();
Config::$configDir = $this->oldConfigDir;
}
public function testWhetherConfigIsCountable()
{
$config = Config::fromArray(array('a' => 'b', 'c' => array('d' => 'e')));
$this->assertInstanceOf('Countable', $config, 'Config does not implement interface `Countable\'');
$this->assertEquals(2, count($config), 'Config does not count sections correctly');
}
public function testWhetherConfigIsTraversable()
{
$config = Config::fromArray(array('a' => array(), 'c' => array()));
$config->setSection('e');
$this->assertInstanceOf('Iterator', $config, 'Config does not implement interface `Iterator\'');
$actual = array();
foreach ($config as $key => $_) {
$actual[] = $key;
}
$this->assertEquals(
array('a', 'c', 'e'),
$actual,
'Config does not iterate properly in the order its sections were inserted'
);
}
public function testWhetherOneCanCheckIfAConfigHasAnySections()
{
$config = new Config();
$this->assertTrue($config->isEmpty(), 'Config does not report that it is empty');
$config->setSection('test');
$this->assertFalse($config->isEmpty(), 'Config does report that it is empty although it is not');
}
public function testWhetherItIsPossibleToRetrieveAllSectionNames()
{
$config = Config::fromArray(array('a' => array('b' => 'c'), 'd' => array('e' => 'f')));
$this->assertEquals(
array('a', 'd'),
$config->keys(),
'Config::keys does not list section names correctly'
);
}
public function testWhetherConfigCanBeConvertedToAnArray()
{
$config = Config::fromArray(array('a' => 'b', 'c' => array('d' => 'e')));
$this->assertEquals(
array('a' => 'b', 'c' => array('d' => 'e')),
$config->toArray(),
'Config::toArray does not return the correct array'
);
}
public function testWhetherItIsPossibleToDirectlyRetrieveASectionProperty()
{
$config = Config::fromArray(array('a' => array('b' => 'c')));
$this->assertEquals(
'c',
$config->get('a', 'b'),
'Config::get does not return the actual value of a section\'s property'
);
$this->assertNull(
$config->get('a', 'c'),
'Config::get does not return NULL as default for non-existent section properties'
);
$this->assertNull(
$config->get('b', 'c'),
'Config::get does not return NULL as default for non-existent sections'
);
$this->assertEquals(
'test',
$config->get('a', 'c', 'test'),
'Config::get does not return the given default value for non-existent section properties'
);
$this->assertEquals(
'c',
$config->get('a', 'b', 'test'),
'Config::get does not return the actual value of a section\'s property in case a default is given'
);
}
public function testWhetherConfigReturnsSingleSections()
{
$config = Config::fromArray(array('a' => array('b' => 'c')));
$this->assertInstanceOf(
'Icinga\Data\ConfigObject',
$config->getSection('a'),
'Config::getSection does not return a known section'
);
}
/**
* @depends testWhetherConfigReturnsSingleSections
*/
public function testWhetherConfigSetsSingleSections()
{
$config = new Config();
$config->setSection('a', array('b' => 'c'));
$this->assertInstanceOf(
'Icinga\Data\ConfigObject',
$config->getSection('a'),
'Config::setSection does not set a new section'
);
$config->setSection('a', array('bb' => 'cc'));
$this->assertNull(
$config->getSection('a')->b,
'Config::setSection does not overwrite existing sections'
);
$this->assertEquals(
'cc',
$config->getSection('a')->bb,
'Config::setSection does not overwrite existing sections'
);
}
/**
* @depends testWhetherConfigIsCountable
*/
public function testWhetherConfigRemovesSingleSections()
{
$config = Config::fromArray(array('a' => array('b' => 'c'), 'd' => array('e' => 'f')));
$config->removeSection('a');
$this->assertEquals(
1,
$config->count(),
'Config::removeSection does not remove a known section'
);
}
/**
* @depends testWhetherConfigSetsSingleSections
*/
public function testWhetherConfigKnowsWhichSectionsItHas()
{
$config = new Config();
$config->setSection('a');
$this->assertTrue(
$config->hasSection('a'),
'Config::hasSection does not know anything about its sections'
);
$this->assertFalse(
$config->hasSection('b'),
'Config::hasSection does not know anything about its sections'
);
}
public function testWhetherAnExceptionIsThrownWhenTryingToAccessASectionPropertyOnANonSection()
{
$this->expectException(\UnexpectedValueException::class);
$config = Config::fromArray(array('a' => 'b'));
$config->get('a', 'b');
}
public function testWhetherConfigResolvePathReturnsValidAbsolutePaths()
{
$this->assertEquals(
Config::$configDir . DIRECTORY_SEPARATOR . 'a' . DIRECTORY_SEPARATOR . 'b.ini',
Config::resolvePath(DIRECTORY_SEPARATOR . 'a' . DIRECTORY_SEPARATOR . 'b.ini'),
'Config::resolvePath does not produce valid absolute paths'
);
}
/**
* @depends testWhetherConfigCanBeConvertedToAnArray
* @depends testWhetherConfigResolvePathReturnsValidAbsolutePaths
*/
public function testWhetherItIsPossibleToInitializeAConfigFromAIniFile()
{
$config = Config::fromIni(Config::resolvePath('config.ini'));
$this->assertEquals(
array(
'logging' => array(
'enable' => 1
),
'backend' => array(
'type' => 'db',
'user' => 'user',
'password' => 'password',
'disable' => 1
)
),
$config->toArray(),
'Config::fromIni does not load INI files correctly'
);
$this->assertInstanceOf(
get_class($config),
Config::fromIni('nichda'),
'Config::fromIni does not return empty configs for non-existent configuration files'
);
}
public function testWhetherFromIniThrowsAnExceptionOnInsufficientPermission()
{
$this->expectException(\Icinga\Exception\NotReadableError::class);
Config::fromIni('/etc/shadow');
}
/**
* @depends testWhetherItIsPossibleToInitializeAConfigFromAIniFile
*/
public function testWhetherItIsPossibleToRetrieveApplicationConfiguration()
{
$config = Config::app();
$this->assertEquals(
array(
'logging' => array(
'enable' => 1
),
'backend' => array(
'type' => 'db',
'user' => 'user',
'password' => 'password',
'disable' => 1
)
),
$config->toArray(),
'Config::app does not load INI files correctly'
);
}
/**
* @depends testWhetherItIsPossibleToInitializeAConfigFromAIniFile
*/
public function testWhetherItIsPossibleToRetrieveModuleConfiguration()
{
$config = Config::module('amodule');
$this->assertEquals(
array(
'menu' => array(
'breadcrumb' => 1
)
),
$config->toArray(),
'Config::module does not load INI files correctly'
);
}
}