pictcode / lib / Cake / Test / Case / Console / Command / SchemaShellTest.php @ 26d1f852
履歴 | 表示 | アノテート | ダウンロード (20.355 KB)
1 |
<?php
|
---|---|
2 |
/**
|
3 |
* SchemaShellTest Test file
|
4 |
*
|
5 |
* CakePHP : Rapid Development Framework (http://cakephp.org)
|
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://cakephp.org CakePHP Project
|
14 |
* @package Cake.Test.Case.Console.Command
|
15 |
* @since CakePHP v 1.3
|
16 |
* @license http://www.opensource.org/licenses/mit-license.php MIT License
|
17 |
*/
|
18 |
|
19 |
App::uses('ShellDispatcher', 'Console'); |
20 |
App::uses('ConsoleOutput', 'Console'); |
21 |
App::uses('ConsoleInput', 'Console'); |
22 |
App::uses('Shell', 'Console'); |
23 |
App::uses('CakeSchema', 'Model'); |
24 |
App::uses('SchemaShell', 'Console/Command'); |
25 |
|
26 |
/**
|
27 |
* Test for Schema database management
|
28 |
*
|
29 |
* @package Cake.Test.Case.Console.Command
|
30 |
*/
|
31 |
class SchemaShellTestSchema extends CakeSchema { |
32 |
|
33 |
/**
|
34 |
* connection property
|
35 |
*
|
36 |
* @var string
|
37 |
*/
|
38 |
public $connection = 'test'; |
39 |
|
40 |
/**
|
41 |
* comments property
|
42 |
*
|
43 |
* @var array
|
44 |
*/
|
45 |
public $comments = array( |
46 |
'id' => array('type' => 'integer', 'null' => false, 'default' => 0, 'key' => 'primary'), |
47 |
'post_id' => array('type' => 'integer', 'null' => false, 'default' => 0), |
48 |
'user_id' => array('type' => 'integer', 'null' => false), |
49 |
'title' => array('type' => 'string', 'null' => false, 'length' => 100), |
50 |
'comment' => array('type' => 'text', 'null' => false, 'default' => null), |
51 |
'published' => array('type' => 'string', 'null' => true, 'default' => 'N', 'length' => 1), |
52 |
'created' => array('type' => 'datetime', 'null' => true, 'default' => null), |
53 |
'updated' => array('type' => 'datetime', 'null' => true, 'default' => null), |
54 |
'indexes' => array('PRIMARY' => array('column' => 'id', 'unique' => true)), |
55 |
); |
56 |
|
57 |
/**
|
58 |
* posts property
|
59 |
*
|
60 |
* @var array
|
61 |
*/
|
62 |
public $articles = array( |
63 |
'id' => array('type' => 'integer', 'null' => false, 'default' => 0, 'key' => 'primary'), |
64 |
'user_id' => array('type' => 'integer', 'null' => true, 'default' => ''), |
65 |
'title' => array('type' => 'string', 'null' => false, 'default' => 'Title'), |
66 |
'body' => array('type' => 'text', 'null' => true, 'default' => null), |
67 |
'summary' => array('type' => 'text', 'null' => true), |
68 |
'published' => array('type' => 'string', 'null' => true, 'default' => 'Y', 'length' => 1), |
69 |
'created' => array('type' => 'datetime', 'null' => true, 'default' => null), |
70 |
'updated' => array('type' => 'datetime', 'null' => true, 'default' => null), |
71 |
'indexes' => array('PRIMARY' => array('column' => 'id', 'unique' => true)), |
72 |
); |
73 |
|
74 |
public $newone = array( |
75 |
'id' => array('type' => 'integer', 'null' => false, 'default' => 0, 'key' => 'primary'), |
76 |
'testit' => array('type' => 'string', 'null' => false, 'default' => 'Title'), |
77 |
'created' => array('type' => 'datetime', 'null' => true, 'default' => null), |
78 |
'updated' => array('type' => 'datetime', 'null' => true, 'default' => null), |
79 |
'indexes' => array('PRIMARY' => array('column' => 'id', 'unique' => true)), |
80 |
); |
81 |
} |
82 |
|
83 |
/**
|
84 |
* SchemaShellTest class
|
85 |
*
|
86 |
* @package Cake.Test.Case.Console.Command
|
87 |
*/
|
88 |
class SchemaShellTest extends CakeTestCase { |
89 |
|
90 |
/**
|
91 |
* Fixtures
|
92 |
*
|
93 |
* @var array
|
94 |
*/
|
95 |
public $fixtures = array( |
96 |
'core.article', 'core.user', 'core.post', 'core.auth_user', 'core.author', |
97 |
'core.comment', 'core.test_plugin_comment', 'core.aco', 'core.aro', 'core.aros_aco', |
98 |
); |
99 |
|
100 |
/**
|
101 |
* setUp method
|
102 |
*
|
103 |
* @return void
|
104 |
*/
|
105 |
public function setUp() { |
106 |
parent::setUp();
|
107 |
|
108 |
$out = $this->getMock('ConsoleOutput', array(), array(), '', false); |
109 |
$in = $this->getMock('ConsoleInput', array(), array(), '', false); |
110 |
$this->Shell = $this->getMock( |
111 |
'SchemaShell',
|
112 |
array('in', 'out', 'hr', 'createFile', 'error', 'err', '_stop'), |
113 |
array($out, $out, $in) |
114 |
); |
115 |
} |
116 |
|
117 |
/**
|
118 |
* tearDown method
|
119 |
*
|
120 |
* @return void
|
121 |
*/
|
122 |
public function tearDown() { |
123 |
parent::tearDown();
|
124 |
if (!empty($this->file) && $this->file instanceof File) { |
125 |
$this->file->delete(); |
126 |
unset($this->file); |
127 |
} |
128 |
} |
129 |
|
130 |
/**
|
131 |
* test startup method
|
132 |
*
|
133 |
* @return void
|
134 |
*/
|
135 |
public function testStartup() { |
136 |
$this->Shell->startup(); |
137 |
$this->assertTrue(isset($this->Shell->Schema)); |
138 |
$this->assertInstanceOf('CakeSchema', $this->Shell->Schema); |
139 |
$this->assertEquals(Inflector::camelize(Inflector::slug(APP_DIR)), $this->Shell->Schema->name); |
140 |
$this->assertEquals('schema.php', $this->Shell->Schema->file); |
141 |
|
142 |
$this->Shell->Schema = null; |
143 |
$this->Shell->params = array( |
144 |
'name' => 'TestSchema' |
145 |
); |
146 |
$this->Shell->startup(); |
147 |
$this->assertEquals('TestSchema', $this->Shell->Schema->name); |
148 |
$this->assertEquals('test_schema.php', $this->Shell->Schema->file); |
149 |
$this->assertEquals('default', $this->Shell->Schema->connection); |
150 |
$this->assertEquals(APP . 'Config' . DS . 'Schema', $this->Shell->Schema->path); |
151 |
|
152 |
$this->Shell->Schema = null; |
153 |
$this->Shell->params = array( |
154 |
'file' => 'other_file.php', |
155 |
'connection' => 'test', |
156 |
'path' => '/test/path' |
157 |
); |
158 |
$this->Shell->startup(); |
159 |
$this->assertEquals(Inflector::camelize(Inflector::slug(APP_DIR)), $this->Shell->Schema->name); |
160 |
$this->assertEquals('other_file.php', $this->Shell->Schema->file); |
161 |
$this->assertEquals('test', $this->Shell->Schema->connection); |
162 |
$this->assertEquals('/test/path', $this->Shell->Schema->path); |
163 |
} |
164 |
|
165 |
/**
|
166 |
* Test View - and that it dumps the schema file to stdout
|
167 |
*
|
168 |
* @return void
|
169 |
*/
|
170 |
public function testView() { |
171 |
$this->Shell->startup(); |
172 |
$this->Shell->Schema->path = APP . 'Config' . DS . 'Schema'; |
173 |
$this->Shell->params['file'] = 'i18n.php'; |
174 |
$this->Shell->expects($this->once())->method('_stop'); |
175 |
$this->Shell->expects($this->once())->method('out'); |
176 |
$this->Shell->view(); |
177 |
} |
178 |
|
179 |
/**
|
180 |
* test that view() can find plugin schema files.
|
181 |
*
|
182 |
* @return void
|
183 |
*/
|
184 |
public function testViewWithPlugins() { |
185 |
App::build(array( |
186 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
187 |
)); |
188 |
CakePlugin::load('TestPlugin'); |
189 |
$this->Shell->args = array('TestPlugin.schema'); |
190 |
$this->Shell->startup(); |
191 |
$this->Shell->expects($this->exactly(2))->method('_stop'); |
192 |
$this->Shell->expects($this->atLeastOnce())->method('out'); |
193 |
$this->Shell->view(); |
194 |
|
195 |
$this->Shell->args = array(); |
196 |
$this->Shell->params = array('plugin' => 'TestPlugin'); |
197 |
$this->Shell->startup(); |
198 |
$this->Shell->view(); |
199 |
|
200 |
App::build();
|
201 |
CakePlugin::unload();
|
202 |
} |
203 |
|
204 |
/**
|
205 |
* test dump() with sql file generation
|
206 |
*
|
207 |
* @return void
|
208 |
*/
|
209 |
public function testDumpWithFileWriting() { |
210 |
$this->Shell->params = array( |
211 |
'name' => 'i18n', |
212 |
'connection' => 'test', |
213 |
'write' => TMP . 'tests' . DS . 'i18n.sql' |
214 |
); |
215 |
$this->Shell->expects($this->once())->method('_stop'); |
216 |
$this->Shell->startup(); |
217 |
$this->Shell->dump(); |
218 |
|
219 |
$this->file = new File(TMP . 'tests' . DS . 'i18n.sql'); |
220 |
$contents = $this->file->read(); |
221 |
$this->assertRegExp('/DROP TABLE/', $contents); |
222 |
$this->assertRegExp('/CREATE TABLE.*?i18n/', $contents); |
223 |
$this->assertRegExp('/id/', $contents); |
224 |
$this->assertRegExp('/model/', $contents); |
225 |
$this->assertRegExp('/field/', $contents); |
226 |
$this->assertRegExp('/locale/', $contents); |
227 |
$this->assertRegExp('/foreign_key/', $contents); |
228 |
$this->assertRegExp('/content/', $contents); |
229 |
} |
230 |
|
231 |
/**
|
232 |
* test that dump() can find and work with plugin schema files.
|
233 |
*
|
234 |
* @return void
|
235 |
*/
|
236 |
public function testDumpFileWritingWithPlugins() { |
237 |
App::build(array( |
238 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
239 |
)); |
240 |
CakePlugin::load('TestPlugin'); |
241 |
$this->Shell->args = array('TestPlugin.TestPluginApp'); |
242 |
$this->Shell->params = array( |
243 |
'connection' => 'test', |
244 |
'write' => TMP . 'tests' . DS . 'dump_test.sql' |
245 |
); |
246 |
$this->Shell->startup(); |
247 |
$this->Shell->expects($this->once())->method('_stop'); |
248 |
$this->Shell->dump(); |
249 |
|
250 |
$this->file = new File(TMP . 'tests' . DS . 'dump_test.sql'); |
251 |
$contents = $this->file->read(); |
252 |
|
253 |
$this->assertRegExp('/CREATE TABLE.*?test_plugin_acos/', $contents); |
254 |
$this->assertRegExp('/id/', $contents); |
255 |
$this->assertRegExp('/model/', $contents); |
256 |
|
257 |
$this->file->delete(); |
258 |
App::build();
|
259 |
CakePlugin::unload();
|
260 |
} |
261 |
|
262 |
/**
|
263 |
* test generate with snapshot generation
|
264 |
*
|
265 |
* @return void
|
266 |
*/
|
267 |
public function testGenerateSnapshot() { |
268 |
$this->Shell->path = TMP; |
269 |
$this->Shell->params['file'] = 'schema.php'; |
270 |
$this->Shell->params['force'] = false; |
271 |
$this->Shell->args = array('snapshot'); |
272 |
$this->Shell->Schema = $this->getMock('CakeSchema'); |
273 |
$this->Shell->Schema->expects($this->at(0))->method('read')->will($this->returnValue(array('schema data'))); |
274 |
$this->Shell->Schema->expects($this->at(0))->method('write')->will($this->returnValue(true)); |
275 |
|
276 |
$this->Shell->Schema->expects($this->at(1))->method('read'); |
277 |
$this->Shell->Schema->expects($this->at(1))->method('write')->with(array('schema data', 'file' => 'schema_0.php')); |
278 |
|
279 |
$this->Shell->generate(); |
280 |
} |
281 |
|
282 |
/**
|
283 |
* test generate without a snapshot.
|
284 |
*
|
285 |
* @return void
|
286 |
*/
|
287 |
public function testGenerateNoOverwrite() { |
288 |
touch(TMP . 'schema.php'); |
289 |
$this->Shell->params['file'] = 'schema.php'; |
290 |
$this->Shell->params['force'] = false; |
291 |
$this->Shell->args = array(); |
292 |
|
293 |
$this->Shell->expects($this->once())->method('in')->will($this->returnValue('q')); |
294 |
$this->Shell->Schema = $this->getMock('CakeSchema'); |
295 |
$this->Shell->Schema->path = TMP; |
296 |
$this->Shell->Schema->expects($this->never())->method('read'); |
297 |
|
298 |
$this->Shell->generate(); |
299 |
unlink(TMP . 'schema.php'); |
300 |
} |
301 |
|
302 |
/**
|
303 |
* test generate with overwriting of the schema files.
|
304 |
*
|
305 |
* @return void
|
306 |
*/
|
307 |
public function testGenerateOverwrite() { |
308 |
touch(TMP . 'schema.php'); |
309 |
$this->Shell->params['file'] = 'schema.php'; |
310 |
$this->Shell->params['force'] = false; |
311 |
$this->Shell->args = array(); |
312 |
|
313 |
$this->Shell->expects($this->once())->method('in')->will($this->returnValue('o')); |
314 |
|
315 |
$this->Shell->expects($this->at(2))->method('out') |
316 |
->with(new PHPUnit_Framework_Constraint_PCREMatch('/Schema file:\s[a-z\.]+\sgenerated/')); |
317 |
|
318 |
$this->Shell->Schema = $this->getMock('CakeSchema'); |
319 |
$this->Shell->Schema->path = TMP; |
320 |
$this->Shell->Schema->expects($this->once())->method('read')->will($this->returnValue(array('schema data'))); |
321 |
$this->Shell->Schema->expects($this->once())->method('write')->will($this->returnValue(true)); |
322 |
|
323 |
$this->Shell->Schema->expects($this->once())->method('read'); |
324 |
$this->Shell->Schema->expects($this->once())->method('write') |
325 |
->with(array('schema data', 'file' => 'schema.php')); |
326 |
|
327 |
$this->Shell->generate(); |
328 |
unlink(TMP . 'schema.php'); |
329 |
} |
330 |
|
331 |
/**
|
332 |
* test that generate() can read plugin dirs and generate schema files for the models
|
333 |
* in a plugin.
|
334 |
*
|
335 |
* @return void
|
336 |
*/
|
337 |
public function testGenerateWithPlugins() { |
338 |
App::build(array( |
339 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
340 |
), App::RESET); |
341 |
CakePlugin::load('TestPlugin'); |
342 |
|
343 |
$this->db->cacheSources = false; |
344 |
$this->Shell->params = array( |
345 |
'plugin' => 'TestPlugin', |
346 |
'connection' => 'test', |
347 |
'force' => false |
348 |
); |
349 |
$this->Shell->startup(); |
350 |
$this->Shell->Schema->path = TMP . 'tests' . DS; |
351 |
|
352 |
$this->Shell->generate(); |
353 |
$this->file = new File(TMP . 'tests' . DS . 'schema.php'); |
354 |
$contents = $this->file->read(); |
355 |
|
356 |
$this->assertRegExp('/class TestPluginSchema/', $contents); |
357 |
$this->assertRegExp('/public \$posts/', $contents); |
358 |
$this->assertRegExp('/public \$auth_users/', $contents); |
359 |
$this->assertRegExp('/public \$authors/', $contents); |
360 |
$this->assertRegExp('/public \$test_plugin_comments/', $contents); |
361 |
$this->assertNotRegExp('/public \$users/', $contents); |
362 |
$this->assertNotRegExp('/public \$articles/', $contents); |
363 |
CakePlugin::unload();
|
364 |
} |
365 |
|
366 |
/**
|
367 |
* test generate with specific models
|
368 |
*
|
369 |
* @return void
|
370 |
*/
|
371 |
public function testGenerateModels() { |
372 |
App::build(array( |
373 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
374 |
), App::RESET); |
375 |
CakePlugin::load('TestPlugin'); |
376 |
|
377 |
$this->db->cacheSources = false; |
378 |
$this->Shell->params = array( |
379 |
'plugin' => 'TestPlugin', |
380 |
'connection' => 'test', |
381 |
'models' => 'TestPluginComment', |
382 |
'force' => false, |
383 |
'overwrite' => true |
384 |
); |
385 |
$this->Shell->startup(); |
386 |
$this->Shell->Schema->path = TMP . 'tests' . DS; |
387 |
|
388 |
$this->Shell->generate(); |
389 |
$this->file = new File(TMP . 'tests' . DS . 'schema.php'); |
390 |
$contents = $this->file->read(); |
391 |
|
392 |
$this->assertRegExp('/class TestPluginSchema/', $contents); |
393 |
$this->assertRegExp('/public \$test_plugin_comments/', $contents); |
394 |
$this->assertNotRegExp('/public \$authors/', $contents); |
395 |
$this->assertNotRegExp('/public \$auth_users/', $contents); |
396 |
$this->assertNotRegExp('/public \$posts/', $contents); |
397 |
CakePlugin::unload();
|
398 |
} |
399 |
|
400 |
/**
|
401 |
* test generate with excluded tables
|
402 |
*
|
403 |
* @return void
|
404 |
*/
|
405 |
public function testGenerateExclude() { |
406 |
Configure::write('Acl.database', 'test'); |
407 |
$this->db->cacheSources = false; |
408 |
$this->Shell->params = array( |
409 |
'connection' => 'test', |
410 |
'force' => false, |
411 |
'models' => 'Aro, Aco, Permission', |
412 |
'overwrite' => true, |
413 |
'exclude' => 'acos, aros', |
414 |
); |
415 |
$this->Shell->startup(); |
416 |
$this->Shell->Schema->path = TMP . 'tests' . DS; |
417 |
|
418 |
$this->Shell->generate(); |
419 |
$this->file = new File(TMP . 'tests' . DS . 'schema.php'); |
420 |
$contents = $this->file->read(); |
421 |
|
422 |
$this->assertNotContains('public $acos = array(', $contents); |
423 |
$this->assertNotContains('public $aros = array(', $contents); |
424 |
$this->assertContains('public $aros_acos = array(', $contents); |
425 |
} |
426 |
|
427 |
/**
|
428 |
* Test schema run create with --yes option
|
429 |
*
|
430 |
* @return void
|
431 |
*/
|
432 |
public function testCreateOptionYes() { |
433 |
$this->Shell = $this->getMock( |
434 |
'SchemaShell',
|
435 |
array('in', 'out', 'hr', 'createFile', 'error', 'err', '_stop', '_run'), |
436 |
array(&$this->Dispatcher) |
437 |
); |
438 |
|
439 |
$this->Shell->params = array( |
440 |
'connection' => 'test', |
441 |
'yes' => true, |
442 |
); |
443 |
$this->Shell->args = array('i18n'); |
444 |
$this->Shell->expects($this->never())->method('in'); |
445 |
$this->Shell->expects($this->exactly(2))->method('_run'); |
446 |
$this->Shell->startup(); |
447 |
$this->Shell->create(); |
448 |
} |
449 |
|
450 |
/**
|
451 |
* Test schema run create with no table args.
|
452 |
*
|
453 |
* @return void
|
454 |
*/
|
455 |
public function testCreateNoArgs() { |
456 |
$this->Shell->params = array( |
457 |
'connection' => 'test' |
458 |
); |
459 |
$this->Shell->args = array('i18n'); |
460 |
$this->Shell->startup(); |
461 |
$this->Shell->expects($this->any())->method('in')->will($this->returnValue('y')); |
462 |
$this->Shell->create(); |
463 |
|
464 |
$db = ConnectionManager::getDataSource('test'); |
465 |
|
466 |
$db->cacheSources = false; |
467 |
$sources = $db->listSources(); |
468 |
$this->assertTrue(in_array($db->config['prefix'] . 'i18n', $sources)); |
469 |
|
470 |
$schema = new i18nSchema(); |
471 |
$db->execute($db->dropSchema($schema)); |
472 |
} |
473 |
|
474 |
/**
|
475 |
* Test schema run create with no table args.
|
476 |
*
|
477 |
* @return void
|
478 |
*/
|
479 |
public function testCreateWithTableArgs() { |
480 |
$db = ConnectionManager::getDataSource('test'); |
481 |
$sources = $db->listSources(); |
482 |
if (in_array('i18n', $sources)) { |
483 |
$this->markTestSkipped('i18n table already exists, cannot try to create it again.'); |
484 |
} |
485 |
$this->Shell->params = array( |
486 |
'connection' => 'test', |
487 |
'name' => 'I18n', |
488 |
'path' => APP . 'Config' . DS . 'Schema' |
489 |
); |
490 |
$this->Shell->args = array('I18n', 'i18n'); |
491 |
$this->Shell->startup(); |
492 |
$this->Shell->expects($this->any())->method('in')->will($this->returnValue('y')); |
493 |
$this->Shell->create(); |
494 |
|
495 |
$db = ConnectionManager::getDataSource('test'); |
496 |
$db->cacheSources = false; |
497 |
$sources = $db->listSources(); |
498 |
$this->assertTrue(in_array($db->config['prefix'] . 'i18n', $sources), 'i18n should be present.'); |
499 |
|
500 |
$schema = new I18nSchema(); |
501 |
$db->execute($db->dropSchema($schema, 'i18n')); |
502 |
} |
503 |
|
504 |
/**
|
505 |
* test run update with a table arg.
|
506 |
*
|
507 |
* @return void
|
508 |
*/
|
509 |
public function testUpdateWithTable() { |
510 |
$this->Shell = $this->getMock( |
511 |
'SchemaShell',
|
512 |
array('in', 'out', 'hr', 'createFile', 'error', 'err', '_stop', '_run'), |
513 |
array(&$this->Dispatcher) |
514 |
); |
515 |
|
516 |
$this->Shell->params = array( |
517 |
'connection' => 'test', |
518 |
'force' => true |
519 |
); |
520 |
$this->Shell->args = array('SchemaShellTest', 'articles'); |
521 |
$this->Shell->startup(); |
522 |
$this->Shell->expects($this->any()) |
523 |
->method('in')
|
524 |
->will($this->returnValue('y')); |
525 |
$this->Shell->expects($this->once()) |
526 |
->method('_run')
|
527 |
->with($this->arrayHasKey('articles'), 'update', $this->isInstanceOf('CakeSchema')); |
528 |
|
529 |
$this->Shell->update(); |
530 |
} |
531 |
|
532 |
/**
|
533 |
* test run update with a table arg. and checks that a CREATE statement is issued
|
534 |
* table creation
|
535 |
* @return void
|
536 |
*/
|
537 |
public function testUpdateWithTableCreate() { |
538 |
$this->Shell = $this->getMock( |
539 |
'SchemaShell',
|
540 |
array('in', 'out', 'hr', 'createFile', 'error', 'err', '_stop', '_run'), |
541 |
array(&$this->Dispatcher) |
542 |
); |
543 |
|
544 |
$this->Shell->params = array( |
545 |
'connection' => 'test', |
546 |
'force' => true |
547 |
); |
548 |
$this->Shell->args = array('SchemaShellTest', 'newone'); |
549 |
$this->Shell->startup(); |
550 |
$this->Shell->expects($this->any()) |
551 |
->method('in')
|
552 |
->will($this->returnValue('y')); |
553 |
$this->Shell->expects($this->once()) |
554 |
->method('_run')
|
555 |
->with($this->arrayHasKey('newone'), 'update', $this->isInstanceOf('CakeSchema')); |
556 |
|
557 |
$this->Shell->update(); |
558 |
} |
559 |
|
560 |
/**
|
561 |
* test run update with --yes option
|
562 |
*
|
563 |
* @return void
|
564 |
*/
|
565 |
public function testUpdateWithOptionYes() { |
566 |
$this->Shell = $this->getMock( |
567 |
'SchemaShell',
|
568 |
array('in', 'out', 'hr', 'createFile', 'error', 'err', '_stop', '_run'), |
569 |
array(&$this->Dispatcher) |
570 |
); |
571 |
|
572 |
$this->Shell->params = array( |
573 |
'connection' => 'test', |
574 |
'force' => true, |
575 |
'yes' => true, |
576 |
); |
577 |
$this->Shell->args = array('SchemaShellTest', 'articles'); |
578 |
$this->Shell->startup(); |
579 |
$this->Shell->expects($this->never())->method('in'); |
580 |
$this->Shell->expects($this->once()) |
581 |
->method('_run')
|
582 |
->with($this->arrayHasKey('articles'), 'update', $this->isInstanceOf('CakeSchema')); |
583 |
|
584 |
$this->Shell->update(); |
585 |
} |
586 |
|
587 |
/**
|
588 |
* test that the plugin param creates the correct path in the schema object.
|
589 |
*
|
590 |
* @return void
|
591 |
*/
|
592 |
public function testPluginParam() { |
593 |
App::build(array( |
594 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
595 |
)); |
596 |
CakePlugin::load('TestPlugin'); |
597 |
$this->Shell->params = array( |
598 |
'plugin' => 'TestPlugin', |
599 |
'connection' => 'test' |
600 |
); |
601 |
$this->Shell->startup(); |
602 |
$expected = CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS . 'TestPlugin' . DS . 'Config' . DS . 'Schema'; |
603 |
$this->assertEquals($expected, $this->Shell->Schema->path); |
604 |
CakePlugin::unload();
|
605 |
} |
606 |
|
607 |
/**
|
608 |
* test that underscored names also result in CamelCased class names
|
609 |
*
|
610 |
* @return void
|
611 |
*/
|
612 |
public function testName() { |
613 |
App::build(array( |
614 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
615 |
)); |
616 |
CakePlugin::load('TestPlugin'); |
617 |
$this->Shell->params = array( |
618 |
'plugin' => 'TestPlugin', |
619 |
'connection' => 'test', |
620 |
'name' => 'custom_names', |
621 |
'force' => false, |
622 |
'overwrite' => true, |
623 |
); |
624 |
$this->Shell->startup(); |
625 |
if (file_exists($this->Shell->Schema->path . DS . 'custom_names.php')) { |
626 |
unlink($this->Shell->Schema->path . DS . 'custom_names.php'); |
627 |
} |
628 |
$this->Shell->generate(); |
629 |
|
630 |
$contents = file_get_contents($this->Shell->Schema->path . DS . 'custom_names.php'); |
631 |
$this->assertRegExp('/class CustomNamesSchema/', $contents); |
632 |
unlink($this->Shell->Schema->path . DS . 'custom_names.php'); |
633 |
CakePlugin::unload();
|
634 |
} |
635 |
|
636 |
/**
|
637 |
* test that passing name and file creates the passed filename with the
|
638 |
* passed class name
|
639 |
*
|
640 |
* @return void
|
641 |
*/
|
642 |
public function testNameAndFile() { |
643 |
App::build(array( |
644 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
645 |
)); |
646 |
CakePlugin::load('TestPlugin'); |
647 |
$this->Shell->params = array( |
648 |
'plugin' => 'TestPlugin', |
649 |
'connection' => 'test', |
650 |
'name' => 'custom_name', |
651 |
'file' => 'other_name', |
652 |
'force' => false, |
653 |
'overwrite' => true, |
654 |
); |
655 |
$this->Shell->startup(); |
656 |
$file = $this->Shell->Schema->path . DS . 'other_name.php'; |
657 |
if (file_exists($file)) { |
658 |
unlink($file); |
659 |
} |
660 |
$this->Shell->generate(); |
661 |
|
662 |
$this->assertFileExists($file); |
663 |
$contents = file_get_contents($file); |
664 |
$this->assertRegExp('/class CustomNameSchema/', $contents); |
665 |
|
666 |
if (file_exists($file)) { |
667 |
unlink($file); |
668 |
} |
669 |
CakePlugin::unload();
|
670 |
} |
671 |
|
672 |
/**
|
673 |
* test that using Plugin.name with write.
|
674 |
*
|
675 |
* @return void
|
676 |
*/
|
677 |
public function testPluginDotSyntaxWithCreate() { |
678 |
App::build(array( |
679 |
'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS) |
680 |
)); |
681 |
CakePlugin::load('TestPlugin'); |
682 |
$this->Shell->params = array( |
683 |
'connection' => 'test' |
684 |
); |
685 |
$this->Shell->args = array('TestPlugin.TestPluginApp'); |
686 |
$this->Shell->startup(); |
687 |
$this->Shell->expects($this->any())->method('in')->will($this->returnValue('y')); |
688 |
$this->Shell->create(); |
689 |
|
690 |
$db = ConnectionManager::getDataSource('test'); |
691 |
$sources = $db->listSources(); |
692 |
$this->assertTrue(in_array($db->config['prefix'] . 'test_plugin_acos', $sources)); |
693 |
|
694 |
$schema = new TestPluginAppSchema(); |
695 |
$db->execute($db->dropSchema($schema, 'test_plugin_acos')); |
696 |
CakePlugin::unload();
|
697 |
} |
698 |
} |