統計
| ブランチ: | リビジョン:

pictcode / lib / Cake / Test / Case / Log / CakeLogTest.php @ 9d2f0219

履歴 | 表示 | アノテート | ダウンロード (19.993 KB)

1 635eef61 spyder1211
<?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
}