pictcode / lib / Cake / Test / Case / BasicsTest.php @ 9ddbf630
履歴 | 表示 | アノテート | ダウンロード (34.962 KB)
1 |
<?php
|
---|---|
2 |
/**
|
3 |
* BasicsTest 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
|
15 |
* @since CakePHP(tm) v 1.2.0.4206
|
16 |
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
17 |
*/
|
18 |
|
19 |
require_once CAKE . 'basics.php'; |
20 |
|
21 |
App::uses('Folder', 'Utility'); |
22 |
App::uses('CakeResponse', 'Network'); |
23 |
App::uses('Debugger', 'Utility'); |
24 |
|
25 |
/**
|
26 |
* BasicsTest class
|
27 |
*
|
28 |
* @package Cake.Test.Case
|
29 |
*/
|
30 |
class BasicsTest extends CakeTestCase { |
31 |
|
32 |
/**
|
33 |
* setUp method
|
34 |
*
|
35 |
* @return void
|
36 |
*/
|
37 |
public function setUp() { |
38 |
parent::setUp();
|
39 |
App::build(array( |
40 |
'Locale' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Locale' . DS) |
41 |
)); |
42 |
} |
43 |
|
44 |
/**
|
45 |
* test the array_diff_key compatibility function.
|
46 |
*
|
47 |
* @return void
|
48 |
*/
|
49 |
public function testArrayDiffKey() { |
50 |
$one = array('one' => 1, 'two' => 2, 'three' => 3); |
51 |
$two = array('one' => 'one', 'two' => 'two'); |
52 |
$result = array_diff_key($one, $two); |
53 |
$expected = array('three' => 3); |
54 |
$this->assertEquals($expected, $result); |
55 |
|
56 |
$one = array('one' => array('value', 'value-two'), 'two' => 2, 'three' => 3); |
57 |
$two = array('two' => 'two'); |
58 |
$result = array_diff_key($one, $two); |
59 |
$expected = array('one' => array('value', 'value-two'), 'three' => 3); |
60 |
$this->assertEquals($expected, $result); |
61 |
|
62 |
$one = array('one' => null, 'two' => 2, 'three' => '', 'four' => 0); |
63 |
$two = array('two' => 'two'); |
64 |
$result = array_diff_key($one, $two); |
65 |
$expected = array('one' => null, 'three' => '', 'four' => 0); |
66 |
$this->assertEquals($expected, $result); |
67 |
|
68 |
$one = array('minYear' => null, 'maxYear' => null, 'separator' => '-', 'interval' => 1, 'monthNames' => true); |
69 |
$two = array('minYear' => null, 'maxYear' => null, 'separator' => '-', 'interval' => 1, 'monthNames' => true); |
70 |
$result = array_diff_key($one, $two); |
71 |
$this->assertSame(array(), $result); |
72 |
} |
73 |
|
74 |
/**
|
75 |
* testHttpBase method
|
76 |
*
|
77 |
* @return void
|
78 |
*/
|
79 |
public function testEnv() { |
80 |
$this->skipIf(!function_exists('ini_get') || ini_get('safe_mode') === '1', 'Safe mode is on.'); |
81 |
|
82 |
$server = $_SERVER; |
83 |
$env = $_ENV; |
84 |
|
85 |
$_SERVER['HTTP_HOST'] = 'localhost'; |
86 |
$this->assertEquals(env('HTTP_BASE'), '.localhost'); |
87 |
|
88 |
$_SERVER['HTTP_HOST'] = 'com.ar'; |
89 |
$this->assertEquals(env('HTTP_BASE'), '.com.ar'); |
90 |
|
91 |
$_SERVER['HTTP_HOST'] = 'example.ar'; |
92 |
$this->assertEquals(env('HTTP_BASE'), '.example.ar'); |
93 |
|
94 |
$_SERVER['HTTP_HOST'] = 'example.com'; |
95 |
$this->assertEquals(env('HTTP_BASE'), '.example.com'); |
96 |
|
97 |
$_SERVER['HTTP_HOST'] = 'www.example.com'; |
98 |
$this->assertEquals(env('HTTP_BASE'), '.example.com'); |
99 |
|
100 |
$_SERVER['HTTP_HOST'] = 'subdomain.example.com'; |
101 |
$this->assertEquals(env('HTTP_BASE'), '.example.com'); |
102 |
|
103 |
$_SERVER['HTTP_HOST'] = 'example.com.ar'; |
104 |
$this->assertEquals(env('HTTP_BASE'), '.example.com.ar'); |
105 |
|
106 |
$_SERVER['HTTP_HOST'] = 'www.example.com.ar'; |
107 |
$this->assertEquals(env('HTTP_BASE'), '.example.com.ar'); |
108 |
|
109 |
$_SERVER['HTTP_HOST'] = 'subdomain.example.com.ar'; |
110 |
$this->assertEquals(env('HTTP_BASE'), '.example.com.ar'); |
111 |
|
112 |
$_SERVER['HTTP_HOST'] = 'double.subdomain.example.com'; |
113 |
$this->assertEquals(env('HTTP_BASE'), '.subdomain.example.com'); |
114 |
|
115 |
$_SERVER['HTTP_HOST'] = 'double.subdomain.example.com.ar'; |
116 |
$this->assertEquals(env('HTTP_BASE'), '.subdomain.example.com.ar'); |
117 |
|
118 |
$_SERVER = $_ENV = array(); |
119 |
|
120 |
$_SERVER['SCRIPT_NAME'] = '/a/test/test.php'; |
121 |
$this->assertEquals(env('SCRIPT_NAME'), '/a/test/test.php'); |
122 |
|
123 |
$_SERVER = $_ENV = array(); |
124 |
|
125 |
$_ENV['CGI_MODE'] = 'BINARY'; |
126 |
$_ENV['SCRIPT_URL'] = '/a/test/test.php'; |
127 |
$this->assertEquals(env('SCRIPT_NAME'), '/a/test/test.php'); |
128 |
|
129 |
$_SERVER = $_ENV = array(); |
130 |
|
131 |
$this->assertFalse(env('HTTPS')); |
132 |
|
133 |
$_SERVER['HTTPS'] = 'on'; |
134 |
$this->assertTrue(env('HTTPS')); |
135 |
|
136 |
$_SERVER['HTTPS'] = '1'; |
137 |
$this->assertTrue(env('HTTPS')); |
138 |
|
139 |
$_SERVER['HTTPS'] = 'I am not empty'; |
140 |
$this->assertTrue(env('HTTPS')); |
141 |
|
142 |
$_SERVER['HTTPS'] = 1; |
143 |
$this->assertTrue(env('HTTPS')); |
144 |
|
145 |
$_SERVER['HTTPS'] = 'off'; |
146 |
$this->assertFalse(env('HTTPS')); |
147 |
|
148 |
$_SERVER['HTTPS'] = false; |
149 |
$this->assertFalse(env('HTTPS')); |
150 |
|
151 |
$_SERVER['HTTPS'] = ''; |
152 |
$this->assertFalse(env('HTTPS')); |
153 |
|
154 |
$_SERVER = array(); |
155 |
|
156 |
$_ENV['SCRIPT_URI'] = 'https://domain.test/a/test.php'; |
157 |
$this->assertTrue(env('HTTPS')); |
158 |
|
159 |
$_ENV['SCRIPT_URI'] = 'http://domain.test/a/test.php'; |
160 |
$this->assertFalse(env('HTTPS')); |
161 |
|
162 |
$_SERVER = $_ENV = array(); |
163 |
|
164 |
$this->assertNull(env('TEST_ME')); |
165 |
|
166 |
$_ENV['TEST_ME'] = 'a'; |
167 |
$this->assertEquals(env('TEST_ME'), 'a'); |
168 |
|
169 |
$_SERVER['TEST_ME'] = 'b'; |
170 |
$this->assertEquals(env('TEST_ME'), 'b'); |
171 |
|
172 |
unset($_ENV['TEST_ME']); |
173 |
$this->assertEquals(env('TEST_ME'), 'b'); |
174 |
|
175 |
$_SERVER = $server; |
176 |
$_ENV = $env; |
177 |
} |
178 |
|
179 |
/**
|
180 |
* Test h()
|
181 |
*
|
182 |
* @return void
|
183 |
*/
|
184 |
public function testH() { |
185 |
$string = '<foo>'; |
186 |
$result = h($string); |
187 |
$this->assertEquals('<foo>', $result); |
188 |
|
189 |
$in = array('this & that', '<p>Which one</p>'); |
190 |
$result = h($in); |
191 |
$expected = array('this & that', '<p>Which one</p>'); |
192 |
$this->assertEquals($expected, $result); |
193 |
|
194 |
$string = '<foo> & '; |
195 |
$result = h($string); |
196 |
$this->assertEquals('<foo> & &nbsp;', $result); |
197 |
|
198 |
$string = '<foo> & '; |
199 |
$result = h($string, false); |
200 |
$this->assertEquals('<foo> & ', $result); |
201 |
|
202 |
$string = '<foo> & '; |
203 |
$result = h($string, 'UTF-8'); |
204 |
$this->assertEquals('<foo> & &nbsp;', $result); |
205 |
|
206 |
$arr = array('<foo>', ' '); |
207 |
$result = h($arr); |
208 |
$expected = array( |
209 |
'<foo>',
|
210 |
'&nbsp;'
|
211 |
); |
212 |
$this->assertEquals($expected, $result); |
213 |
|
214 |
$arr = array('<foo>', ' '); |
215 |
$result = h($arr, false); |
216 |
$expected = array( |
217 |
'<foo>',
|
218 |
' '
|
219 |
); |
220 |
$this->assertEquals($expected, $result); |
221 |
|
222 |
$arr = array('f' => '<foo>', 'n' => ' '); |
223 |
$result = h($arr, false); |
224 |
$expected = array( |
225 |
'f' => '<foo>', |
226 |
'n' => ' ' |
227 |
); |
228 |
$this->assertEquals($expected, $result); |
229 |
|
230 |
// Test that boolean values are not converted to strings
|
231 |
$result = h(false); |
232 |
$this->assertFalse($result); |
233 |
|
234 |
$arr = array('foo' => false, 'bar' => true); |
235 |
$result = h($arr); |
236 |
$this->assertFalse($result['foo']); |
237 |
$this->assertTrue($result['bar']); |
238 |
|
239 |
$obj = new stdClass(); |
240 |
$result = h($obj); |
241 |
$this->assertEquals('(object)stdClass', $result); |
242 |
|
243 |
$obj = new CakeResponse(array('body' => 'Body content')); |
244 |
$result = h($obj); |
245 |
$this->assertEquals('Body content', $result); |
246 |
} |
247 |
|
248 |
/**
|
249 |
* Test am()
|
250 |
*
|
251 |
* @return void
|
252 |
*/
|
253 |
public function testAm() { |
254 |
$result = am(array('one', 'two'), 2, 3, 4); |
255 |
$expected = array('one', 'two', 2, 3, 4); |
256 |
$this->assertEquals($expected, $result); |
257 |
|
258 |
$result = am(array('one' => array(2, 3), 'two' => array('foo')), array('one' => array(4, 5))); |
259 |
$expected = array('one' => array(4, 5), 'two' => array('foo')); |
260 |
$this->assertEquals($expected, $result); |
261 |
} |
262 |
|
263 |
/**
|
264 |
* test cache()
|
265 |
*
|
266 |
* @return void
|
267 |
*/
|
268 |
public function testCache() { |
269 |
$_cacheDisable = Configure::read('Cache.disable'); |
270 |
$this->skipIf($_cacheDisable, 'Cache is disabled, skipping cache() tests.'); |
271 |
|
272 |
Configure::write('Cache.disable', true); |
273 |
$result = cache('basics_test', 'simple cache write'); |
274 |
$this->assertNull($result); |
275 |
|
276 |
$result = cache('basics_test'); |
277 |
$this->assertNull($result); |
278 |
|
279 |
Configure::write('Cache.disable', false); |
280 |
$result = cache('basics_test', 'simple cache write'); |
281 |
$this->assertTrue((bool)$result); |
282 |
$this->assertTrue(file_exists(CACHE . 'basics_test')); |
283 |
|
284 |
$result = cache('basics_test'); |
285 |
$this->assertEquals('simple cache write', $result); |
286 |
if (file_exists(CACHE . 'basics_test')) { |
287 |
unlink(CACHE . 'basics_test'); |
288 |
} |
289 |
|
290 |
cache('basics_test', 'expired', '+1 second'); |
291 |
sleep(2); |
292 |
$result = cache('basics_test', null, '+1 second'); |
293 |
$this->assertNull($result); |
294 |
|
295 |
Configure::write('Cache.disable', $_cacheDisable); |
296 |
} |
297 |
|
298 |
/**
|
299 |
* test clearCache()
|
300 |
*
|
301 |
* @return void
|
302 |
*/
|
303 |
public function testClearCache() { |
304 |
$cacheOff = Configure::read('Cache.disable'); |
305 |
$this->skipIf($cacheOff, 'Cache is disabled, skipping clearCache() tests.'); |
306 |
|
307 |
cache('views' . DS . 'basics_test.cache', 'simple cache write'); |
308 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'basics_test.cache')); |
309 |
|
310 |
cache('views' . DS . 'basics_test_2.cache', 'simple cache write 2'); |
311 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'basics_test_2.cache')); |
312 |
|
313 |
cache('views' . DS . 'basics_test_3.cache', 'simple cache write 3'); |
314 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'basics_test_3.cache')); |
315 |
|
316 |
$result = clearCache(array('basics_test', 'basics_test_2'), 'views', '.cache'); |
317 |
$this->assertTrue($result); |
318 |
$this->assertFalse(file_exists(CACHE . 'views' . DS . 'basics_test.cache')); |
319 |
$this->assertFalse(file_exists(CACHE . 'views' . DS . 'basics_test.cache')); |
320 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'basics_test_3.cache')); |
321 |
|
322 |
$result = clearCache(null, 'views', '.cache'); |
323 |
$this->assertTrue($result); |
324 |
$this->assertFalse(file_exists(CACHE . 'views' . DS . 'basics_test_3.cache')); |
325 |
|
326 |
// Different path from views and with prefix
|
327 |
cache('models' . DS . 'basics_test.cache', 'simple cache write'); |
328 |
$this->assertTrue(file_exists(CACHE . 'models' . DS . 'basics_test.cache')); |
329 |
|
330 |
cache('models' . DS . 'basics_test_2.cache', 'simple cache write 2'); |
331 |
$this->assertTrue(file_exists(CACHE . 'models' . DS . 'basics_test_2.cache')); |
332 |
|
333 |
cache('models' . DS . 'basics_test_3.cache', 'simple cache write 3'); |
334 |
$this->assertTrue(file_exists(CACHE . 'models' . DS . 'basics_test_3.cache')); |
335 |
|
336 |
$result = clearCache('basics', 'models', '.cache'); |
337 |
$this->assertTrue($result); |
338 |
$this->assertFalse(file_exists(CACHE . 'models' . DS . 'basics_test.cache')); |
339 |
$this->assertFalse(file_exists(CACHE . 'models' . DS . 'basics_test_2.cache')); |
340 |
$this->assertFalse(file_exists(CACHE . 'models' . DS . 'basics_test_3.cache')); |
341 |
|
342 |
// checking if empty files were not removed
|
343 |
$emptyExists = file_exists(CACHE . 'views' . DS . 'empty'); |
344 |
if (!$emptyExists) { |
345 |
cache('views' . DS . 'empty', ''); |
346 |
} |
347 |
cache('views' . DS . 'basics_test.php', 'simple cache write'); |
348 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'basics_test.php')); |
349 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'empty')); |
350 |
|
351 |
$result = clearCache();
|
352 |
$this->assertTrue($result); |
353 |
$this->assertTrue(file_exists(CACHE . 'views' . DS . 'empty')); |
354 |
$this->assertFalse(file_exists(CACHE . 'views' . DS . 'basics_test.php')); |
355 |
if (!$emptyExists) { |
356 |
unlink(CACHE . 'views' . DS . 'empty'); |
357 |
} |
358 |
} |
359 |
|
360 |
/**
|
361 |
* test __()
|
362 |
*
|
363 |
* @return void
|
364 |
*/
|
365 |
public function testTranslate() { |
366 |
Configure::write('Config.language', 'rule_1_po'); |
367 |
|
368 |
$result = __('Plural Rule 1'); |
369 |
$expected = 'Plural Rule 1 (translated)'; |
370 |
$this->assertEquals($expected, $result); |
371 |
|
372 |
$result = __('Plural Rule 1 (from core)'); |
373 |
$expected = 'Plural Rule 1 (from core translated)'; |
374 |
$this->assertEquals($expected, $result); |
375 |
|
376 |
$result = __('Some string with %s', 'arguments'); |
377 |
$expected = 'Some string with arguments'; |
378 |
$this->assertEquals($expected, $result); |
379 |
|
380 |
$result = __('Some string with %s %s', 'multiple', 'arguments'); |
381 |
$expected = 'Some string with multiple arguments'; |
382 |
$this->assertEquals($expected, $result); |
383 |
|
384 |
$result = __('Some string with %s and a null argument', null); |
385 |
$expected = 'Some string with %s and a null argument'; |
386 |
$this->assertEquals($expected, $result); |
387 |
|
388 |
$result = __('Some string with multiple %s%s, first being null', null, 'arguments'); |
389 |
$expected = 'Some string with multiple arguments, first being null'; |
390 |
$this->assertEquals($expected, $result); |
391 |
|
392 |
$result = __('Some string with %s %s', array('multiple', 'arguments')); |
393 |
$expected = 'Some string with multiple arguments'; |
394 |
$this->assertEquals($expected, $result); |
395 |
|
396 |
$result = __('Testing %2$s %1$s', 'order', 'different'); |
397 |
$expected = 'Testing different order'; |
398 |
$this->assertEquals($expected, $result); |
399 |
|
400 |
$result = __('Testing %2$s %1$s', array('order', 'different')); |
401 |
$expected = 'Testing different order'; |
402 |
$this->assertEquals($expected, $result); |
403 |
|
404 |
$result = __('Testing %.2f number', 1.2345); |
405 |
$expected = 'Testing 1.23 number'; |
406 |
$this->assertEquals($expected, $result); |
407 |
} |
408 |
|
409 |
/**
|
410 |
* testTranslatePercent
|
411 |
*
|
412 |
* @return void
|
413 |
*/
|
414 |
public function testTranslatePercent() { |
415 |
$result = __('%s are 100% real fruit', 'Apples'); |
416 |
$expected = 'Apples are 100% real fruit'; |
417 |
$this->assertEquals($expected, $result, 'Percent sign at end of word should be considered literal'); |
418 |
|
419 |
$result = __('%s are %d% real fruit', 'Apples', 100); |
420 |
$expected = 'Apples are 100% real fruit'; |
421 |
$this->assertEquals($expected, $result, 'A digit marker should not be misinterpreted'); |
422 |
|
423 |
$result = __('%s are %s% real fruit', 'Apples', 100); |
424 |
$expected = 'Apples are 100% real fruit'; |
425 |
$this->assertEquals($expected, $result, 'A string marker should not be misinterpreted'); |
426 |
|
427 |
$result = __('%nonsense %s', 'Apples'); |
428 |
$expected = '%nonsense Apples'; |
429 |
$this->assertEquals($expected, $result, 'A percent sign at the start of the string should be considered literal'); |
430 |
|
431 |
$result = __('%s are awesome%', 'Apples'); |
432 |
$expected = 'Apples are awesome%'; |
433 |
$this->assertEquals($expected, $result, 'A percent sign at the end of the string should be considered literal'); |
434 |
|
435 |
$result = __('%2$d %1$s entered the bowl', 'Apples', 2); |
436 |
$expected = '2 Apples entered the bowl'; |
437 |
$this->assertEquals($expected, $result, 'Positional replacement markers should not be misinterpreted'); |
438 |
|
439 |
$result = __('%.2f% of all %s agree', 99.44444, 'Cats'); |
440 |
$expected = '99.44% of all Cats agree'; |
441 |
$this->assertEquals($expected, $result, 'significant-digit placeholder should not be misinterpreted'); |
442 |
} |
443 |
|
444 |
/**
|
445 |
* testTranslateWithFormatSpecifiers
|
446 |
*
|
447 |
* @return void
|
448 |
*/
|
449 |
public function testTranslateWithFormatSpecifiers() { |
450 |
$expected = 'Check, one, two, three'; |
451 |
$result = __('Check, %+10s, three', 'one, two'); |
452 |
$this->assertEquals($expected, $result); |
453 |
|
454 |
$expected = 'Check, +1, two, three'; |
455 |
$result = __('Check, %+5d, two, three', 1); |
456 |
$this->assertEquals($expected, $result); |
457 |
|
458 |
$expected = 'Check, @@one, two, three'; |
459 |
$result = __('Check, %\'@+10s, three', 'one, two'); |
460 |
$this->assertEquals($expected, $result); |
461 |
|
462 |
$expected = 'Check, one, two , three'; |
463 |
$result = __('Check, %-10s, three', 'one, two'); |
464 |
$this->assertEquals($expected, $result); |
465 |
|
466 |
$expected = 'Check, one, two##, three'; |
467 |
$result = __('Check, %\'#-10s, three', 'one, two'); |
468 |
$this->assertEquals($expected, $result); |
469 |
|
470 |
$expected = 'Check, one, two, three'; |
471 |
$result = __d('default', 'Check, %+10s, three', 'one, two'); |
472 |
$this->assertEquals($expected, $result); |
473 |
|
474 |
$expected = 'Check, @@one, two, three'; |
475 |
$result = __d('default', 'Check, %\'@+10s, three', 'one, two'); |
476 |
$this->assertEquals($expected, $result); |
477 |
|
478 |
$expected = 'Check, one, two , three'; |
479 |
$result = __d('default', 'Check, %-10s, three', 'one, two'); |
480 |
$this->assertEquals($expected, $result); |
481 |
|
482 |
$expected = 'Check, one, two##, three'; |
483 |
$result = __d('default', 'Check, %\'#-10s, three', 'one, two'); |
484 |
$this->assertEquals($expected, $result); |
485 |
} |
486 |
|
487 |
/**
|
488 |
* testTranslateDomainPluralWithFormatSpecifiers
|
489 |
*
|
490 |
* @return void
|
491 |
*/
|
492 |
public function testTranslateDomainPluralWithFormatSpecifiers() { |
493 |
$result = __dn('core', '%+5d item.', '%+5d items.', 1, 1); |
494 |
$expected = ' +1 item.'; |
495 |
$this->assertEquals($expected, $result); |
496 |
|
497 |
$result = __dn('core', '%-5d item.', '%-5d items.', 10, 10); |
498 |
$expected = '10 items.'; |
499 |
$this->assertEquals($expected, $result); |
500 |
|
501 |
$result = __dn('core', '%\'#+5d item.', '%\'*+5d items.', 1, 1); |
502 |
$expected = '###+1 item.'; |
503 |
$this->assertEquals($expected, $result); |
504 |
|
505 |
$result = __dn('core', '%\'#+5d item.', '%\'*+5d items.', 90, 90); |
506 |
$expected = '**+90 items.'; |
507 |
$this->assertEquals($expected, $result); |
508 |
|
509 |
$result = __dn('core', '%\'#+5d item.', '%\'*+5d items.', 9000, 9000); |
510 |
$expected = '+9000 items.'; |
511 |
$this->assertEquals($expected, $result); |
512 |
} |
513 |
|
514 |
/**
|
515 |
* test testTranslatePluralWithFormatSpecifiers
|
516 |
*
|
517 |
* @return void
|
518 |
*/
|
519 |
public function testTranslatePluralWithFormatSpecifiers() { |
520 |
Configure::write('Config.language', 'rule_1_po'); |
521 |
|
522 |
$result = __n('%-5d = 1', '%-5d = 0 or > 1', 10); |
523 |
$expected = '%-5d = 0 or > 1 (translated)'; |
524 |
$this->assertEquals($expected, $result); |
525 |
} |
526 |
|
527 |
/**
|
528 |
* test testTranslateDomainCategoryWithFormatSpecifiers
|
529 |
*
|
530 |
* @return void
|
531 |
*/
|
532 |
public function testTranslateDomainCategoryWithFormatSpecifiers() { |
533 |
Configure::write('Config.language', 'rule_1_po'); |
534 |
|
535 |
$result = __dc('default', '%+10s world', 6, 'hello'); |
536 |
$expected = ' hello world'; |
537 |
$this->assertEquals($expected, $result); |
538 |
|
539 |
$result = __dc('default', '%-10s world', 6, 'hello'); |
540 |
$expected = 'hello world'; |
541 |
$this->assertEquals($expected, $result); |
542 |
|
543 |
$result = __dc('default', '%\'@-10s world', 6, 'hello'); |
544 |
$expected = 'hello@@@@@ world'; |
545 |
$this->assertEquals($expected, $result); |
546 |
} |
547 |
|
548 |
/**
|
549 |
* test testTranslateDomainCategoryPluralWithFormatSpecifiers
|
550 |
*
|
551 |
* @return void
|
552 |
*/
|
553 |
public function testTranslateDomainCategoryPluralWithFormatSpecifiers() { |
554 |
Configure::write('Config.language', 'rule_1_po'); |
555 |
|
556 |
$result = __dcn('default', '%-5d = 1', '%-5d = 0 or > 1', 0, 6); |
557 |
$expected = '%-5d = 0 or > 1 (translated)'; |
558 |
$this->assertEquals($expected, $result); |
559 |
|
560 |
$result = __dcn('default', '%-5d = 1', '%-5d = 0 or > 1', 1, 6); |
561 |
$expected = '%-5d = 1 (translated)'; |
562 |
$this->assertEquals($expected, $result); |
563 |
} |
564 |
|
565 |
/**
|
566 |
* test testTranslateCategoryWithFormatSpecifiers
|
567 |
*
|
568 |
* @return void
|
569 |
*/
|
570 |
public function testTranslateCategoryWithFormatSpecifiers() { |
571 |
$result = __c('Some string with %+10s', 6, 'arguments'); |
572 |
$expected = 'Some string with arguments'; |
573 |
$this->assertEquals($expected, $result); |
574 |
|
575 |
$result = __c('Some string with %-10s: args', 6, 'arguments'); |
576 |
$expected = 'Some string with arguments : args'; |
577 |
$this->assertEquals($expected, $result); |
578 |
|
579 |
$result = __c('Some string with %\'*-10s: args', 6, 'arguments'); |
580 |
$expected = 'Some string with arguments*: args'; |
581 |
$this->assertEquals($expected, $result); |
582 |
} |
583 |
|
584 |
/**
|
585 |
* test __n()
|
586 |
*
|
587 |
* @return void
|
588 |
*/
|
589 |
public function testTranslatePlural() { |
590 |
Configure::write('Config.language', 'rule_1_po'); |
591 |
|
592 |
$result = __n('%d = 1', '%d = 0 or > 1', 0); |
593 |
$expected = '%d = 0 or > 1 (translated)'; |
594 |
$this->assertEquals($expected, $result); |
595 |
|
596 |
$result = __n('%d = 1', '%d = 0 or > 1', 1); |
597 |
$expected = '%d = 1 (translated)'; |
598 |
$this->assertEquals($expected, $result); |
599 |
|
600 |
$result = __n('%d = 1 (from core)', '%d = 0 or > 1 (from core)', 2); |
601 |
$expected = '%d = 0 or > 1 (from core translated)'; |
602 |
$this->assertEquals($expected, $result); |
603 |
|
604 |
$result = __n('%d item.', '%d items.', 1, 1); |
605 |
$expected = '1 item.'; |
606 |
$this->assertEquals($expected, $result); |
607 |
|
608 |
$result = __n('%d item for id %s', '%d items for id %s', 2, 2, '1234'); |
609 |
$expected = '2 items for id 1234'; |
610 |
$this->assertEquals($expected, $result); |
611 |
|
612 |
$result = __n('%d item for id %s', '%d items for id %s', 2, array(2, '1234')); |
613 |
$expected = '2 items for id 1234'; |
614 |
$this->assertEquals($expected, $result); |
615 |
} |
616 |
|
617 |
/**
|
618 |
* test __d()
|
619 |
*
|
620 |
* @return void
|
621 |
*/
|
622 |
public function testTranslateDomain() { |
623 |
Configure::write('Config.language', 'rule_1_po'); |
624 |
|
625 |
$result = __d('default', 'Plural Rule 1'); |
626 |
$expected = 'Plural Rule 1 (translated)'; |
627 |
$this->assertEquals($expected, $result); |
628 |
|
629 |
$result = __d('core', 'Plural Rule 1'); |
630 |
$expected = 'Plural Rule 1'; |
631 |
$this->assertEquals($expected, $result); |
632 |
|
633 |
$result = __d('core', 'Plural Rule 1 (from core)'); |
634 |
$expected = 'Plural Rule 1 (from core translated)'; |
635 |
$this->assertEquals($expected, $result); |
636 |
|
637 |
$result = __d('core', 'Some string with %s', 'arguments'); |
638 |
$expected = 'Some string with arguments'; |
639 |
$this->assertEquals($expected, $result); |
640 |
|
641 |
$result = __d('core', 'Some string with %s %s', 'multiple', 'arguments'); |
642 |
$expected = 'Some string with multiple arguments'; |
643 |
$this->assertEquals($expected, $result); |
644 |
|
645 |
$result = __d('core', 'Some string with %s %s', array('multiple', 'arguments')); |
646 |
$expected = 'Some string with multiple arguments'; |
647 |
$this->assertEquals($expected, $result); |
648 |
} |
649 |
|
650 |
/**
|
651 |
* test __dn()
|
652 |
*
|
653 |
* @return void
|
654 |
*/
|
655 |
public function testTranslateDomainPlural() { |
656 |
Configure::write('Config.language', 'rule_1_po'); |
657 |
|
658 |
$result = __dn('default', '%d = 1', '%d = 0 or > 1', 0); |
659 |
$expected = '%d = 0 or > 1 (translated)'; |
660 |
$this->assertEquals($expected, $result); |
661 |
|
662 |
$result = __dn('core', '%d = 1', '%d = 0 or > 1', 0); |
663 |
$expected = '%d = 0 or > 1'; |
664 |
$this->assertEquals($expected, $result); |
665 |
|
666 |
$result = __dn('core', '%d = 1 (from core)', '%d = 0 or > 1 (from core)', 0); |
667 |
$expected = '%d = 0 or > 1 (from core translated)'; |
668 |
$this->assertEquals($expected, $result); |
669 |
|
670 |
$result = __dn('default', '%d = 1', '%d = 0 or > 1', 1); |
671 |
$expected = '%d = 1 (translated)'; |
672 |
$this->assertEquals($expected, $result); |
673 |
|
674 |
$result = __dn('core', '%d item.', '%d items.', 1, 1); |
675 |
$expected = '1 item.'; |
676 |
$this->assertEquals($expected, $result); |
677 |
|
678 |
$result = __dn('core', '%d item for id %s', '%d items for id %s', 2, 2, '1234'); |
679 |
$expected = '2 items for id 1234'; |
680 |
$this->assertEquals($expected, $result); |
681 |
|
682 |
$result = __dn('core', '%d item for id %s', '%d items for id %s', 2, array(2, '1234')); |
683 |
$expected = '2 items for id 1234'; |
684 |
$this->assertEquals($expected, $result); |
685 |
} |
686 |
|
687 |
/**
|
688 |
* test __c()
|
689 |
*
|
690 |
* @return void
|
691 |
*/
|
692 |
public function testTranslateCategory() { |
693 |
Configure::write('Config.language', 'rule_1_po'); |
694 |
|
695 |
$result = __c('Plural Rule 1', 6); |
696 |
$expected = 'Plural Rule 1 (translated)'; |
697 |
$this->assertEquals($expected, $result); |
698 |
|
699 |
$result = __c('Plural Rule 1 (from core)', 6); |
700 |
$expected = 'Plural Rule 1 (from core translated)'; |
701 |
$this->assertEquals($expected, $result); |
702 |
|
703 |
$result = __c('Some string with %s', 6, 'arguments'); |
704 |
$expected = 'Some string with arguments'; |
705 |
$this->assertEquals($expected, $result); |
706 |
|
707 |
$result = __c('Some string with %s %s', 6, 'multiple', 'arguments'); |
708 |
$expected = 'Some string with multiple arguments'; |
709 |
$this->assertEquals($expected, $result); |
710 |
|
711 |
$result = __c('Some string with %s %s', 6, array('multiple', 'arguments')); |
712 |
$expected = 'Some string with multiple arguments'; |
713 |
$this->assertEquals($expected, $result); |
714 |
} |
715 |
|
716 |
/**
|
717 |
* test __dc()
|
718 |
*
|
719 |
* @return void
|
720 |
*/
|
721 |
public function testTranslateDomainCategory() { |
722 |
Configure::write('Config.language', 'rule_1_po'); |
723 |
|
724 |
$result = __dc('default', 'Plural Rule 1', 6); |
725 |
$expected = 'Plural Rule 1 (translated)'; |
726 |
$this->assertEquals($expected, $result); |
727 |
|
728 |
$result = __dc('default', 'Plural Rule 1 (from core)', 6); |
729 |
$expected = 'Plural Rule 1 (from core translated)'; |
730 |
$this->assertEquals($expected, $result); |
731 |
|
732 |
$result = __dc('core', 'Plural Rule 1', 6); |
733 |
$expected = 'Plural Rule 1'; |
734 |
$this->assertEquals($expected, $result); |
735 |
|
736 |
$result = __dc('core', 'Plural Rule 1 (from core)', 6); |
737 |
$expected = 'Plural Rule 1 (from core translated)'; |
738 |
$this->assertEquals($expected, $result); |
739 |
|
740 |
$result = __dc('core', 'Some string with %s', 6, 'arguments'); |
741 |
$expected = 'Some string with arguments'; |
742 |
$this->assertEquals($expected, $result); |
743 |
|
744 |
$result = __dc('core', 'Some string with %s %s', 6, 'multiple', 'arguments'); |
745 |
$expected = 'Some string with multiple arguments'; |
746 |
$this->assertEquals($expected, $result); |
747 |
|
748 |
$result = __dc('core', 'Some string with %s %s', 6, array('multiple', 'arguments')); |
749 |
$expected = 'Some string with multiple arguments'; |
750 |
$this->assertEquals($expected, $result); |
751 |
} |
752 |
|
753 |
/**
|
754 |
* test __dcn()
|
755 |
*
|
756 |
* @return void
|
757 |
*/
|
758 |
public function testTranslateDomainCategoryPlural() { |
759 |
Configure::write('Config.language', 'rule_1_po'); |
760 |
|
761 |
$result = __dcn('default', '%d = 1', '%d = 0 or > 1', 0, 6); |
762 |
$expected = '%d = 0 or > 1 (translated)'; |
763 |
$this->assertEquals($expected, $result); |
764 |
|
765 |
$result = __dcn('default', '%d = 1 (from core)', '%d = 0 or > 1 (from core)', 1, 6); |
766 |
$expected = '%d = 1 (from core translated)'; |
767 |
$this->assertEquals($expected, $result); |
768 |
|
769 |
$result = __dcn('core', '%d = 1', '%d = 0 or > 1', 0, 6); |
770 |
$expected = '%d = 0 or > 1'; |
771 |
$this->assertEquals($expected, $result); |
772 |
|
773 |
$result = __dcn('core', '%d item.', '%d items.', 1, 6, 1); |
774 |
$expected = '1 item.'; |
775 |
$this->assertEquals($expected, $result); |
776 |
|
777 |
$result = __dcn('core', '%d item for id %s', '%d items for id %s', 2, 6, 2, '1234'); |
778 |
$expected = '2 items for id 1234'; |
779 |
$this->assertEquals($expected, $result); |
780 |
|
781 |
$result = __dcn('core', '%d item for id %s', '%d items for id %s', 2, 6, array(2, '1234')); |
782 |
$expected = '2 items for id 1234'; |
783 |
$this->assertEquals($expected, $result); |
784 |
} |
785 |
|
786 |
/**
|
787 |
* test LogError()
|
788 |
*
|
789 |
* @return void
|
790 |
*/
|
791 |
public function testLogError() { |
792 |
if (file_exists(LOGS . 'error.log')) { |
793 |
unlink(LOGS . 'error.log'); |
794 |
} |
795 |
|
796 |
// disable stderr output for this test
|
797 |
if (CakeLog::stream('stderr')) { |
798 |
CakeLog::disable('stderr'); |
799 |
} |
800 |
|
801 |
LogError('Testing LogError() basic function'); |
802 |
LogError("Testing with\nmulti-line\nstring"); |
803 |
|
804 |
if (CakeLog::stream('stderr')) { |
805 |
CakeLog::enable('stderr'); |
806 |
} |
807 |
|
808 |
$result = file_get_contents(LOGS . 'error.log'); |
809 |
$this->assertRegExp('/Error: Testing LogError\(\) basic function/', $result); |
810 |
$this->assertNotRegExp("/Error: Testing with\nmulti-line\nstring/", $result); |
811 |
$this->assertRegExp('/Error: Testing with multi-line string/', $result); |
812 |
} |
813 |
|
814 |
/**
|
815 |
* test fileExistsInPath()
|
816 |
*
|
817 |
* @return void
|
818 |
*/
|
819 |
public function testFileExistsInPath() { |
820 |
if (!function_exists('ini_set')) { |
821 |
$this->markTestSkipped('%s ini_set function not available'); |
822 |
} |
823 |
|
824 |
$_includePath = ini_get('include_path'); |
825 |
|
826 |
$path = TMP . 'basics_test'; |
827 |
$folder1 = $path . DS . 'folder1'; |
828 |
$folder2 = $path . DS . 'folder2'; |
829 |
$file1 = $path . DS . 'file1.php'; |
830 |
$file2 = $folder1 . DS . 'file2.php'; |
831 |
$file3 = $folder1 . DS . 'file3.php'; |
832 |
$file4 = $folder2 . DS . 'file4.php'; |
833 |
|
834 |
new Folder($path, true); |
835 |
new Folder($folder1, true); |
836 |
new Folder($folder2, true); |
837 |
touch($file1); |
838 |
touch($file2); |
839 |
touch($file3); |
840 |
touch($file4); |
841 |
|
842 |
ini_set('include_path', $path . PATH_SEPARATOR . $folder1); |
843 |
|
844 |
$this->assertEquals(fileExistsInPath('file1.php'), $file1); |
845 |
$this->assertEquals(fileExistsInPath('file2.php'), $file2); |
846 |
$this->assertEquals(fileExistsInPath('folder1' . DS . 'file2.php'), $file2); |
847 |
$this->assertEquals(fileExistsInPath($file2), $file2); |
848 |
$this->assertEquals(fileExistsInPath('file3.php'), $file3); |
849 |
$this->assertEquals(fileExistsInPath($file4), $file4); |
850 |
|
851 |
$this->assertFalse(fileExistsInPath('file1')); |
852 |
$this->assertFalse(fileExistsInPath('file4.php')); |
853 |
|
854 |
$Folder = new Folder($path); |
855 |
$Folder->delete(); |
856 |
|
857 |
ini_set('include_path', $_includePath); |
858 |
} |
859 |
|
860 |
/**
|
861 |
* test convertSlash()
|
862 |
*
|
863 |
* @return void
|
864 |
*/
|
865 |
public function testConvertSlash() { |
866 |
$result = convertSlash('\path\to\location\\'); |
867 |
$expected = '\path\to\location\\'; |
868 |
$this->assertEquals($expected, $result); |
869 |
|
870 |
$result = convertSlash('/path/to/location/'); |
871 |
$expected = 'path_to_location'; |
872 |
$this->assertEquals($expected, $result); |
873 |
} |
874 |
|
875 |
/**
|
876 |
* test debug()
|
877 |
*
|
878 |
* @return void
|
879 |
*/
|
880 |
public function testDebug() { |
881 |
ob_start(); |
882 |
debug('this-is-a-test', false); |
883 |
$result = ob_get_clean();
|
884 |
$expectedText = <<<EXPECTED |
885 |
%s (line %d)
|
886 |
########## DEBUG ##########
|
887 |
'this-is-a-test'
|
888 |
###########################
|
889 |
|
890 |
EXPECTED;
|
891 |
$expected = sprintf($expectedText, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 9); |
892 |
|
893 |
$this->assertEquals($expected, $result); |
894 |
|
895 |
ob_start(); |
896 |
debug('<div>this-is-a-test</div>', true); |
897 |
$result = ob_get_clean();
|
898 |
$expectedHtml = <<<EXPECTED |
899 |
<div class="cake-debug-output">
|
900 |
<span><strong>%s</strong> (line <strong>%d</strong>)</span>
|
901 |
<pre class="cake-debug">
|
902 |
'<div>this-is-a-test</div>'
|
903 |
</pre>
|
904 |
</div>
|
905 |
EXPECTED;
|
906 |
$expected = sprintf($expectedHtml, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 10); |
907 |
$this->assertEquals($expected, $result); |
908 |
|
909 |
ob_start(); |
910 |
debug('<div>this-is-a-test</div>', true, true); |
911 |
$result = ob_get_clean();
|
912 |
$expected = <<<EXPECTED |
913 |
<div class="cake-debug-output">
|
914 |
<span><strong>%s</strong> (line <strong>%d</strong>)</span>
|
915 |
<pre class="cake-debug">
|
916 |
'<div>this-is-a-test</div>'
|
917 |
</pre>
|
918 |
</div>
|
919 |
EXPECTED;
|
920 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 10); |
921 |
$this->assertEquals($expected, $result); |
922 |
|
923 |
ob_start(); |
924 |
debug('<div>this-is-a-test</div>', true, false); |
925 |
$result = ob_get_clean();
|
926 |
$expected = <<<EXPECTED |
927 |
<div class="cake-debug-output">
|
928 |
|
929 |
<pre class="cake-debug">
|
930 |
'<div>this-is-a-test</div>'
|
931 |
</pre>
|
932 |
</div>
|
933 |
EXPECTED;
|
934 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 10); |
935 |
$this->assertEquals($expected, $result); |
936 |
|
937 |
ob_start(); |
938 |
debug('<div>this-is-a-test</div>', null); |
939 |
$result = ob_get_clean();
|
940 |
$expectedHtml = <<<EXPECTED |
941 |
<div class="cake-debug-output">
|
942 |
<span><strong>%s</strong> (line <strong>%d</strong>)</span>
|
943 |
<pre class="cake-debug">
|
944 |
'<div>this-is-a-test</div>'
|
945 |
</pre>
|
946 |
</div>
|
947 |
EXPECTED;
|
948 |
$expectedText = <<<EXPECTED |
949 |
%s (line %d)
|
950 |
########## DEBUG ##########
|
951 |
'<div>this-is-a-test</div>'
|
952 |
###########################
|
953 |
|
954 |
EXPECTED;
|
955 |
if (PHP_SAPI === 'cli') { |
956 |
$expected = sprintf($expectedText, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 18); |
957 |
} else {
|
958 |
$expected = sprintf($expectedHtml, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 20); |
959 |
} |
960 |
$this->assertEquals($expected, $result); |
961 |
|
962 |
ob_start(); |
963 |
debug('<div>this-is-a-test</div>', null, false); |
964 |
$result = ob_get_clean();
|
965 |
$expectedHtml = <<<EXPECTED |
966 |
<div class="cake-debug-output">
|
967 |
|
968 |
<pre class="cake-debug">
|
969 |
'<div>this-is-a-test</div>'
|
970 |
</pre>
|
971 |
</div>
|
972 |
EXPECTED;
|
973 |
$expectedText = <<<EXPECTED |
974 |
|
975 |
########## DEBUG ##########
|
976 |
'<div>this-is-a-test</div>'
|
977 |
###########################
|
978 |
|
979 |
EXPECTED;
|
980 |
if (PHP_SAPI === 'cli') { |
981 |
$expected = sprintf($expectedText, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 18); |
982 |
} else {
|
983 |
$expected = sprintf($expectedHtml, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 19); |
984 |
} |
985 |
$this->assertEquals($expected, $result); |
986 |
|
987 |
ob_start(); |
988 |
debug('<div>this-is-a-test</div>', false); |
989 |
$result = ob_get_clean();
|
990 |
$expected = <<<EXPECTED |
991 |
%s (line %d)
|
992 |
########## DEBUG ##########
|
993 |
'<div>this-is-a-test</div>'
|
994 |
###########################
|
995 |
|
996 |
EXPECTED;
|
997 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 9); |
998 |
$this->assertEquals($expected, $result); |
999 |
|
1000 |
ob_start(); |
1001 |
debug('<div>this-is-a-test</div>', false, true); |
1002 |
$result = ob_get_clean();
|
1003 |
$expected = <<<EXPECTED |
1004 |
%s (line %d)
|
1005 |
########## DEBUG ##########
|
1006 |
'<div>this-is-a-test</div>'
|
1007 |
###########################
|
1008 |
|
1009 |
EXPECTED;
|
1010 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 9); |
1011 |
$this->assertEquals($expected, $result); |
1012 |
|
1013 |
ob_start(); |
1014 |
debug('<div>this-is-a-test</div>', false, false); |
1015 |
$result = ob_get_clean();
|
1016 |
$expected = <<<EXPECTED |
1017 |
|
1018 |
########## DEBUG ##########
|
1019 |
'<div>this-is-a-test</div>'
|
1020 |
###########################
|
1021 |
|
1022 |
EXPECTED;
|
1023 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 9); |
1024 |
$this->assertEquals($expected, $result); |
1025 |
|
1026 |
ob_start(); |
1027 |
debug(false, false, false); |
1028 |
$result = ob_get_clean();
|
1029 |
$expected = <<<EXPECTED |
1030 |
|
1031 |
########## DEBUG ##########
|
1032 |
false
|
1033 |
###########################
|
1034 |
|
1035 |
EXPECTED;
|
1036 |
$expected = sprintf($expected, str_replace(CAKE_CORE_INCLUDE_PATH, '', __FILE__), __LINE__ - 9); |
1037 |
$this->assertEquals($expected, $result); |
1038 |
} |
1039 |
|
1040 |
/**
|
1041 |
* test pr()
|
1042 |
*
|
1043 |
* @return void
|
1044 |
*/
|
1045 |
public function testPr() { |
1046 |
$this->skipIf(PHP_SAPI === 'cli', 'Skipping web test in cli mode'); |
1047 |
ob_start(); |
1048 |
pr('this is a test');
|
1049 |
$result = ob_get_clean();
|
1050 |
$expected = "<pre>this is a test</pre>"; |
1051 |
$this->assertEquals($expected, $result); |
1052 |
|
1053 |
ob_start(); |
1054 |
pr(array('this' => 'is', 'a' => 'test')); |
1055 |
$result = ob_get_clean();
|
1056 |
$expected = "<pre>Array\n(\n [this] => is\n [a] => test\n)\n</pre>"; |
1057 |
$this->assertEquals($expected, $result); |
1058 |
} |
1059 |
|
1060 |
/**
|
1061 |
* test pr()
|
1062 |
*
|
1063 |
* @return void
|
1064 |
*/
|
1065 |
public function testPrCli() { |
1066 |
$this->skipIf(PHP_SAPI !== 'cli', 'Skipping cli test in web mode'); |
1067 |
ob_start(); |
1068 |
pr('this is a test');
|
1069 |
$result = ob_get_clean();
|
1070 |
$expected = "\nthis is a test\n"; |
1071 |
$this->assertEquals($expected, $result); |
1072 |
|
1073 |
ob_start(); |
1074 |
pr(array('this' => 'is', 'a' => 'test')); |
1075 |
$result = ob_get_clean();
|
1076 |
$expected = "\nArray\n(\n [this] => is\n [a] => test\n)\n\n"; |
1077 |
$this->assertEquals($expected, $result); |
1078 |
} |
1079 |
|
1080 |
/**
|
1081 |
* test stripslashes_deep()
|
1082 |
*
|
1083 |
* @return void
|
1084 |
*/
|
1085 |
public function testStripslashesDeep() { |
1086 |
$this->skipIf(ini_get('magic_quotes_sybase') === '1', 'magic_quotes_sybase is on.'); |
1087 |
|
1088 |
$this->assertEquals(stripslashes_deep("tes\'t"), "tes't"); |
1089 |
$this->assertEquals(stripslashes_deep('tes\\' . chr(0) . 't'), 'tes' . chr(0) . 't'); |
1090 |
$this->assertEquals(stripslashes_deep('tes\"t'), 'tes"t'); |
1091 |
$this->assertEquals(stripslashes_deep("tes\'t"), "tes't"); |
1092 |
$this->assertEquals(stripslashes_deep('te\\st'), 'test'); |
1093 |
|
1094 |
$nested = array( |
1095 |
'a' => "tes\'t", |
1096 |
'b' => 'tes\\' . chr(0) . 't', |
1097 |
'c' => array( |
1098 |
'd' => 'tes\"t', |
1099 |
'e' => "te\'s\'t", |
1100 |
array('f' => "tes\'t") |
1101 |
), |
1102 |
'g' => 'te\\st' |
1103 |
); |
1104 |
$expected = array( |
1105 |
'a' => "tes't", |
1106 |
'b' => 'tes' . chr(0) . 't', |
1107 |
'c' => array( |
1108 |
'd' => 'tes"t', |
1109 |
'e' => "te's't", |
1110 |
array('f' => "tes't") |
1111 |
), |
1112 |
'g' => 'test' |
1113 |
); |
1114 |
$this->assertEquals($expected, stripslashes_deep($nested)); |
1115 |
} |
1116 |
|
1117 |
/**
|
1118 |
* test stripslashes_deep() with magic_quotes_sybase on
|
1119 |
*
|
1120 |
* @return void
|
1121 |
*/
|
1122 |
public function testStripslashesDeepSybase() { |
1123 |
if (!(ini_get('magic_quotes_sybase') === '1')) { |
1124 |
$this->markTestSkipped('magic_quotes_sybase is off'); |
1125 |
} |
1126 |
|
1127 |
$this->assertEquals(stripslashes_deep("tes\'t"), "tes\'t"); |
1128 |
|
1129 |
$nested = array( |
1130 |
'a' => "tes't", |
1131 |
'b' => "tes''t", |
1132 |
'c' => array( |
1133 |
'd' => "tes'''t", |
1134 |
'e' => "tes''''t", |
1135 |
array('f' => "tes''t") |
1136 |
), |
1137 |
'g' => "te'''''st" |
1138 |
); |
1139 |
$expected = array( |
1140 |
'a' => "tes't", |
1141 |
'b' => "tes't", |
1142 |
'c' => array( |
1143 |
'd' => "tes''t", |
1144 |
'e' => "tes''t", |
1145 |
array('f' => "tes't") |
1146 |
), |
1147 |
'g' => "te'''st" |
1148 |
); |
1149 |
$this->assertEquals($expected, stripslashes_deep($nested)); |
1150 |
} |
1151 |
|
1152 |
/**
|
1153 |
* Tests that the stackTrace() method is a shortcut for Debugger::trace()
|
1154 |
*
|
1155 |
* @return void
|
1156 |
*/
|
1157 |
public function testStackTrace() { |
1158 |
ob_start(); |
1159 |
list(, $expected) = array(stackTrace(), Debugger::trace()); |
1160 |
$result = ob_get_clean();
|
1161 |
$this->assertEquals($expected, $result); |
1162 |
|
1163 |
$opts = array('args' => true); |
1164 |
ob_start(); |
1165 |
list(, $expected) = array(stackTrace($opts), Debugger::trace($opts)); |
1166 |
$result = ob_get_clean();
|
1167 |
$this->assertEquals($expected, $result); |
1168 |
} |
1169 |
|
1170 |
/**
|
1171 |
* test pluginSplit
|
1172 |
*
|
1173 |
* @return void
|
1174 |
*/
|
1175 |
public function testPluginSplit() { |
1176 |
$result = pluginSplit('Something.else'); |
1177 |
$this->assertEquals(array('Something', 'else'), $result); |
1178 |
|
1179 |
$result = pluginSplit('Something.else.more.dots'); |
1180 |
$this->assertEquals(array('Something', 'else.more.dots'), $result); |
1181 |
|
1182 |
$result = pluginSplit('Somethingelse'); |
1183 |
$this->assertEquals(array(null, 'Somethingelse'), $result); |
1184 |
|
1185 |
$result = pluginSplit('Something.else', true); |
1186 |
$this->assertEquals(array('Something.', 'else'), $result); |
1187 |
|
1188 |
$result = pluginSplit('Something.else.more.dots', true); |
1189 |
$this->assertEquals(array('Something.', 'else.more.dots'), $result); |
1190 |
|
1191 |
$result = pluginSplit('Post', false, 'Blog'); |
1192 |
$this->assertEquals(array('Blog', 'Post'), $result); |
1193 |
|
1194 |
$result = pluginSplit('Blog.Post', false, 'Ultimate'); |
1195 |
$this->assertEquals(array('Blog', 'Post'), $result); |
1196 |
} |
1197 |
} |