3 class MWDebugTest
extends MediaWikiTestCase
{
5 protected function setUp() {
7 // Make sure MWDebug class is enabled
8 static $MWDebugEnabled = false;
9 if ( !$MWDebugEnabled ) {
11 $MWDebugEnabled = true;
13 /** Clear log before each test */
15 MediaWiki\
suppressWarnings();
18 protected function tearDown() {
19 MediaWiki\restoreWarnings
();
24 * @covers MWDebug::log
26 public function testAddLog() {
27 MWDebug
::log( 'logging a string' );
30 'msg' => 'logging a string',
32 'caller' => 'MWDebugTest->testAddLog',
39 * @covers MWDebug::warning
41 public function testAddWarning() {
42 MWDebug
::warning( 'Warning message' );
45 'msg' => 'Warning message',
47 'caller' => 'MWDebugTest::testAddWarning',
54 * @covers MWDebug::deprecated
56 public function testAvoidDuplicateDeprecations() {
57 MWDebug
::deprecated( 'wfOldFunction', '1.0', 'component' );
58 MWDebug
::deprecated( 'wfOldFunction', '1.0', 'component' );
60 // assertCount() not available on WMF integration server
61 $this->assertEquals( 1,
62 count( MWDebug
::getLog() ),
63 "Only one deprecated warning per function should be kept"
68 * @covers MWDebug::deprecated
70 public function testAvoidNonConsecutivesDuplicateDeprecations() {
71 MWDebug
::deprecated( 'wfOldFunction', '1.0', 'component' );
72 MWDebug
::warning( 'some warning' );
73 MWDebug
::log( 'we could have logged something too' );
74 // Another deprecation
75 MWDebug
::deprecated( 'wfOldFunction', '1.0', 'component' );
77 // assertCount() not available on WMF integration server
78 $this->assertEquals( 3,
79 count( MWDebug
::getLog() ),
80 "Only one deprecated warning per function should be kept"
85 * @covers MWDebug::appendDebugInfoToApiResult
87 public function testAppendDebugInfoToApiResultXmlFormat() {
88 $request = $this->newApiRequest(
89 array( 'action' => 'help', 'format' => 'xml' ),
90 '/api.php?action=help&format=xml'
93 $context = new RequestContext();
94 $context->setRequest( $request );
96 $apiMain = new ApiMain( $context );
98 $result = new ApiResult( $apiMain );
100 MWDebug
::appendDebugInfoToApiResult( $context, $result );
102 $this->assertInstanceOf( 'ApiResult', $result );
103 $data = $result->getResultData();
105 $expectedKeys = array( 'mwVersion', 'phpEngine', 'phpVersion', 'gitRevision', 'gitBranch',
106 'gitViewUrl', 'time', 'log', 'debugLog', 'queries', 'request', 'memory',
107 'memoryPeak', 'includes', '_element' );
109 foreach ( $expectedKeys as $expectedKey ) {
110 $this->assertArrayHasKey( $expectedKey, $data['debuginfo'], "debuginfo has $expectedKey" );
113 $xml = ApiFormatXml
::recXmlPrint( 'help', $data );
115 // exception not thrown
116 $this->assertInternalType( 'string', $xml );
120 * @param string[] $params
121 * @param string $requestUrl
123 * @return FauxRequest
125 private function newApiRequest( array $params, $requestUrl ) {
126 $request = $this->getMockBuilder( 'FauxRequest' )
127 ->setMethods( array( 'getRequestURL' ) )
128 ->setConstructorArgs( array(
133 $request->expects( $this->any() )
134 ->method( 'getRequestURL' )
135 ->will( $this->returnValue( $requestUrl ) );