mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-23 00:14:07 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			287 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			287 lines
		
	
	
		
			8.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* Icinga Web 2 | (c) 2013-2015 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()
 | |
|     {
 | |
|         parent::setUp();
 | |
|         $this->oldConfigDir = Config::$configDir;
 | |
|         Config::$configDir = dirname(__FILE__) . '/ConfigTest/files';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Reset config dir
 | |
|      */
 | |
|     public function tearDown()
 | |
|     {
 | |
|         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'
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException UnexpectedValueException
 | |
|      */
 | |
|     public function testWhetherAnExceptionIsThrownWhenTryingToAccessASectionPropertyOnANonSection()
 | |
|     {
 | |
|         $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'
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Icinga\Exception\NotReadableError
 | |
|      */
 | |
|     public function testWhetherFromIniThrowsAnExceptionOnInsufficientPermission()
 | |
|     {
 | |
|         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'
 | |
|         );
 | |
|     }
 | |
| }
 |