pictcode / lib / Cake / Test / Case / Log / Engine / SyslogLogTest.php @ 0b1b8047
履歴 | 表示 | アノテート | ダウンロード (2.603 KB)
| 1 | 635eef61 | spyder1211 | <?php
|
|---|---|---|---|
| 2 | /**
|
||
| 3 | * CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
|
||
| 4 | * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||
| 5 | *
|
||
| 6 | * Licensed under The MIT License
|
||
| 7 | * For full copyright and license information, please see the LICENSE.txt
|
||
| 8 | * Redistributions of files must retain the above copyright notice
|
||
| 9 | *
|
||
| 10 | * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
||
| 11 | * @link http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
|
||
| 12 | * @package Cake.Test.Case.Log.Engine
|
||
| 13 | * @since CakePHP(tm) v 2.4
|
||
| 14 | * @license http://www.opensource.org/licenses/mit-license.php MIT License
|
||
| 15 | */
|
||
| 16 | |||
| 17 | App::uses('SyslogLog', 'Log/Engine'); |
||
| 18 | |||
| 19 | /**
|
||
| 20 | * SyslogLogTest class
|
||
| 21 | *
|
||
| 22 | * @package Cake.Test.Case.Log.Engine
|
||
| 23 | */
|
||
| 24 | class SyslogLogTest extends CakeTestCase { |
||
| 25 | |||
| 26 | /**
|
||
| 27 | * Tests that the connection to the logger is open with the right arguments
|
||
| 28 | *
|
||
| 29 | * @return void
|
||
| 30 | */
|
||
| 31 | public function testOpenLog() { |
||
| 32 | $log = $this->getMock('SyslogLog', array('_open', '_write')); |
||
| 33 | $log->expects($this->once())->method('_open')->with('', LOG_ODELAY, LOG_USER); |
||
| 34 | $log->write('debug', 'message'); |
||
| 35 | |||
| 36 | $log = $this->getMock('SyslogLog', array('_open', '_write')); |
||
| 37 | $log->config(array( |
||
| 38 | 'prefix' => 'thing', |
||
| 39 | 'flag' => LOG_NDELAY, |
||
| 40 | 'facility' => LOG_MAIL, |
||
| 41 | 'format' => '%s: %s' |
||
| 42 | )); |
||
| 43 | $log->expects($this->once())->method('_open') |
||
| 44 | ->with('thing', LOG_NDELAY, LOG_MAIL); |
||
| 45 | $log->write('debug', 'message'); |
||
| 46 | } |
||
| 47 | |||
| 48 | /**
|
||
| 49 | * Tests that single lines are written to syslog
|
||
| 50 | *
|
||
| 51 | * @dataProvider typesProvider
|
||
| 52 | * @return void
|
||
| 53 | */
|
||
| 54 | public function testWriteOneLine($type, $expected) { |
||
| 55 | $log = $this->getMock('SyslogLog', array('_open', '_write')); |
||
| 56 | $log->expects($this->once())->method('_write')->with($expected, $type . ': Foo'); |
||
| 57 | $log->write($type, 'Foo'); |
||
| 58 | } |
||
| 59 | |||
| 60 | /**
|
||
| 61 | * Tests that multiple lines are split and logged separately
|
||
| 62 | *
|
||
| 63 | * @return void
|
||
| 64 | */
|
||
| 65 | public function testWriteMultiLine() { |
||
| 66 | $log = $this->getMock('SyslogLog', array('_open', '_write')); |
||
| 67 | $log->expects($this->at(1))->method('_write')->with(LOG_DEBUG, 'debug: Foo'); |
||
| 68 | $log->expects($this->at(2))->method('_write')->with(LOG_DEBUG, 'debug: Bar'); |
||
| 69 | $log->expects($this->exactly(2))->method('_write'); |
||
| 70 | $log->write('debug', "Foo\nBar"); |
||
| 71 | } |
||
| 72 | |||
| 73 | /**
|
||
| 74 | * Data provider for the write function test
|
||
| 75 | *
|
||
| 76 | * @return array
|
||
| 77 | */
|
||
| 78 | public function typesProvider() { |
||
| 79 | return array( |
||
| 80 | array('emergency', LOG_EMERG), |
||
| 81 | array('alert', LOG_ALERT), |
||
| 82 | array('critical', LOG_CRIT), |
||
| 83 | array('error', LOG_ERR), |
||
| 84 | array('warning', LOG_WARNING), |
||
| 85 | array('notice', LOG_NOTICE), |
||
| 86 | array('info', LOG_INFO), |
||
| 87 | array('debug', LOG_DEBUG) |
||
| 88 | ); |
||
| 89 | } |
||
| 90 | |||
| 91 | } |