wiki.techinc.nl/tests/phpunit/unit/includes/config/MultiConfigTest.php
Max Semenik 0f9cc78aba Cleanup of old PHPUnit usage, part 2
Bug: T192167
Bug: T234597
Change-Id: Ifec7f02f64d6613dbfa1878007f68c2e411a83dc
2019-10-04 21:47:46 -07:00

40 lines
1.1 KiB
PHP

<?php
class MultiConfigTest extends \MediaWikiUnitTestCase {
/**
* Tests that settings are fetched in the right order
*
* @covers MultiConfig::__construct
* @covers MultiConfig::get
*/
public function testGet() {
$multi = new MultiConfig( [
new HashConfig( [ 'foo' => 'bar' ] ),
new HashConfig( [ 'foo' => 'baz', 'bar' => 'foo' ] ),
new HashConfig( [ 'bar' => 'baz' ] ),
] );
$this->assertEquals( 'bar', $multi->get( 'foo' ) );
$this->assertEquals( 'foo', $multi->get( 'bar' ) );
$this->expectException( ConfigException::class );
$this->expectExceptionMessage( 'MultiConfig::get: undefined option:' );
$multi->get( 'notset' );
}
/**
* @covers MultiConfig::has
*/
public function testHas() {
$conf = new MultiConfig( [
new HashConfig( [ 'foo' => 'foo' ] ),
new HashConfig( [ 'something' => 'bleh' ] ),
new HashConfig( [ 'meh' => 'eh' ] ),
] );
$this->assertTrue( $conf->has( 'foo' ) );
$this->assertTrue( $conf->has( 'something' ) );
$this->assertTrue( $conf->has( 'meh' ) );
$this->assertFalse( $conf->has( 'what' ) );
}
}