pictcode / lib / Cake / Test / Case / Console / ShellTest.php @ 26d1f852
履歴 | 表示 | アノテート | ダウンロード (25.493 KB)
1 |
<?php
|
---|---|
2 |
/**
|
3 |
* ShellTest file
|
4 |
*
|
5 |
* Test Case for Shell
|
6 |
*
|
7 |
* CakePHP : Rapid Development Framework (http://cakephp.org)
|
8 |
* Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
9 |
*
|
10 |
* Licensed under The MIT License
|
11 |
* For full copyright and license information, please see the LICENSE.txt
|
12 |
* Redistributions of files must retain the above copyright notice.
|
13 |
*
|
14 |
* @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
|
15 |
* @link http://cakephp.org CakePHP Project
|
16 |
* @package Cake.Test.Case.Console.Command
|
17 |
* @since CakePHP v 1.2.0.7726
|
18 |
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
19 |
*/
|
20 |
|
21 |
App::uses('ShellDispatcher', 'Console'); |
22 |
App::uses('Shell', 'Console'); |
23 |
App::uses('Folder', 'Utility'); |
24 |
|
25 |
/**
|
26 |
* ShellTestShell class
|
27 |
*
|
28 |
* @package Cake.Test.Case.Console.Command
|
29 |
*/
|
30 |
class ShellTestShell extends Shell { |
31 |
|
32 |
/**
|
33 |
* name property
|
34 |
*
|
35 |
* @var name
|
36 |
*/
|
37 |
public $name = 'ShellTestShell'; |
38 |
|
39 |
/**
|
40 |
* stopped property
|
41 |
*
|
42 |
* @var int
|
43 |
*/
|
44 |
public $stopped; |
45 |
|
46 |
/**
|
47 |
* testMessage property
|
48 |
*
|
49 |
* @var string
|
50 |
*/
|
51 |
public $testMessage = 'all your base are belong to us'; |
52 |
|
53 |
/**
|
54 |
* stop method
|
55 |
*
|
56 |
* @param int $status
|
57 |
* @return void
|
58 |
*/
|
59 |
protected function _stop($status = 0) { |
60 |
$this->stopped = $status; |
61 |
} |
62 |
|
63 |
protected function _secret() { |
64 |
} |
65 |
|
66 |
//@codingStandardsIgnoreStart
|
67 |
public function do_something() { |
68 |
} |
69 |
|
70 |
protected function no_access() { |
71 |
} |
72 |
|
73 |
public function log_something() { |
74 |
$this->log($this->testMessage); |
75 |
} |
76 |
//@codingStandardsIgnoreEnd
|
77 |
|
78 |
public function mergeVars($properties, $class, $normalize = true) { |
79 |
return $this->_mergeVars($properties, $class, $normalize); |
80 |
} |
81 |
|
82 |
public function useLogger($enable = true) { |
83 |
$this->_useLogger($enable); |
84 |
} |
85 |
|
86 |
} |
87 |
|
88 |
/**
|
89 |
* Class for testing merging vars
|
90 |
*
|
91 |
* @package Cake.Test.Case.Console.Command
|
92 |
*/
|
93 |
class TestMergeShell extends Shell { |
94 |
|
95 |
public $tasks = array('DbConfig', 'Fixture'); |
96 |
|
97 |
public $uses = array('Comment'); |
98 |
|
99 |
} |
100 |
|
101 |
/**
|
102 |
* TestAppleTask class
|
103 |
*
|
104 |
* @package Cake.Test.Case.Console.Command
|
105 |
*/
|
106 |
class TestAppleTask extends Shell { |
107 |
} |
108 |
|
109 |
/**
|
110 |
* TestBananaTask class
|
111 |
*
|
112 |
* @package Cake.Test.Case.Console.Command
|
113 |
*/
|
114 |
class TestBananaTask extends Shell { |
115 |
} |
116 |
|
117 |
/**
|
118 |
* ShellTest class
|
119 |
*
|
120 |
* @package Cake.Test.Case.Console.Command
|
121 |
*/
|
122 |
class ShellTest extends CakeTestCase { |
123 |
|
124 |
/**
|
125 |
* Fixtures used in this test case
|
126 |
*
|
127 |
* @var array
|
128 |
*/
|
129 |
public $fixtures = array( |
130 |
'core.post', 'core.comment', 'core.article', 'core.user', |
131 |
'core.tag', 'core.articles_tag', 'core.attachment' |
132 |
); |
133 |
|
134 |
/**
|
135 |
* setUp method
|
136 |
*
|
137 |
* @return void
|
138 |
*/
|
139 |
public function setUp() { |
140 |
parent::setUp();
|
141 |
|
142 |
$output = $this->getMock('ConsoleOutput', array(), array(), '', false); |
143 |
$error = $this->getMock('ConsoleOutput', array(), array(), '', false); |
144 |
$in = $this->getMock('ConsoleInput', array(), array(), '', false); |
145 |
$this->Shell = new ShellTestShell($output, $error, $in); |
146 |
|
147 |
if (is_dir(TMP . 'shell_test')) { |
148 |
$Folder = new Folder(TMP . 'shell_test'); |
149 |
$Folder->delete(); |
150 |
} |
151 |
} |
152 |
|
153 |
/**
|
154 |
* testConstruct method
|
155 |
*
|
156 |
* @return void
|
157 |
*/
|
158 |
public function testConstruct() { |
159 |
$this->assertEquals('ShellTestShell', $this->Shell->name); |
160 |
$this->assertInstanceOf('ConsoleInput', $this->Shell->stdin); |
161 |
$this->assertInstanceOf('ConsoleOutput', $this->Shell->stdout); |
162 |
$this->assertInstanceOf('ConsoleOutput', $this->Shell->stderr); |
163 |
} |
164 |
|
165 |
/**
|
166 |
* test merging vars
|
167 |
*
|
168 |
* @return void
|
169 |
*/
|
170 |
public function testMergeVars() { |
171 |
$this->Shell->tasks = array('DbConfig' => array('one', 'two')); |
172 |
$this->Shell->uses = array('Posts'); |
173 |
$this->Shell->mergeVars(array('tasks'), 'TestMergeShell'); |
174 |
$this->Shell->mergeVars(array('uses'), 'TestMergeShell', false); |
175 |
|
176 |
$expected = array('DbConfig' => null, 'Fixture' => null, 'DbConfig' => array('one', 'two')); |
177 |
$this->assertEquals($expected, $this->Shell->tasks); |
178 |
|
179 |
$expected = array('Fixture' => null, 'DbConfig' => array('one', 'two')); |
180 |
$this->assertEquals($expected, Hash::normalize($this->Shell->tasks), 'Normalized results are wrong.'); |
181 |
$this->assertEquals(array('Comment', 'Posts'), $this->Shell->uses, 'Merged models are wrong.'); |
182 |
} |
183 |
|
184 |
/**
|
185 |
* testInitialize method
|
186 |
*
|
187 |
* @return void
|
188 |
*/
|
189 |
public function testInitialize() { |
190 |
App::build(array( |
191 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS), |
192 |
'Model' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS) |
193 |
), App::RESET); |
194 |
|
195 |
CakePlugin::load('TestPlugin'); |
196 |
$this->Shell->tasks = array('DbConfig' => array('one', 'two')); |
197 |
$this->Shell->uses = array('TestPlugin.TestPluginPost'); |
198 |
$this->Shell->initialize(); |
199 |
|
200 |
$this->assertTrue(isset($this->Shell->TestPluginPost)); |
201 |
$this->assertInstanceOf('TestPluginPost', $this->Shell->TestPluginPost); |
202 |
$this->assertEquals('TestPluginPost', $this->Shell->modelClass); |
203 |
CakePlugin::unload('TestPlugin'); |
204 |
|
205 |
$this->Shell->uses = array('Comment'); |
206 |
$this->Shell->initialize(); |
207 |
$this->assertTrue(isset($this->Shell->Comment)); |
208 |
$this->assertInstanceOf('Comment', $this->Shell->Comment); |
209 |
$this->assertEquals('Comment', $this->Shell->modelClass); |
210 |
$this->assertInstanceOf('DbConfigTask', $this->Shell->DbConfig); |
211 |
|
212 |
App::build();
|
213 |
} |
214 |
|
215 |
/**
|
216 |
* testLoadModel method
|
217 |
*
|
218 |
* @return void
|
219 |
*/
|
220 |
public function testLoadModel() { |
221 |
App::build(array( |
222 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS), |
223 |
'Model' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS) |
224 |
), App::RESET); |
225 |
|
226 |
$Shell = new TestMergeShell(); |
227 |
$this->assertEquals('Comment', $Shell->Comment->alias); |
228 |
$this->assertInstanceOf('Comment', $Shell->Comment); |
229 |
$this->assertEquals('Comment', $Shell->modelClass); |
230 |
|
231 |
CakePlugin::load('TestPlugin'); |
232 |
$this->Shell->loadModel('TestPlugin.TestPluginPost'); |
233 |
$this->assertTrue(isset($this->Shell->TestPluginPost)); |
234 |
$this->assertInstanceOf('TestPluginPost', $this->Shell->TestPluginPost); |
235 |
$this->assertEquals('TestPluginPost', $this->Shell->modelClass); |
236 |
CakePlugin::unload('TestPlugin'); |
237 |
|
238 |
App::build();
|
239 |
} |
240 |
|
241 |
/**
|
242 |
* testIn method
|
243 |
*
|
244 |
* @return void
|
245 |
*/
|
246 |
public function testIn() { |
247 |
$this->Shell->stdin->expects($this->at(0)) |
248 |
->method('read')
|
249 |
->will($this->returnValue('n')); |
250 |
|
251 |
$this->Shell->stdin->expects($this->at(1)) |
252 |
->method('read')
|
253 |
->will($this->returnValue('Y')); |
254 |
|
255 |
$this->Shell->stdin->expects($this->at(2)) |
256 |
->method('read')
|
257 |
->will($this->returnValue('y')); |
258 |
|
259 |
$this->Shell->stdin->expects($this->at(3)) |
260 |
->method('read')
|
261 |
->will($this->returnValue('y')); |
262 |
|
263 |
$this->Shell->stdin->expects($this->at(4)) |
264 |
->method('read')
|
265 |
->will($this->returnValue('y')); |
266 |
|
267 |
$this->Shell->stdin->expects($this->at(5)) |
268 |
->method('read')
|
269 |
->will($this->returnValue('0')); |
270 |
|
271 |
$result = $this->Shell->in('Just a test?', array('y', 'n'), 'n'); |
272 |
$this->assertEquals('n', $result); |
273 |
|
274 |
$result = $this->Shell->in('Just a test?', array('y', 'n'), 'n'); |
275 |
$this->assertEquals('Y', $result); |
276 |
|
277 |
$result = $this->Shell->in('Just a test?', 'y,n', 'n'); |
278 |
$this->assertEquals('y', $result); |
279 |
|
280 |
$result = $this->Shell->in('Just a test?', 'y/n', 'n'); |
281 |
$this->assertEquals('y', $result); |
282 |
|
283 |
$result = $this->Shell->in('Just a test?', 'y', 'y'); |
284 |
$this->assertEquals('y', $result); |
285 |
|
286 |
$result = $this->Shell->in('Just a test?', array(0, 1, 2), '0'); |
287 |
$this->assertEquals('0', $result); |
288 |
} |
289 |
|
290 |
/**
|
291 |
* Test in() when not interactive.
|
292 |
*
|
293 |
* @return void
|
294 |
*/
|
295 |
public function testInNonInteractive() { |
296 |
$this->Shell->interactive = false; |
297 |
|
298 |
$result = $this->Shell->in('Just a test?', 'y/n', 'n'); |
299 |
$this->assertEquals('n', $result); |
300 |
} |
301 |
|
302 |
/**
|
303 |
* testOut method
|
304 |
*
|
305 |
* @return void
|
306 |
*/
|
307 |
public function testOut() { |
308 |
$this->Shell->stdout->expects($this->at(0)) |
309 |
->method('write')
|
310 |
->with("Just a test", 1); |
311 |
|
312 |
$this->Shell->stdout->expects($this->at(1)) |
313 |
->method('write')
|
314 |
->with(array('Just', 'a', 'test'), 1); |
315 |
|
316 |
$this->Shell->stdout->expects($this->at(2)) |
317 |
->method('write')
|
318 |
->with(array('Just', 'a', 'test'), 2); |
319 |
|
320 |
$this->Shell->stdout->expects($this->at(3)) |
321 |
->method('write')
|
322 |
->with('', 1); |
323 |
|
324 |
$this->Shell->out('Just a test'); |
325 |
|
326 |
$this->Shell->out(array('Just', 'a', 'test')); |
327 |
|
328 |
$this->Shell->out(array('Just', 'a', 'test'), 2); |
329 |
|
330 |
$this->Shell->out(); |
331 |
} |
332 |
|
333 |
/**
|
334 |
* test that verbose and quiet output levels work
|
335 |
*
|
336 |
* @return void
|
337 |
*/
|
338 |
public function testVerboseOutput() { |
339 |
$this->Shell->stdout->expects($this->at(0))->method('write') |
340 |
->with('Verbose', 1); |
341 |
$this->Shell->stdout->expects($this->at(1))->method('write') |
342 |
->with('Normal', 1); |
343 |
$this->Shell->stdout->expects($this->at(2))->method('write') |
344 |
->with('Quiet', 1); |
345 |
|
346 |
$this->Shell->params['verbose'] = true; |
347 |
$this->Shell->params['quiet'] = false; |
348 |
|
349 |
$this->Shell->out('Verbose', 1, Shell::VERBOSE); |
350 |
$this->Shell->out('Normal', 1, Shell::NORMAL); |
351 |
$this->Shell->out('Quiet', 1, Shell::QUIET); |
352 |
} |
353 |
|
354 |
/**
|
355 |
* test that verbose and quiet output levels work
|
356 |
*
|
357 |
* @return void
|
358 |
*/
|
359 |
public function testQuietOutput() { |
360 |
$this->Shell->stdout->expects($this->once())->method('write') |
361 |
->with('Quiet', 1); |
362 |
|
363 |
$this->Shell->params['verbose'] = false; |
364 |
$this->Shell->params['quiet'] = true; |
365 |
|
366 |
$this->Shell->out('Verbose', 1, Shell::VERBOSE); |
367 |
$this->Shell->out('Normal', 1, Shell::NORMAL); |
368 |
$this->Shell->out('Quiet', 1, Shell::QUIET); |
369 |
} |
370 |
|
371 |
/**
|
372 |
* Test overwriting.
|
373 |
*
|
374 |
* @return void
|
375 |
*/
|
376 |
public function testOverwrite() { |
377 |
$number = strlen('Some text I want to overwrite'); |
378 |
|
379 |
$this->Shell->stdout->expects($this->at(0)) |
380 |
->method('write')
|
381 |
->with('Some <info>text</info> I want to overwrite', 0) |
382 |
->will($this->returnValue($number)); |
383 |
|
384 |
$this->Shell->stdout->expects($this->at(1)) |
385 |
->method('write')
|
386 |
->with(str_repeat("\x08", $number), 0); |
387 |
|
388 |
$this->Shell->stdout->expects($this->at(2)) |
389 |
->method('write')
|
390 |
->with('Less text', 0) |
391 |
->will($this->returnValue(9)); |
392 |
|
393 |
$this->Shell->stdout->expects($this->at(3)) |
394 |
->method('write')
|
395 |
->with(str_repeat(' ', $number - 9), 0); |
396 |
|
397 |
$this->Shell->out('Some <info>text</info> I want to overwrite', 0); |
398 |
$this->Shell->overwrite('Less text'); |
399 |
} |
400 |
|
401 |
/**
|
402 |
* testErr method
|
403 |
*
|
404 |
* @return void
|
405 |
*/
|
406 |
public function testErr() { |
407 |
$this->Shell->stderr->expects($this->at(0)) |
408 |
->method('write')
|
409 |
->with("Just a test", 1); |
410 |
|
411 |
$this->Shell->stderr->expects($this->at(1)) |
412 |
->method('write')
|
413 |
->with(array('Just', 'a', 'test'), 1); |
414 |
|
415 |
$this->Shell->stderr->expects($this->at(2)) |
416 |
->method('write')
|
417 |
->with(array('Just', 'a', 'test'), 2); |
418 |
|
419 |
$this->Shell->stderr->expects($this->at(3)) |
420 |
->method('write')
|
421 |
->with('', 1); |
422 |
|
423 |
$this->Shell->err('Just a test'); |
424 |
|
425 |
$this->Shell->err(array('Just', 'a', 'test')); |
426 |
|
427 |
$this->Shell->err(array('Just', 'a', 'test'), 2); |
428 |
|
429 |
$this->Shell->err(); |
430 |
} |
431 |
|
432 |
/**
|
433 |
* testNl
|
434 |
*
|
435 |
* @return void
|
436 |
*/
|
437 |
public function testNl() { |
438 |
$newLine = "\n"; |
439 |
if (DS === '\\') { |
440 |
$newLine = "\r\n"; |
441 |
} |
442 |
$this->assertEquals($this->Shell->nl(), $newLine); |
443 |
$this->assertEquals($this->Shell->nl(true), $newLine); |
444 |
$this->assertEquals("", $this->Shell->nl(false)); |
445 |
$this->assertEquals($this->Shell->nl(2), $newLine . $newLine); |
446 |
$this->assertEquals($this->Shell->nl(1), $newLine); |
447 |
} |
448 |
|
449 |
/**
|
450 |
* testHr
|
451 |
*
|
452 |
* @return void
|
453 |
*/
|
454 |
public function testHr() { |
455 |
$bar = '---------------------------------------------------------------'; |
456 |
|
457 |
$this->Shell->stdout->expects($this->at(0))->method('write')->with('', 0); |
458 |
$this->Shell->stdout->expects($this->at(1))->method('write')->with($bar, 1); |
459 |
$this->Shell->stdout->expects($this->at(2))->method('write')->with('', 0); |
460 |
|
461 |
$this->Shell->stdout->expects($this->at(3))->method('write')->with("", true); |
462 |
$this->Shell->stdout->expects($this->at(4))->method('write')->with($bar, 1); |
463 |
$this->Shell->stdout->expects($this->at(5))->method('write')->with("", true); |
464 |
|
465 |
$this->Shell->stdout->expects($this->at(6))->method('write')->with("", 2); |
466 |
$this->Shell->stdout->expects($this->at(7))->method('write')->with($bar, 1); |
467 |
$this->Shell->stdout->expects($this->at(8))->method('write')->with("", 2); |
468 |
|
469 |
$this->Shell->hr(); |
470 |
|
471 |
$this->Shell->hr(true); |
472 |
|
473 |
$this->Shell->hr(2); |
474 |
} |
475 |
|
476 |
/**
|
477 |
* testError
|
478 |
*
|
479 |
* @return void
|
480 |
*/
|
481 |
public function testError() { |
482 |
$this->Shell->stderr->expects($this->at(0)) |
483 |
->method('write')
|
484 |
->with("<error>Error:</error> Foo Not Found", 1); |
485 |
|
486 |
$this->Shell->stderr->expects($this->at(1)) |
487 |
->method('write')
|
488 |
->with("<error>Error:</error> Foo Not Found", 1); |
489 |
|
490 |
$this->Shell->stderr->expects($this->at(2)) |
491 |
->method('write')
|
492 |
->with("Searched all...", 1); |
493 |
|
494 |
$this->Shell->error('Foo Not Found'); |
495 |
$this->assertSame($this->Shell->stopped, 1); |
496 |
|
497 |
$this->Shell->stopped = null; |
498 |
|
499 |
$this->Shell->error('Foo Not Found', 'Searched all...'); |
500 |
$this->assertSame($this->Shell->stopped, 1); |
501 |
} |
502 |
|
503 |
/**
|
504 |
* testLoadTasks method
|
505 |
*
|
506 |
* @return void
|
507 |
*/
|
508 |
public function testLoadTasks() { |
509 |
$this->assertTrue($this->Shell->loadTasks()); |
510 |
|
511 |
$this->Shell->tasks = null; |
512 |
$this->assertTrue($this->Shell->loadTasks()); |
513 |
|
514 |
$this->Shell->tasks = false; |
515 |
$this->assertTrue($this->Shell->loadTasks()); |
516 |
|
517 |
$this->Shell->tasks = true; |
518 |
$this->assertTrue($this->Shell->loadTasks()); |
519 |
|
520 |
$this->Shell->tasks = array(); |
521 |
$this->assertTrue($this->Shell->loadTasks()); |
522 |
|
523 |
$this->Shell->tasks = array('TestApple'); |
524 |
$this->assertTrue($this->Shell->loadTasks()); |
525 |
$this->assertInstanceOf('TestAppleTask', $this->Shell->TestApple); |
526 |
|
527 |
$this->Shell->tasks = 'TestBanana'; |
528 |
$this->assertTrue($this->Shell->loadTasks()); |
529 |
$this->assertInstanceOf('TestAppleTask', $this->Shell->TestApple); |
530 |
$this->assertInstanceOf('TestBananaTask', $this->Shell->TestBanana); |
531 |
|
532 |
unset($this->Shell->ShellTestApple, $this->Shell->TestBanana); |
533 |
|
534 |
$this->Shell->tasks = array('TestApple', 'TestBanana'); |
535 |
$this->assertTrue($this->Shell->loadTasks()); |
536 |
$this->assertInstanceOf('TestAppleTask', $this->Shell->TestApple); |
537 |
$this->assertInstanceOf('TestBananaTask', $this->Shell->TestBanana); |
538 |
} |
539 |
|
540 |
/**
|
541 |
* test that __get() makes args and params references
|
542 |
*
|
543 |
* @return void
|
544 |
*/
|
545 |
public function testMagicGetArgAndParamReferences() { |
546 |
$this->Shell->tasks = array('TestApple'); |
547 |
$this->Shell->args = array('one'); |
548 |
$this->Shell->params = array('help' => false); |
549 |
$this->Shell->loadTasks(); |
550 |
$result = $this->Shell->TestApple; |
551 |
|
552 |
$this->Shell->args = array('one', 'two'); |
553 |
|
554 |
$this->assertSame($this->Shell->args, $result->args); |
555 |
$this->assertSame($this->Shell->params, $result->params); |
556 |
} |
557 |
|
558 |
/**
|
559 |
* testShortPath method
|
560 |
*
|
561 |
* @return void
|
562 |
*/
|
563 |
public function testShortPath() { |
564 |
$path = $expected = DS . 'tmp' . DS . 'ab' . DS . 'cd'; |
565 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
566 |
|
567 |
$path = $expected = DS . 'tmp' . DS . 'ab' . DS . 'cd' . DS; |
568 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
569 |
|
570 |
$path = $expected = DS . 'tmp' . DS . 'ab' . DS . 'index.php'; |
571 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
572 |
|
573 |
$path = DS . 'tmp' . DS . 'ab' . DS . DS . 'cd'; |
574 |
$expected = DS . 'tmp' . DS . 'ab' . DS . 'cd'; |
575 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
576 |
|
577 |
$path = 'tmp' . DS . 'ab'; |
578 |
$expected = 'tmp' . DS . 'ab'; |
579 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
580 |
|
581 |
$path = 'tmp' . DS . 'ab'; |
582 |
$expected = 'tmp' . DS . 'ab'; |
583 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
584 |
|
585 |
$path = APP; |
586 |
$expected = DS . basename(APP) . DS; |
587 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
588 |
|
589 |
$path = APP . 'index.php'; |
590 |
$expected = DS . basename(APP) . DS . 'index.php'; |
591 |
$this->assertEquals($expected, $this->Shell->shortPath($path)); |
592 |
} |
593 |
|
594 |
/**
|
595 |
* testCreateFile method
|
596 |
*
|
597 |
* @return void
|
598 |
*/
|
599 |
public function testCreateFileNonInteractive() { |
600 |
$eol = PHP_EOL; |
601 |
|
602 |
$path = TMP . 'shell_test'; |
603 |
$file = $path . DS . 'file1.php'; |
604 |
|
605 |
new Folder($path, true); |
606 |
|
607 |
$this->Shell->interactive = false; |
608 |
|
609 |
$contents = "<?php{$eol}echo 'test';${eol}\$te = 'st';{$eol}"; |
610 |
$result = $this->Shell->createFile($file, $contents); |
611 |
$this->assertTrue($result); |
612 |
$this->assertTrue(file_exists($file)); |
613 |
$this->assertEquals(file_get_contents($file), $contents); |
614 |
|
615 |
$contents = "<?php\necho 'another test';\n\$te = 'st';\n"; |
616 |
$result = $this->Shell->createFile($file, $contents); |
617 |
$this->assertTrue($result); |
618 |
$this->assertTrue(file_exists($file)); |
619 |
$this->assertTextEquals(file_get_contents($file), $contents); |
620 |
} |
621 |
|
622 |
/**
|
623 |
* test createFile when the shell is interactive.
|
624 |
*
|
625 |
* @return void
|
626 |
*/
|
627 |
public function testCreateFileInteractive() { |
628 |
$eol = PHP_EOL; |
629 |
|
630 |
$path = TMP . 'shell_test'; |
631 |
$file = $path . DS . 'file1.php'; |
632 |
new Folder($path, true); |
633 |
|
634 |
$this->Shell->interactive = true; |
635 |
|
636 |
$this->Shell->stdin->expects($this->at(0)) |
637 |
->method('read')
|
638 |
->will($this->returnValue('n')); |
639 |
|
640 |
$this->Shell->stdin->expects($this->at(1)) |
641 |
->method('read')
|
642 |
->will($this->returnValue('y')); |
643 |
|
644 |
$contents = "<?php{$eol}echo 'yet another test';{$eol}\$te = 'st';{$eol}"; |
645 |
$result = $this->Shell->createFile($file, $contents); |
646 |
$this->assertTrue($result); |
647 |
$this->assertTrue(file_exists($file)); |
648 |
$this->assertEquals(file_get_contents($file), $contents); |
649 |
|
650 |
// no overwrite
|
651 |
$contents = 'new contents'; |
652 |
$result = $this->Shell->createFile($file, $contents); |
653 |
$this->assertFalse($result); |
654 |
$this->assertTrue(file_exists($file)); |
655 |
$this->assertNotEquals($contents, file_get_contents($file)); |
656 |
|
657 |
// overwrite
|
658 |
$contents = 'more new contents'; |
659 |
$result = $this->Shell->createFile($file, $contents); |
660 |
$this->assertTrue($result); |
661 |
$this->assertTrue(file_exists($file)); |
662 |
$this->assertEquals($contents, file_get_contents($file)); |
663 |
} |
664 |
|
665 |
/**
|
666 |
* Test that you can't create files that aren't writable.
|
667 |
*
|
668 |
* @return void
|
669 |
*/
|
670 |
public function testCreateFileNoPermissions() { |
671 |
$this->skipIf(DIRECTORY_SEPARATOR === '\\', 'Cant perform operations using permissions on Windows.'); |
672 |
|
673 |
$path = TMP . 'shell_test'; |
674 |
$file = $path . DS . 'no_perms'; |
675 |
|
676 |
if (!is_dir($path)) { |
677 |
mkdir($path); |
678 |
} |
679 |
chmod($path, 0444); |
680 |
|
681 |
$this->Shell->createFile($file, 'testing'); |
682 |
$this->assertFalse(file_exists($file)); |
683 |
|
684 |
chmod($path, 0744); |
685 |
rmdir($path); |
686 |
} |
687 |
|
688 |
/**
|
689 |
* test hasTask method
|
690 |
*
|
691 |
* @return void
|
692 |
*/
|
693 |
public function testHasTask() { |
694 |
$this->Shell->tasks = array('Extract', 'DbConfig'); |
695 |
$this->Shell->loadTasks(); |
696 |
|
697 |
$this->assertTrue($this->Shell->hasTask('extract')); |
698 |
$this->assertTrue($this->Shell->hasTask('Extract')); |
699 |
$this->assertFalse($this->Shell->hasTask('random')); |
700 |
|
701 |
$this->assertTrue($this->Shell->hasTask('db_config')); |
702 |
$this->assertTrue($this->Shell->hasTask('DbConfig')); |
703 |
} |
704 |
|
705 |
/**
|
706 |
* test the hasMethod
|
707 |
*
|
708 |
* @return void
|
709 |
*/
|
710 |
public function testHasMethod() { |
711 |
$this->assertTrue($this->Shell->hasMethod('do_something')); |
712 |
$this->assertFalse($this->Shell->hasMethod('hr'), 'hr is callable'); |
713 |
$this->assertFalse($this->Shell->hasMethod('_secret'), '_secret is callable'); |
714 |
$this->assertFalse($this->Shell->hasMethod('no_access'), 'no_access is callable'); |
715 |
} |
716 |
|
717 |
/**
|
718 |
* test run command calling main.
|
719 |
*
|
720 |
* @return void
|
721 |
*/
|
722 |
public function testRunCommandMain() { |
723 |
$Mock = $this->getMock('Shell', array('main', 'startup'), array(), '', false); |
724 |
|
725 |
$Mock->expects($this->once())->method('main')->will($this->returnValue(true)); |
726 |
$result = $Mock->runCommand(null, array()); |
727 |
$this->assertTrue($result); |
728 |
} |
729 |
|
730 |
/**
|
731 |
* test run command calling a legit method.
|
732 |
*
|
733 |
* @return void
|
734 |
*/
|
735 |
public function testRunCommandWithMethod() { |
736 |
$Mock = $this->getMock('Shell', array('hit_me', 'startup'), array(), '', false); |
737 |
|
738 |
$Mock->expects($this->once())->method('hit_me')->will($this->returnValue(true)); |
739 |
$result = $Mock->runCommand('hit_me', array()); |
740 |
$this->assertTrue($result); |
741 |
} |
742 |
|
743 |
/**
|
744 |
* test run command causing exception on Shell method.
|
745 |
*
|
746 |
* @return void
|
747 |
*/
|
748 |
public function testRunCommandBaseclassMethod() { |
749 |
$Mock = $this->getMock('Shell', array('startup', 'getOptionParser', 'out'), array(), '', false); |
750 |
$Parser = $this->getMock('ConsoleOptionParser', array(), array(), '', false); |
751 |
|
752 |
$Parser->expects($this->once())->method('help'); |
753 |
$Mock->expects($this->once())->method('getOptionParser') |
754 |
->will($this->returnValue($Parser)); |
755 |
$Mock->expects($this->never())->method('hr'); |
756 |
$Mock->expects($this->once())->method('out'); |
757 |
|
758 |
$Mock->runCommand('hr', array()); |
759 |
} |
760 |
|
761 |
/**
|
762 |
* test run command causing exception on Shell method.
|
763 |
*
|
764 |
* @return void
|
765 |
*/
|
766 |
public function testRunCommandMissingMethod() { |
767 |
$Mock = $this->getMock('Shell', array('startup', 'getOptionParser', 'out'), array(), '', false); |
768 |
$Parser = $this->getMock('ConsoleOptionParser', array(), array(), '', false); |
769 |
|
770 |
$Parser->expects($this->once())->method('help'); |
771 |
$Mock->expects($this->never())->method('idontexist'); |
772 |
$Mock->expects($this->once())->method('getOptionParser') |
773 |
->will($this->returnValue($Parser)); |
774 |
$Mock->expects($this->once())->method('out'); |
775 |
|
776 |
$result = $Mock->runCommand('idontexist', array()); |
777 |
$this->assertFalse($result); |
778 |
} |
779 |
|
780 |
/**
|
781 |
* test that a --help causes help to show.
|
782 |
*
|
783 |
* @return void
|
784 |
*/
|
785 |
public function testRunCommandTriggeringHelp() { |
786 |
$Parser = $this->getMock('ConsoleOptionParser', array(), array(), '', false); |
787 |
$Parser->expects($this->once())->method('parse') |
788 |
->with(array('--help')) |
789 |
->will($this->returnValue(array(array('help' => true), array()))); |
790 |
$Parser->expects($this->once())->method('help'); |
791 |
|
792 |
$Shell = $this->getMock('Shell', array('getOptionParser', 'out', 'startup', '_welcome'), array(), '', false); |
793 |
$Shell->expects($this->once())->method('getOptionParser') |
794 |
->will($this->returnValue($Parser)); |
795 |
$Shell->expects($this->once())->method('out'); |
796 |
|
797 |
$Shell->runCommand(null, array('--help')); |
798 |
} |
799 |
|
800 |
/**
|
801 |
* test that runCommand will call runCommand on the task.
|
802 |
*
|
803 |
* @return void
|
804 |
*/
|
805 |
public function testRunCommandHittingTask() { |
806 |
$Shell = $this->getMock('Shell', array('hasTask', 'startup'), array(), '', false); |
807 |
$task = $this->getMock('Shell', array('execute', 'runCommand'), array(), '', false); |
808 |
$task->expects($this->any()) |
809 |
->method('runCommand')
|
810 |
->with('execute', array('one', 'value')); |
811 |
|
812 |
$Shell->expects($this->once())->method('startup'); |
813 |
$Shell->expects($this->any()) |
814 |
->method('hasTask')
|
815 |
->will($this->returnValue(true)); |
816 |
|
817 |
$Shell->RunCommand = $task; |
818 |
|
819 |
$Shell->runCommand('run_command', array('run_command', 'one', 'value')); |
820 |
} |
821 |
|
822 |
/**
|
823 |
* test wrapBlock wrapping text.
|
824 |
*
|
825 |
* @return void
|
826 |
*/
|
827 |
public function testWrapText() { |
828 |
$text = 'This is the song that never ends. This is the song that never ends. This is the song that never ends.'; |
829 |
$result = $this->Shell->wrapText($text, 33); |
830 |
$expected = <<<TEXT |
831 |
This is the song that never ends.
|
832 |
This is the song that never ends.
|
833 |
This is the song that never ends.
|
834 |
TEXT;
|
835 |
$this->assertTextEquals($expected, $result, 'Text not wrapped.'); |
836 |
|
837 |
$result = $this->Shell->wrapText($text, array('indent' => ' ', 'width' => 33)); |
838 |
$expected = <<<TEXT |
839 |
This is the song that never ends.
|
840 |
This is the song that never ends.
|
841 |
This is the song that never ends.
|
842 |
TEXT;
|
843 |
$this->assertTextEquals($expected, $result, 'Text not wrapped.'); |
844 |
} |
845 |
|
846 |
/**
|
847 |
* Testing camel cased naming of tasks
|
848 |
*
|
849 |
* @return void
|
850 |
*/
|
851 |
public function testShellNaming() { |
852 |
$this->Shell->tasks = array('TestApple'); |
853 |
$this->Shell->loadTasks(); |
854 |
$expected = 'TestApple'; |
855 |
$this->assertEquals($expected, $this->Shell->TestApple->name); |
856 |
} |
857 |
|
858 |
/**
|
859 |
* Test reading params
|
860 |
*
|
861 |
* @dataProvider paramReadingDataProvider
|
862 |
*/
|
863 |
public function testParamReading($toRead, $expected) { |
864 |
$this->Shell->params = array( |
865 |
'key' => 'value', |
866 |
'help' => false, |
867 |
'emptykey' => '', |
868 |
'truthy' => true |
869 |
); |
870 |
$this->assertSame($expected, $this->Shell->param($toRead)); |
871 |
} |
872 |
|
873 |
/**
|
874 |
* Data provider for testing reading values with Shell::param()
|
875 |
*
|
876 |
* @return array
|
877 |
*/
|
878 |
public function paramReadingDataProvider() { |
879 |
return array( |
880 |
array(
|
881 |
'key',
|
882 |
'value',
|
883 |
), |
884 |
array(
|
885 |
'help',
|
886 |
false,
|
887 |
), |
888 |
array(
|
889 |
'emptykey',
|
890 |
'',
|
891 |
), |
892 |
array(
|
893 |
'truthy',
|
894 |
true,
|
895 |
), |
896 |
array(
|
897 |
'does_not_exist',
|
898 |
null,
|
899 |
) |
900 |
); |
901 |
} |
902 |
|
903 |
/**
|
904 |
* Test that option parsers are created with the correct name/command.
|
905 |
*
|
906 |
* @return void
|
907 |
*/
|
908 |
public function testGetOptionParser() { |
909 |
$this->Shell->name = 'test'; |
910 |
$this->Shell->plugin = 'plugin'; |
911 |
$parser = $this->Shell->getOptionParser(); |
912 |
|
913 |
$this->assertEquals('plugin.test', $parser->command()); |
914 |
} |
915 |
|
916 |
/**
|
917 |
* Test file and console and logging
|
918 |
*
|
919 |
* @return void
|
920 |
*/
|
921 |
public function testFileAndConsoleLogging() { |
922 |
// file logging
|
923 |
$this->Shell->log_something(); |
924 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
925 |
|
926 |
unlink(LOGS . 'error.log'); |
927 |
$this->assertFalse(file_exists(LOGS . 'error.log')); |
928 |
|
929 |
// both file and console logging
|
930 |
require_once CORE_TEST_CASES . DS . 'Log' . DS . 'Engine' . DS . 'ConsoleLogTest.php'; |
931 |
$mock = $this->getMock('ConsoleLog', array('write'), array( |
932 |
array('types' => 'error'), |
933 |
)); |
934 |
TestCakeLog::config('console', array( |
935 |
'engine' => 'Console', |
936 |
'stream' => 'php://stderr', |
937 |
)); |
938 |
TestCakeLog::replace('console', $mock); |
939 |
$mock->expects($this->once()) |
940 |
->method('write')
|
941 |
->with('error', $this->Shell->testMessage); |
942 |
$this->Shell->log_something(); |
943 |
$this->assertTrue(file_exists(LOGS . 'error.log')); |
944 |
$contents = file_get_contents(LOGS . 'error.log'); |
945 |
$this->assertContains($this->Shell->testMessage, $contents); |
946 |
} |
947 |
|
948 |
/**
|
949 |
* Tests that _useLogger works properly
|
950 |
*
|
951 |
* @return void
|
952 |
*/
|
953 |
public function testProtectedUseLogger() { |
954 |
CakeLog::drop('stdout'); |
955 |
CakeLog::drop('stderr'); |
956 |
$this->Shell->useLogger(true); |
957 |
$this->assertNotEmpty(CakeLog::stream('stdout')); |
958 |
$this->assertNotEmpty(CakeLog::stream('stderr')); |
959 |
$this->Shell->useLogger(false); |
960 |
$this->assertFalse(CakeLog::stream('stdout')); |
961 |
$this->assertFalse(CakeLog::stream('stderr')); |
962 |
} |
963 |
|
964 |
/**
|
965 |
* Test file and console and logging quiet output
|
966 |
*
|
967 |
* @return void
|
968 |
*/
|
969 |
public function testQuietLog() { |
970 |
$output = $this->getMock('ConsoleOutput', array(), array(), '', false); |
971 |
$error = $this->getMock('ConsoleOutput', array(), array(), '', false); |
972 |
$in = $this->getMock('ConsoleInput', array(), array(), '', false); |
973 |
$this->Shell = $this->getMock('ShellTestShell', array('_useLogger'), array($output, $error, $in)); |
974 |
$this->Shell->expects($this->once())->method('_useLogger')->with(false); |
975 |
$this->Shell->runCommand('foo', array('--quiet')); |
976 |
} |
977 |
|
978 |
} |