pictcode / lib / Cake / Test / Case / Log / CakeLogTest.php @ 0b1b8047
履歴 | 表示 | アノテート | ダウンロード (19.993 KB)
1 |
<?php
|
---|---|
2 |
/**
|
3 |
* CakeLogTest file
|
4 |
*
|
5 |
* CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
6 |
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
7 |
*
|
8 |
* Licensed under The MIT License
|
9 |
* For full copyright and license information, please see the LICENSE.txt
|
10 |
* Redistributions of files must retain the above copyright notice
|
11 |
*
|
12 |
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
13 |
* @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
14 |
* @package Cake.Test.Case.Log
|
15 |
* @since CakePHP(tm) v 1.2.0.5432
|
16 |
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
17 |
*/
|
18 |
|
19 |
App::uses('CakeLog', 'Log'); |
20 |
App::uses('FileLog', 'Log/Engine'); |
21 |
|
22 |
/**
|
23 |
* CakeLogTest class
|
24 |
*
|
25 |
* @package Cake.Test.Case.Log
|
26 |
*/
|
27 |
class CakeLogTest extends CakeTestCase { |
28 |
|
29 |
/**
|
30 |
* Start test callback, clears all streams enabled.
|
31 |
*
|
32 |
* @return void
|
33 |
*/
|
34 |
public function setUp() { |
35 |
parent::setUp();
|
36 |
$streams = CakeLog::configured(); |
37 |
foreach ($streams as $stream) { |
38 |
CakeLog::drop($stream); |
39 |
} |
40 |
} |
41 |
|
42 |
/**
|
43 |
* test importing loggers from app/libs and plugins.
|
44 |
*
|
45 |
* @return void
|
46 |
*/
|
47 |
public function testImportingLoggers() { |
48 |
App::build(array( |
49 |
'Lib' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Lib' . DS), |
50 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
51 |
), App::RESET); |
52 |
CakePlugin::load('TestPlugin'); |
53 |
|
54 |
$result = CakeLog::config('libtest', array( |
55 |
'engine' => 'TestAppLog' |
56 |
)); |
57 |
$this->assertTrue($result); |
58 |
$this->assertEquals(CakeLog::configured(), array('libtest')); |
59 |
|
60 |
$result = CakeLog::config('plugintest', array( |
61 |
'engine' => 'TestPlugin.TestPluginLog' |
62 |
)); |
63 |
$this->assertTrue($result); |
64 |
$this->assertEquals(CakeLog::configured(), array('libtest', 'plugintest')); |
65 |
|
66 |
CakeLog::write(LOG_INFO, 'TestPluginLog is not a BaseLog descendant'); |
67 |
|
68 |
App::build();
|
69 |
CakePlugin::unload();
|
70 |
} |
71 |
|
72 |
/**
|
73 |
* test all the errors from failed logger imports
|
74 |
*
|
75 |
* @expectedException CakeLogException
|
76 |
* @return void
|
77 |
*/
|
78 |
public function testImportingLoggerFailure() { |
79 |
CakeLog::config('fail', array()); |
80 |
} |
81 |
|
82 |
/**
|
83 |
* test config() with valid key name
|
84 |
*
|
85 |
* @return void
|
86 |
*/
|
87 |
public function testValidKeyName() { |
88 |
CakeLog::config('valid', array('engine' => 'File')); |
89 |
$stream = CakeLog::stream('valid'); |
90 |
$this->assertInstanceOf('FileLog', $stream); |
91 |
CakeLog::drop('valid'); |
92 |
} |
93 |
|
94 |
/**
|
95 |
* test config() with valid key name including the deprecated Log suffix
|
96 |
*
|
97 |
* @return void
|
98 |
*/
|
99 |
public function testValidKeyNameLogSuffix() { |
100 |
CakeLog::config('valid', array('engine' => 'FileLog')); |
101 |
$stream = CakeLog::stream('valid'); |
102 |
$this->assertInstanceOf('FileLog', $stream); |
103 |
CakeLog::drop('valid'); |
104 |
} |
105 |
|
106 |
/**
|
107 |
* test config() with invalid key name
|
108 |
*
|
109 |
* @expectedException CakeLogException
|
110 |
* @return void
|
111 |
*/
|
112 |
public function testInvalidKeyName() { |
113 |
CakeLog::config('1nv', array('engine' => 'File')); |
114 |
} |
115 |
|
116 |
/**
|
117 |
* test that loggers have to implement the correct interface.
|
118 |
*
|
119 |
* @expectedException CakeLogException
|
120 |
* @return void
|
121 |
*/
|
122 |
public function testNotImplementingInterface() { |
123 |
CakeLog::config('fail', array('engine' => 'stdClass')); |
124 |
} |
125 |
|
126 |
/**
|
127 |
* Test that CakeLog does not auto create logs when no streams are there to listen.
|
128 |
*
|
129 |
* @return void
|
130 |
*/
|
131 |
public function testNoStreamListenting() { |
132 |
if (file_exists(LOGS . 'error.log')) { |
133 |
unlink(LOGS . 'error.log'); |
134 |
} |
135 |
$res = CakeLog::write(LOG_WARNING, 'Test warning'); |
136 |
$this->assertFalse($res); |
137 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
138 |
|
139 |
$result = CakeLog::configured(); |
140 |
$this->assertEquals(array(), $result); |
141 |
} |
142 |
|
143 |
/**
|
144 |
* test configuring log streams
|
145 |
*
|
146 |
* @return void
|
147 |
*/
|
148 |
public function testConfig() { |
149 |
CakeLog::config('file', array( |
150 |
'engine' => 'File', |
151 |
'path' => LOGS |
152 |
)); |
153 |
$result = CakeLog::configured(); |
154 |
$this->assertEquals(array('file'), $result); |
155 |
|
156 |
if (file_exists(LOGS . 'error.log')) { |
157 |
unlink(LOGS . 'error.log'); |
158 |
} |
159 |
CakeLog::write(LOG_WARNING, 'Test warning'); |
160 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
161 |
|
162 |
$result = file_get_contents(LOGS . 'error.log'); |
163 |
$this->assertRegExp('/^2[0-9]{3}-[0-9]+-[0-9]+ [0-9]+:[0-9]+:[0-9]+ Warning: Test warning/', $result); |
164 |
unlink(LOGS . 'error.log'); |
165 |
} |
166 |
|
167 |
/**
|
168 |
* explicit tests for drop()
|
169 |
*
|
170 |
* @return void
|
171 |
*/
|
172 |
public function testDrop() { |
173 |
CakeLog::config('file', array( |
174 |
'engine' => 'File', |
175 |
'path' => LOGS |
176 |
)); |
177 |
$result = CakeLog::configured(); |
178 |
$this->assertEquals(array('file'), $result); |
179 |
|
180 |
CakeLog::drop('file'); |
181 |
$result = CakeLog::configured(); |
182 |
$this->assertSame(array(), $result); |
183 |
} |
184 |
|
185 |
/**
|
186 |
* testLogFileWriting method
|
187 |
*
|
188 |
* @return void
|
189 |
*/
|
190 |
public function testLogFileWriting() { |
191 |
CakeLog::config('file', array( |
192 |
'engine' => 'File', |
193 |
'path' => LOGS |
194 |
)); |
195 |
if (file_exists(LOGS . 'error.log')) { |
196 |
unlink(LOGS . 'error.log'); |
197 |
} |
198 |
$result = CakeLog::write(LOG_WARNING, 'Test warning'); |
199 |
$this->assertTrue($result); |
200 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
201 |
unlink(LOGS . 'error.log'); |
202 |
|
203 |
CakeLog::write(LOG_WARNING, 'Test warning 1'); |
204 |
CakeLog::write(LOG_WARNING, 'Test warning 2'); |
205 |
$result = file_get_contents(LOGS . 'error.log'); |
206 |
$this->assertRegExp('/^2[0-9]{3}-[0-9]+-[0-9]+ [0-9]+:[0-9]+:[0-9]+ Warning: Test warning 1/', $result); |
207 |
$this->assertRegExp('/2[0-9]{3}-[0-9]+-[0-9]+ [0-9]+:[0-9]+:[0-9]+ Warning: Test warning 2$/', $result); |
208 |
unlink(LOGS . 'error.log'); |
209 |
} |
210 |
|
211 |
/**
|
212 |
* test selective logging by level/type
|
213 |
*
|
214 |
* @return void
|
215 |
*/
|
216 |
public function testSelectiveLoggingByLevel() { |
217 |
if (file_exists(LOGS . 'spam.log')) { |
218 |
unlink(LOGS . 'spam.log'); |
219 |
} |
220 |
if (file_exists(LOGS . 'eggs.log')) { |
221 |
unlink(LOGS . 'eggs.log'); |
222 |
} |
223 |
CakeLog::config('spam', array( |
224 |
'engine' => 'File', |
225 |
'types' => 'debug', |
226 |
'file' => 'spam', |
227 |
)); |
228 |
CakeLog::config('eggs', array( |
229 |
'engine' => 'File', |
230 |
'types' => array('eggs', 'debug', 'error', 'warning'), |
231 |
'file' => 'eggs', |
232 |
)); |
233 |
|
234 |
$testMessage = 'selective logging'; |
235 |
CakeLog::write(LOG_WARNING, $testMessage); |
236 |
|
237 |
$this->assertTrue(file_exists(LOGS . 'eggs.log')); |
238 |
$this->assertFalse(file_exists(LOGS . 'spam.log')); |
239 |
|
240 |
CakeLog::write(LOG_DEBUG, $testMessage); |
241 |
$this->assertTrue(file_exists(LOGS . 'spam.log')); |
242 |
|
243 |
$contents = file_get_contents(LOGS . 'spam.log'); |
244 |
$this->assertContains('Debug: ' . $testMessage, $contents); |
245 |
$contents = file_get_contents(LOGS . 'eggs.log'); |
246 |
$this->assertContains('Debug: ' . $testMessage, $contents); |
247 |
|
248 |
if (file_exists(LOGS . 'spam.log')) { |
249 |
unlink(LOGS . 'spam.log'); |
250 |
} |
251 |
if (file_exists(LOGS . 'eggs.log')) { |
252 |
unlink(LOGS . 'eggs.log'); |
253 |
} |
254 |
} |
255 |
|
256 |
/**
|
257 |
* test enable
|
258 |
*
|
259 |
* @expectedException CakeLogException
|
260 |
* @return void
|
261 |
*/
|
262 |
public function testStreamEnable() { |
263 |
CakeLog::config('spam', array( |
264 |
'engine' => 'File', |
265 |
'file' => 'spam', |
266 |
)); |
267 |
$this->assertTrue(CakeLog::enabled('spam')); |
268 |
CakeLog::drop('spam'); |
269 |
CakeLog::enable('bogus_stream'); |
270 |
} |
271 |
|
272 |
/**
|
273 |
* test disable
|
274 |
*
|
275 |
* @expectedException CakeLogException
|
276 |
* @return void
|
277 |
*/
|
278 |
public function testStreamDisable() { |
279 |
CakeLog::config('spam', array( |
280 |
'engine' => 'File', |
281 |
'file' => 'spam', |
282 |
)); |
283 |
$this->assertTrue(CakeLog::enabled('spam')); |
284 |
CakeLog::disable('spam'); |
285 |
$this->assertFalse(CakeLog::enabled('spam')); |
286 |
CakeLog::drop('spam'); |
287 |
CakeLog::enable('bogus_stream'); |
288 |
} |
289 |
|
290 |
/**
|
291 |
* test enabled() invalid stream
|
292 |
*
|
293 |
* @expectedException CakeLogException
|
294 |
* @return void
|
295 |
*/
|
296 |
public function testStreamEnabledInvalid() { |
297 |
CakeLog::enabled('bogus_stream'); |
298 |
} |
299 |
|
300 |
/**
|
301 |
* test disable invalid stream
|
302 |
*
|
303 |
* @expectedException CakeLogException
|
304 |
* @return void
|
305 |
*/
|
306 |
public function testStreamDisableInvalid() { |
307 |
CakeLog::disable('bogus_stream'); |
308 |
} |
309 |
|
310 |
/**
|
311 |
* resets log config
|
312 |
*
|
313 |
* @return void
|
314 |
*/
|
315 |
protected function _resetLogConfig() { |
316 |
CakeLog::config('debug', array( |
317 |
'engine' => 'File', |
318 |
'types' => array('notice', 'info', 'debug'), |
319 |
'file' => 'debug', |
320 |
)); |
321 |
CakeLog::config('error', array( |
322 |
'engine' => 'File', |
323 |
'types' => array('warning', 'error', 'critical', 'alert', 'emergency'), |
324 |
'file' => 'error', |
325 |
)); |
326 |
} |
327 |
|
328 |
/**
|
329 |
* delete logs
|
330 |
*
|
331 |
* @return void
|
332 |
*/
|
333 |
protected function _deleteLogs() { |
334 |
if (file_exists(LOGS . 'shops.log')) { |
335 |
unlink(LOGS . 'shops.log'); |
336 |
} |
337 |
if (file_exists(LOGS . 'error.log')) { |
338 |
unlink(LOGS . 'error.log'); |
339 |
} |
340 |
if (file_exists(LOGS . 'debug.log')) { |
341 |
unlink(LOGS . 'debug.log'); |
342 |
} |
343 |
if (file_exists(LOGS . 'bogus.log')) { |
344 |
unlink(LOGS . 'bogus.log'); |
345 |
} |
346 |
if (file_exists(LOGS . 'spam.log')) { |
347 |
unlink(LOGS . 'spam.log'); |
348 |
} |
349 |
if (file_exists(LOGS . 'eggs.log')) { |
350 |
unlink(LOGS . 'eggs.log'); |
351 |
} |
352 |
} |
353 |
|
354 |
/**
|
355 |
* test backward compatible scoped logging
|
356 |
*
|
357 |
* @return void
|
358 |
*/
|
359 |
public function testScopedLoggingBC() { |
360 |
$this->_resetLogConfig();
|
361 |
|
362 |
CakeLog::config('shops', array( |
363 |
'engine' => 'File', |
364 |
'types' => array('info', 'notice', 'warning'), |
365 |
'scopes' => array('transactions', 'orders'), |
366 |
'file' => 'shops', |
367 |
)); |
368 |
$this->_deleteLogs();
|
369 |
|
370 |
CakeLog::write('info', 'info message'); |
371 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
372 |
$this->assertTrue(file_exists(LOGS . 'debug.log')); |
373 |
|
374 |
$this->_deleteLogs();
|
375 |
|
376 |
CakeLog::write('transactions', 'transaction message'); |
377 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
378 |
$this->assertFalse(file_exists(LOGS . 'transactions.log')); |
379 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
380 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
381 |
|
382 |
$this->_deleteLogs();
|
383 |
|
384 |
CakeLog::write('error', 'error message'); |
385 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
386 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
387 |
$this->assertFalse(file_exists(LOGS . 'shops.log')); |
388 |
|
389 |
$this->_deleteLogs();
|
390 |
|
391 |
CakeLog::write('orders', 'order message'); |
392 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
393 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
394 |
$this->assertFalse(file_exists(LOGS . 'orders.log')); |
395 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
396 |
|
397 |
$this->_deleteLogs();
|
398 |
|
399 |
CakeLog::write('warning', 'warning message'); |
400 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
401 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
402 |
|
403 |
$this->_deleteLogs();
|
404 |
|
405 |
CakeLog::drop('shops'); |
406 |
} |
407 |
|
408 |
/**
|
409 |
* Test that scopes are exclusive and don't bleed.
|
410 |
*
|
411 |
* @return void
|
412 |
*/
|
413 |
public function testScopedLoggingExclusive() { |
414 |
$this->_deleteLogs();
|
415 |
|
416 |
CakeLog::config('shops', array( |
417 |
'engine' => 'File', |
418 |
'types' => array('info', 'notice', 'warning'), |
419 |
'scopes' => array('transactions', 'orders'), |
420 |
'file' => 'shops.log', |
421 |
)); |
422 |
CakeLog::config('eggs', array( |
423 |
'engine' => 'File', |
424 |
'types' => array('info', 'notice', 'warning'), |
425 |
'scopes' => array('eggs'), |
426 |
'file' => 'eggs.log', |
427 |
)); |
428 |
|
429 |
CakeLog::write('info', 'transactions message', 'transactions'); |
430 |
$this->assertFalse(file_exists(LOGS . 'eggs.log')); |
431 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
432 |
|
433 |
$this->_deleteLogs();
|
434 |
|
435 |
CakeLog::write('info', 'eggs message', 'eggs'); |
436 |
$this->assertTrue(file_exists(LOGS . 'eggs.log')); |
437 |
$this->assertFalse(file_exists(LOGS . 'shops.log')); |
438 |
} |
439 |
|
440 |
/**
|
441 |
* test scoped logging
|
442 |
*
|
443 |
* @return void
|
444 |
*/
|
445 |
public function testScopedLogging() { |
446 |
$this->_resetLogConfig();
|
447 |
$this->_deleteLogs();
|
448 |
|
449 |
CakeLog::config('string-scope', array( |
450 |
'engine' => 'File', |
451 |
'types' => array('info', 'notice', 'warning'), |
452 |
'scopes' => 'string-scope', |
453 |
'file' => 'string-scope.log' |
454 |
)); |
455 |
CakeLog::write('info', 'info message', 'string-scope'); |
456 |
$this->assertTrue(file_exists(LOGS . 'string-scope.log')); |
457 |
|
458 |
CakeLog::drop('string-scope'); |
459 |
|
460 |
CakeLog::config('shops', array( |
461 |
'engine' => 'File', |
462 |
'types' => array('info', 'notice', 'warning'), |
463 |
'scopes' => array('transactions', 'orders'), |
464 |
'file' => 'shops.log', |
465 |
)); |
466 |
|
467 |
CakeLog::write('info', 'info message', 'transactions'); |
468 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
469 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
470 |
$this->assertTrue(file_exists(LOGS . 'debug.log')); |
471 |
|
472 |
$this->_deleteLogs();
|
473 |
|
474 |
CakeLog::write('transactions', 'transaction message', 'orders'); |
475 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
476 |
$this->assertFalse(file_exists(LOGS . 'transactions.log')); |
477 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
478 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
479 |
|
480 |
$this->_deleteLogs();
|
481 |
|
482 |
CakeLog::write('error', 'error message', 'orders'); |
483 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
484 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
485 |
$this->assertFalse(file_exists(LOGS . 'shops.log')); |
486 |
|
487 |
$this->_deleteLogs();
|
488 |
|
489 |
CakeLog::write('orders', 'order message', 'transactions'); |
490 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
491 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
492 |
$this->assertFalse(file_exists(LOGS . 'orders.log')); |
493 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
494 |
|
495 |
$this->_deleteLogs();
|
496 |
|
497 |
CakeLog::write('warning', 'warning message', 'orders'); |
498 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
499 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
500 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
501 |
|
502 |
$this->_deleteLogs();
|
503 |
|
504 |
CakeLog::drop('shops'); |
505 |
} |
506 |
|
507 |
/**
|
508 |
* test bogus type and scope
|
509 |
*
|
510 |
* @return void
|
511 |
*/
|
512 |
public function testBogusTypeAndScope() { |
513 |
$this->_resetLogConfig();
|
514 |
$this->_deleteLogs();
|
515 |
|
516 |
CakeLog::config('file', array( |
517 |
'engine' => 'File', |
518 |
'path' => LOGS |
519 |
)); |
520 |
|
521 |
CakeLog::write('bogus', 'bogus message'); |
522 |
$this->assertTrue(file_exists(LOGS . 'bogus.log')); |
523 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
524 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
525 |
$this->_deleteLogs();
|
526 |
|
527 |
CakeLog::write('bogus', 'bogus message', 'bogus'); |
528 |
$this->assertTrue(file_exists(LOGS . 'bogus.log')); |
529 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
530 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
531 |
$this->_deleteLogs();
|
532 |
|
533 |
CakeLog::write('error', 'bogus message', 'bogus'); |
534 |
$this->assertFalse(file_exists(LOGS . 'bogus.log')); |
535 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
536 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
537 |
$this->_deleteLogs();
|
538 |
} |
539 |
|
540 |
/**
|
541 |
* test scoped logging with convenience methods
|
542 |
*
|
543 |
* @return void
|
544 |
*/
|
545 |
public function testConvenienceScopedLogging() { |
546 |
if (file_exists(LOGS . 'shops.log')) { |
547 |
unlink(LOGS . 'shops.log'); |
548 |
} |
549 |
if (file_exists(LOGS . 'error.log')) { |
550 |
unlink(LOGS . 'error.log'); |
551 |
} |
552 |
if (file_exists(LOGS . 'debug.log')) { |
553 |
unlink(LOGS . 'debug.log'); |
554 |
} |
555 |
|
556 |
$this->_resetLogConfig();
|
557 |
CakeLog::config('shops', array( |
558 |
'engine' => 'File', |
559 |
'types' => array('info', 'debug', 'notice', 'warning'), |
560 |
'scopes' => array('transactions', 'orders'), |
561 |
'file' => 'shops', |
562 |
)); |
563 |
|
564 |
CakeLog::info('info message', 'transactions'); |
565 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
566 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
567 |
$this->assertTrue(file_exists(LOGS . 'debug.log')); |
568 |
|
569 |
$this->_deleteLogs();
|
570 |
|
571 |
CakeLog::error('error message', 'orders'); |
572 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
573 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
574 |
$this->assertFalse(file_exists(LOGS . 'shops.log')); |
575 |
|
576 |
$this->_deleteLogs();
|
577 |
|
578 |
CakeLog::warning('warning message', 'orders'); |
579 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
580 |
$this->assertTrue(file_exists(LOGS . 'shops.log')); |
581 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
582 |
|
583 |
$this->_deleteLogs();
|
584 |
|
585 |
CakeLog::drop('shops'); |
586 |
} |
587 |
|
588 |
/**
|
589 |
* test convenience methods
|
590 |
*
|
591 |
* @return void
|
592 |
*/
|
593 |
public function testConvenienceMethods() { |
594 |
$this->_deleteLogs();
|
595 |
|
596 |
CakeLog::config('debug', array( |
597 |
'engine' => 'File', |
598 |
'types' => array('notice', 'info', 'debug'), |
599 |
'file' => 'debug', |
600 |
)); |
601 |
CakeLog::config('error', array( |
602 |
'engine' => 'File', |
603 |
'types' => array('emergency', 'alert', 'critical', 'error', 'warning'), |
604 |
'file' => 'error', |
605 |
)); |
606 |
|
607 |
$testMessage = 'emergency message'; |
608 |
CakeLog::emergency($testMessage); |
609 |
$contents = file_get_contents(LOGS . 'error.log'); |
610 |
$this->assertRegExp('/(Emergency|Critical): ' . $testMessage . '/', $contents); |
611 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
612 |
$this->_deleteLogs();
|
613 |
|
614 |
$testMessage = 'alert message'; |
615 |
CakeLog::alert($testMessage); |
616 |
$contents = file_get_contents(LOGS . 'error.log'); |
617 |
$this->assertRegExp('/(Alert|Critical): ' . $testMessage . '/', $contents); |
618 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
619 |
$this->_deleteLogs();
|
620 |
|
621 |
$testMessage = 'critical message'; |
622 |
CakeLog::critical($testMessage); |
623 |
$contents = file_get_contents(LOGS . 'error.log'); |
624 |
$this->assertContains('Critical: ' . $testMessage, $contents); |
625 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
626 |
$this->_deleteLogs();
|
627 |
|
628 |
$testMessage = 'error message'; |
629 |
CakeLog::error($testMessage); |
630 |
$contents = file_get_contents(LOGS . 'error.log'); |
631 |
$this->assertContains('Error: ' . $testMessage, $contents); |
632 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
633 |
$this->_deleteLogs();
|
634 |
|
635 |
$testMessage = 'warning message'; |
636 |
CakeLog::warning($testMessage); |
637 |
$contents = file_get_contents(LOGS . 'error.log'); |
638 |
$this->assertContains('Warning: ' . $testMessage, $contents); |
639 |
$this->assertFalse(file_exists(LOGS . 'debug.log')); |
640 |
$this->_deleteLogs();
|
641 |
|
642 |
$testMessage = 'notice message'; |
643 |
CakeLog::notice($testMessage); |
644 |
$contents = file_get_contents(LOGS . 'debug.log'); |
645 |
$this->assertRegExp('/(Notice|Debug): ' . $testMessage . '/', $contents); |
646 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
647 |
$this->_deleteLogs();
|
648 |
|
649 |
$testMessage = 'info message'; |
650 |
CakeLog::info($testMessage); |
651 |
$contents = file_get_contents(LOGS . 'debug.log'); |
652 |
$this->assertRegExp('/(Info|Debug): ' . $testMessage . '/', $contents); |
653 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
654 |
$this->_deleteLogs();
|
655 |
|
656 |
$testMessage = 'debug message'; |
657 |
CakeLog::debug($testMessage); |
658 |
$contents = file_get_contents(LOGS . 'debug.log'); |
659 |
$this->assertContains('Debug: ' . $testMessage, $contents); |
660 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
661 |
$this->_deleteLogs();
|
662 |
} |
663 |
|
664 |
/**
|
665 |
* test levels customization
|
666 |
*
|
667 |
* @return void
|
668 |
*/
|
669 |
public function testLevelCustomization() { |
670 |
$this->skipIf(DIRECTORY_SEPARATOR === '\\', 'Log level tests not supported on Windows.'); |
671 |
|
672 |
$levels = CakeLog::defaultLevels(); |
673 |
$this->assertNotEmpty($levels); |
674 |
$result = array_keys($levels); |
675 |
$this->assertEquals(array(0, 1, 2, 3, 4, 5, 6, 7), $result); |
676 |
|
677 |
$levels = CakeLog::levels(array('foo', 'bar')); |
678 |
CakeLog::defaultLevels();
|
679 |
$this->assertEquals('foo', $levels[8]); |
680 |
$this->assertEquals('bar', $levels[9]); |
681 |
|
682 |
$levels = CakeLog::levels(array(11 => 'spam', 'bar' => 'eggs')); |
683 |
CakeLog::defaultLevels();
|
684 |
$this->assertEquals('spam', $levels[8]); |
685 |
$this->assertEquals('eggs', $levels[9]); |
686 |
|
687 |
$levels = CakeLog::levels(array(11 => 'spam', 'bar' => 'eggs'), false); |
688 |
CakeLog::defaultLevels();
|
689 |
$this->assertEquals(array('spam', 'eggs'), $levels); |
690 |
|
691 |
$levels = CakeLog::levels(array('ham', 9 => 'spam', '12' => 'fam'), false); |
692 |
CakeLog::defaultLevels();
|
693 |
$this->assertEquals(array('ham', 'spam', 'fam'), $levels); |
694 |
} |
695 |
|
696 |
/**
|
697 |
* Test writing log files with custom levels
|
698 |
*
|
699 |
* @return void
|
700 |
*/
|
701 |
public function testCustomLevelWrites() { |
702 |
$this->_deleteLogs();
|
703 |
$this->_resetLogConfig();
|
704 |
|
705 |
CakeLog::levels(array('spam', 'eggs')); |
706 |
|
707 |
$testMessage = 'error message'; |
708 |
CakeLog::write('error', $testMessage); |
709 |
CakeLog::defaultLevels();
|
710 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
711 |
$contents = file_get_contents(LOGS . 'error.log'); |
712 |
$this->assertContains('Error: ' . $testMessage, $contents); |
713 |
|
714 |
CakeLog::config('spam', array( |
715 |
'engine' => 'File', |
716 |
'file' => 'spam.log', |
717 |
'types' => 'spam', |
718 |
)); |
719 |
CakeLog::config('eggs', array( |
720 |
'engine' => 'File', |
721 |
'file' => 'eggs.log', |
722 |
'types' => array('spam', 'eggs'), |
723 |
)); |
724 |
|
725 |
$testMessage = 'spam message'; |
726 |
CakeLog::write('spam', $testMessage); |
727 |
CakeLog::defaultLevels();
|
728 |
$this->assertTrue(file_exists(LOGS . 'spam.log')); |
729 |
$this->assertTrue(file_exists(LOGS . 'eggs.log')); |
730 |
$contents = file_get_contents(LOGS . 'spam.log'); |
731 |
$this->assertContains('Spam: ' . $testMessage, $contents); |
732 |
|
733 |
$testMessage = 'egg message'; |
734 |
CakeLog::write('eggs', $testMessage); |
735 |
CakeLog::defaultLevels();
|
736 |
$contents = file_get_contents(LOGS . 'spam.log'); |
737 |
$this->assertNotContains('Eggs: ' . $testMessage, $contents); |
738 |
$contents = file_get_contents(LOGS . 'eggs.log'); |
739 |
$this->assertContains('Eggs: ' . $testMessage, $contents); |
740 |
|
741 |
CakeLog::drop('spam'); |
742 |
CakeLog::drop('eggs'); |
743 |
|
744 |
$this->_deleteLogs();
|
745 |
} |
746 |
|
747 |
} |