2 use MediaWiki\Logger\LoggerFactory
;
3 use MediaWiki\MediaWikiServices
;
4 use Psr\Log\LoggerInterface
;
5 use Wikimedia\Rdbms\LoadBalancer
;
8 * @covers MediaWikiTestCase
9 * @group MediaWikiTestCaseTest
13 class MediaWikiTestCaseTest
extends MediaWikiTestCase
{
15 private static $startGlobals = [
16 'MediaWikiTestCaseTestGLOBAL-ExistingString' => 'foo',
17 'MediaWikiTestCaseTestGLOBAL-ExistingStringEmpty' => '',
18 'MediaWikiTestCaseTestGLOBAL-ExistingArray' => [ 1, 'foo' => 'bar' ],
19 'MediaWikiTestCaseTestGLOBAL-ExistingArrayEmpty' => [],
22 public static function setUpBeforeClass() {
23 parent
::setUpBeforeClass();
24 foreach ( self
::$startGlobals as $key => $value ) {
25 $GLOBALS[$key] = $value;
29 public static function tearDownAfterClass() {
30 parent
::tearDownAfterClass();
31 foreach ( self
::$startGlobals as $key => $value ) {
32 unset( $GLOBALS[$key] );
36 public function provideExistingKeysAndNewValues() {
38 foreach ( array_keys( self
::$startGlobals ) as $key ) {
39 $providedArray[] = [ $key, 'newValue' ];
40 $providedArray[] = [ $key, [ 'newValue' ] ];
42 return $providedArray;
46 * @dataProvider provideExistingKeysAndNewValues
48 * @covers MediaWikiTestCase::setMwGlobals
49 * @covers MediaWikiTestCase::tearDown
51 public function testSetGlobalsAreRestoredOnTearDown( $globalKey, $newValue ) {
52 $this->setMwGlobals( $globalKey, $newValue );
56 'Global failed to correctly set'
62 self
::$startGlobals[$globalKey],
64 'Global failed to be restored on tearDown'
69 * @dataProvider provideExistingKeysAndNewValues
71 * @covers MediaWikiTestCase::stashMwGlobals
72 * @covers MediaWikiTestCase::tearDown
74 public function testStashedGlobalsAreRestoredOnTearDown( $globalKey, $newValue ) {
75 $this->hideDeprecated( 'MediaWikiTestCase::stashMwGlobals' );
76 $this->stashMwGlobals( $globalKey );
77 $GLOBALS[$globalKey] = $newValue;
81 'Global failed to correctly set'
87 self
::$startGlobals[$globalKey],
89 'Global failed to be restored on tearDown'
94 * @covers MediaWikiTestCase::stashMwGlobals
95 * @covers MediaWikiTestCase::tearDown
97 public function testSetNonExistentGlobalsAreUnsetOnTearDown() {
98 $globalKey = 'abcdefg1234567';
99 $this->setMwGlobals( $globalKey, true );
101 $GLOBALS[$globalKey],
102 'Global failed to correctly set'
108 isset( $GLOBALS[$globalKey] ),
109 'Global failed to be correctly unset'
113 public function testOverrideMwServices() {
114 $initialServices = MediaWikiServices
::getInstance();
116 $this->overrideMwServices();
117 $this->assertNotSame( $initialServices, MediaWikiServices
::getInstance() );
120 public function testSetService() {
121 $initialServices = MediaWikiServices
::getInstance();
122 $initialService = $initialServices->getDBLoadBalancer();
123 $mockService = $this->getMockBuilder( LoadBalancer
::class )
124 ->disableOriginalConstructor()->getMock();
126 $this->setService( 'DBLoadBalancer', $mockService );
127 $this->assertNotSame(
129 MediaWikiServices
::getInstance()->getDBLoadBalancer()
131 $this->assertSame( $mockService, MediaWikiServices
::getInstance()->getDBLoadBalancer() );
135 * @covers MediaWikiTestCase::setLogger
136 * @covers MediaWikiTestCase::restoreLoggers
138 public function testLoggersAreRestoredOnTearDown_replacingExistingLogger() {
139 $logger1 = LoggerFactory
::getInstance( 'foo' );
140 $this->setLogger( 'foo', $this->createMock( LoggerInterface
::class ) );
141 $logger2 = LoggerFactory
::getInstance( 'foo' );
143 $logger3 = LoggerFactory
::getInstance( 'foo' );
145 $this->assertSame( $logger1, $logger3 );
146 $this->assertNotSame( $logger1, $logger2 );
150 * @covers MediaWikiTestCase::setLogger
151 * @covers MediaWikiTestCase::restoreLoggers
153 public function testLoggersAreRestoredOnTearDown_replacingNonExistingLogger() {
154 $this->setLogger( 'foo', $this->createMock( LoggerInterface
::class ) );
155 $logger1 = LoggerFactory
::getInstance( 'foo' );
157 $logger2 = LoggerFactory
::getInstance( 'foo' );
159 $this->assertNotSame( $logger1, $logger2 );
160 $this->assertInstanceOf( \Psr\Log\LoggerInterface
::class, $logger2 );
164 * @covers MediaWikiTestCase::setLogger
165 * @covers MediaWikiTestCase::restoreLoggers
167 public function testLoggersAreRestoredOnTearDown_replacingSameLoggerTwice() {
168 $logger1 = LoggerFactory
::getInstance( 'baz' );
169 $this->setLogger( 'foo', $this->createMock( LoggerInterface
::class ) );
170 $this->setLogger( 'foo', $this->createMock( LoggerInterface
::class ) );
172 $logger2 = LoggerFactory
::getInstance( 'baz' );
174 $this->assertSame( $logger1, $logger2 );