MediaWiki REL1_31
LegacyLoggerTest.php
Go to the documentation of this file.
1<?php
21namespace MediaWiki\Logger;
22
24use Psr\Log\LogLevel;
25
27
32 public function testInterpolate( $message, $context, $expect ) {
33 $this->assertEquals(
34 $expect, LegacyLogger::interpolate( $message, $context ) );
35 }
36
37 public function provideInterpolate() {
38 $e = new \Exception( 'boom!' );
39 $d = new \DateTime();
40 return [
41 [
42 'no-op',
43 [],
44 'no-op',
45 ],
46 [
47 'Hello {world}!',
48 [
49 'world' => 'World',
50 ],
51 'Hello World!',
52 ],
53 [
54 '{greeting} {user}',
55 [
56 'greeting' => 'Goodnight',
57 'user' => 'Moon',
58 ],
59 'Goodnight Moon',
60 ],
61 [
62 'Oops {key_not_set}',
63 [],
64 'Oops {key_not_set}',
65 ],
66 [
67 '{ not interpolated }',
68 [
69 'not interpolated' => 'This should NOT show up in the message',
70 ],
71 '{ not interpolated }',
72 ],
73 [
74 '{null}',
75 [
76 'null' => null,
77 ],
78 '[Null]',
79 ],
80 [
81 '{bool}',
82 [
83 'bool' => true,
84 ],
85 'true',
86 ],
87 [
88 '{float}',
89 [
90 'float' => 1.23,
91 ],
92 '1.23',
93 ],
94 [
95 '{array}',
96 [
97 'array' => [ 1, 2, 3 ],
98 ],
99 '[Array(3)]',
100 ],
101 [
102 '{exception}',
103 [
104 'exception' => $e,
105 ],
106 '[Exception ' . get_class( $e ) . '( ' .
107 $e->getFile() . ':' . $e->getLine() . ') ' .
108 $e->getMessage() . ']',
109 ],
110 [
111 '{datetime}',
112 [
113 'datetime' => $d,
114 ],
115 $d->format( 'c' ),
116 ],
117 [
118 '{object}',
119 [
120 'object' => new \stdClass,
121 ],
122 '[Object stdClass]',
123 ],
124 ];
125 }
126
131 public function testShouldEmit( $level, $config, $expected ) {
132 $this->setMwGlobals( 'wgDebugLogGroups', [ 'fakechannel' => $config ] );
133 $this->assertEquals(
134 $expected,
135 LegacyLogger::shouldEmit( 'fakechannel', 'some message', $level, [] )
136 );
137 }
138
139 public static function provideShouldEmit() {
140 $dest = [ 'destination' => 'foobar' ];
141 $tests = [
142 [
143 LogLevel::DEBUG,
144 $dest,
145 true
146 ],
147 [
148 LogLevel::WARNING,
149 $dest + [ 'level' => LogLevel::INFO ],
150 true,
151 ],
152 [
153 LogLevel::INFO,
154 $dest + [ 'level' => LogLevel::CRITICAL ],
155 false,
156 ],
157 ];
158
159 if ( class_exists( '\Monolog\Logger' ) ) {
160 $tests[] = [
161 \Monolog\Logger::INFO,
162 $dest + [ 'level' => LogLevel::INFO ],
163 true,
164 ];
165 $tests[] = [
166 \Monolog\Logger::WARNING,
167 $dest + [ 'level' => LogLevel::EMERGENCY ],
168 false,
169 ];
170 }
171
172 return $tests;
173 }
174
175}
setMwGlobals( $pairs, $value=null)
Sets a global, maintaining a stashed version of the previous global to be restored in tearDown.
testShouldEmit( $level, $config, $expected)
MediaWiki\Logger\LegacyLogger::shouldEmit provideShouldEmit.
testInterpolate( $message, $context, $expect)
MediaWiki\Logger\LegacyLogger::interpolate provideInterpolate.
static shouldEmit( $channel, $message, $level, $context)
Determine if the given message should be emitted or not.
static interpolate( $message, array $context)
Interpolate placeholders in logging message.
do that in ParserLimitReportFormat instead use this to modify the parameters of the image all existing parser cache entries will be invalid To avoid you ll need to handle that somehow(e.g. with the RejectParserCacheValue hook) because MediaWiki won 't do it for you. & $defaults also a ContextSource after deleting those rows but within the same transaction you ll probably need to make sure the header is varied on and they can depend only on the ResourceLoaderContext $context
Definition hooks.txt:2811
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return true
Definition hooks.txt:2006
returning false will NOT prevent logging $e
Definition hooks.txt:2176