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

pictcode / lib / Cake / Test / Case / TestSuite / CakeTestFixtureTest.php @ 00f32066

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

1
<?php
2
/**
3
 * CakeTestFixture 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.TestSuite
15
 * @since         CakePHP(tm) v 1.2.0.4667
16
 * @license       http://www.opensource.org/licenses/mit-license.php MIT License
17
 */
18

    
19
App::uses('DboSource', 'Model/Datasource');
20
App::uses('Model', 'Model');
21
App::uses('CakeTestFixture', 'TestSuite/Fixture');
22

    
23
/**
24
 * CakeTestFixtureTestFixture class
25
 *
26
 * @package       Cake.Test.Case.TestSuite
27
 */
28
class CakeTestFixtureTestFixture extends CakeTestFixture {
29

    
30
/**
31
 * Name property
32
 *
33
 * @var string
34
 */
35
        public $name = 'FixtureTest';
36

    
37
/**
38
 * Table property
39
 *
40
 * @var string
41
 */
42
        public $table = 'fixture_tests';
43

    
44
/**
45
 * Fields array
46
 *
47
 * @var array
48
 */
49
        public $fields = array(
50
                'id' => array('type' => 'integer', 'key' => 'primary'),
51
                'name' => array('type' => 'string', 'length' => '255'),
52
                'created' => array('type' => 'datetime')
53
        );
54

    
55
/**
56
 * Records property
57
 *
58
 * @var array
59
 */
60
        public $records = array(
61
                array('name' => 'Gandalf', 'created' => '2009-04-28 19:20:00'),
62
                array('name' => 'Captain Picard', 'created' => '2009-04-28 19:20:00'),
63
                array('name' => 'Chewbacca', 'created' => '2009-04-28 19:20:00')
64
        );
65
}
66

    
67
/**
68
 * StringTestFixture class
69
 *
70
 * @package       Cake.Test.Case.TestSuite
71
 */
72
class StringsTestFixture extends CakeTestFixture {
73

    
74
/**
75
 * Name property
76
 *
77
 * @var string
78
 */
79
        public $name = 'Strings';
80

    
81
/**
82
 * Table property
83
 *
84
 * @var string
85
 */
86
        public $table = 'strings';
87

    
88
/**
89
 * Fields array
90
 *
91
 * @var array
92
 */
93
        public $fields = array(
94
                'id' => array('type' => 'integer', 'key' => 'primary'),
95
                'name' => array('type' => 'string', 'length' => '255'),
96
                'email' => array('type' => 'string', 'length' => '255'),
97
                'age' => array('type' => 'integer', 'default' => 10)
98
        );
99

    
100
/**
101
 * Records property
102
 *
103
 * @var array
104
 */
105
        public $records = array(
106
                array('name' => 'Mark Doe', 'email' => 'mark.doe@email.com'),
107
                array('name' => 'John Doe', 'email' => 'john.doe@email.com', 'age' => 20),
108
                array('email' => 'jane.doe@email.com', 'name' => 'Jane Doe', 'age' => 30)
109
        );
110
}
111

    
112
/**
113
 * InvalidTestFixture class
114
 *
115
 * @package       Cake.Test.Case.TestSuite
116
 */
117
class InvalidTestFixture extends CakeTestFixture {
118

    
119
/**
120
 * Name property
121
 *
122
 * @var string
123
 */
124
        public $name = 'Invalid';
125

    
126
/**
127
 * Table property
128
 *
129
 * @var string
130
 */
131
        public $table = 'invalid';
132

    
133
/**
134
 * Fields array - missing "email" row
135
 *
136
 * @var array
137
 */
138
        public $fields = array(
139
                'id' => array('type' => 'integer', 'key' => 'primary'),
140
                'name' => array('type' => 'string', 'length' => '255'),
141
                'age' => array('type' => 'integer', 'default' => 10)
142
        );
143

    
144
/**
145
 * Records property
146
 *
147
 * @var array
148
 */
149
        public $records = array(
150
                array('name' => 'Mark Doe', 'email' => 'mark.doe@email.com'),
151
                array('name' => 'John Doe', 'email' => 'john.doe@email.com', 'age' => 20),
152
                array('email' => 'jane.doe@email.com', 'name' => 'Jane Doe', 'age' => 30)
153
        );
154
}
155

    
156
/**
157
 * CakeTestFixtureImportFixture class
158
 *
159
 * @package       Cake.Test.Case.TestSuite
160
 */
161
class CakeTestFixtureImportFixture extends CakeTestFixture {
162

    
163
/**
164
 * Name property
165
 *
166
 * @var string
167
 */
168
        public $name = 'ImportFixture';
169

    
170
/**
171
 * Import property
172
 *
173
 * @var mixed
174
 */
175
        public $import = array('table' => 'fixture_tests', 'connection' => 'fixture_test_suite');
176
}
177

    
178
/**
179
 * CakeTestFixtureDefaultImportFixture class
180
 *
181
 * @package       Cake.Test.Case.TestSuite
182
 */
183
class CakeTestFixtureDefaultImportFixture extends CakeTestFixture {
184

    
185
/**
186
 * Name property
187
 *
188
 * @var string
189
 */
190
        public $name = 'ImportFixture';
191
}
192

    
193
/**
194
 * FixtureImportTestModel class
195
 *
196
 * @package       Cake.Test.Case.TestSuite
197
 */
198
class FixtureImportTestModel extends Model {
199

    
200
        public $name = 'FixtureImport';
201

    
202
        public $useTable = 'fixture_tests';
203

    
204
        public $useDbConfig = 'test';
205

    
206
}
207

    
208
class FixturePrefixTest extends Model {
209

    
210
        public $name = 'FixturePrefix';
211

    
212
        public $useTable = '_tests';
213

    
214
        public $tablePrefix = 'fixture';
215

    
216
        public $useDbConfig = 'test';
217
}
218

    
219
/**
220
 * Test case for CakeTestFixture
221
 *
222
 * @package       Cake.Test.Case.TestSuite
223
 */
224
class CakeTestFixtureTest extends CakeTestCase {
225

    
226
/**
227
 * setUp method
228
 *
229
 * @return void
230
 */
231
        public function setUp() {
232
                parent::setUp();
233
                $methods = array_diff(get_class_methods('DboSource'), array('enabled'));
234
                $methods[] = 'connect';
235

    
236
                $this->criticDb = $this->getMock('DboSource', $methods);
237
                $this->criticDb->fullDebug = true;
238
                $this->db = ConnectionManager::getDataSource('test');
239
                $this->_backupConfig = $this->db->config;
240
        }
241

    
242
/**
243
 * tearDown
244
 *
245
 * @return void
246
 */
247
        public function tearDown() {
248
                parent::tearDown();
249
                unset($this->criticDb);
250
                $this->db->config = $this->_backupConfig;
251
        }
252

    
253
/**
254
 * testInit
255
 *
256
 * @return void
257
 */
258
        public function testInit() {
259
                $Fixture = new CakeTestFixtureTestFixture();
260
                unset($Fixture->table);
261
                $Fixture->init();
262
                $this->assertEquals('fixture_tests', $Fixture->table);
263
                $this->assertEquals('id', $Fixture->primaryKey);
264

    
265
                $Fixture = new CakeTestFixtureTestFixture();
266
                $Fixture->primaryKey = 'my_random_key';
267
                $Fixture->init();
268
                $this->assertEquals('my_random_key', $Fixture->primaryKey);
269
        }
270

    
271
/**
272
 * test that init() correctly sets the fixture table when the connection
273
 * or model have prefixes defined.
274
 *
275
 * @return void
276
 */
277
        public function testInitDbPrefix() {
278
                $this->skipIf($this->db instanceof Sqlite, 'Cannot open 2 connections to Sqlite');
279
                $db = ConnectionManager::getDataSource('test');
280
                $Source = new CakeTestFixtureTestFixture();
281
                $Source->drop($db);
282
                $Source->create($db);
283
                $Source->insert($db);
284

    
285
                $Fixture = new CakeTestFixtureTestFixture();
286
                $expected = array('id', 'name', 'created');
287
                $this->assertEquals($expected, array_keys($Fixture->fields));
288

    
289
                $config = $db->config;
290
                $config['prefix'] = 'fixture_test_suite_';
291
                ConnectionManager::create('fixture_test_suite', $config);
292

    
293
                $Fixture->fields = $Fixture->records = null;
294
                $Fixture->import = array('table' => 'fixture_tests', 'connection' => 'test', 'records' => true);
295
                $Fixture->init();
296
                $this->assertEquals(count($Fixture->records), count($Source->records));
297
                $Fixture->create(ConnectionManager::getDataSource('fixture_test_suite'));
298

    
299
                $Fixture = new CakeTestFixtureImportFixture();
300
                $Fixture->fields = $Fixture->records = $Fixture->table = null;
301
                $Fixture->import = array('model' => 'FixtureImportTestModel', 'connection' => 'test');
302
                $Fixture->init();
303
                $this->assertEquals(array('id', 'name', 'created'), array_keys($Fixture->fields));
304
                $this->assertEquals('fixture_tests', $Fixture->table);
305

    
306
                $keys = array_flip(ClassRegistry::keys());
307
                $this->assertFalse(array_key_exists('fixtureimporttestmodel', $keys));
308

    
309
                $Fixture->drop(ConnectionManager::getDataSource('fixture_test_suite'));
310
                $Source->drop($db);
311
        }
312

    
313
/**
314
 * test that fixtures don't duplicate the test db prefix.
315
 *
316
 * @return void
317
 */
318
        public function testInitDbPrefixDuplication() {
319
                $this->skipIf($this->db instanceof Sqlite, 'Cannot open 2 connections to Sqlite');
320
                $db = ConnectionManager::getDataSource('test');
321
                $backPrefix = $db->config['prefix'];
322
                $db->config['prefix'] = 'cake_fixture_test_';
323
                ConnectionManager::create('fixture_test_suite', $db->config);
324
                $newDb = ConnectionManager::getDataSource('fixture_test_suite');
325
                $newDb->config['prefix'] = 'cake_fixture_test_';
326

    
327
                $Source = new CakeTestFixtureTestFixture();
328
                $Source->create($db);
329
                $Source->insert($db);
330

    
331
                $Fixture = new CakeTestFixtureImportFixture();
332
                $Fixture->fields = $Fixture->records = $Fixture->table = null;
333
                $Fixture->import = array('model' => 'FixtureImportTestModel', 'connection' => 'test');
334

    
335
                $Fixture->init();
336
                $this->assertEquals(array('id', 'name', 'created'), array_keys($Fixture->fields));
337
                $this->assertEquals('fixture_tests', $Fixture->table);
338

    
339
                $Source->drop($db);
340
                $db->config['prefix'] = $backPrefix;
341
        }
342

    
343
/**
344
 * test init with a model that has a tablePrefix declared.
345
 *
346
 * @return void
347
 */
348
        public function testInitModelTablePrefix() {
349
                $this->skipIf($this->db instanceof Sqlite, 'Cannot open 2 connections to Sqlite');
350
                $this->skipIf(!empty($this->db->config['prefix']), 'Cannot run this test, you have a database connection prefix.');
351

    
352
                $Source = new CakeTestFixtureTestFixture();
353
                $Source->create($this->db);
354
                $Source->insert($this->db);
355

    
356
                $Fixture = new CakeTestFixtureTestFixture();
357
                unset($Fixture->table);
358
                $Fixture->fields = $Fixture->records = null;
359
                $Fixture->import = array('model' => 'FixturePrefixTest', 'connection' => 'test', 'records' => false);
360
                $Fixture->init();
361
                $this->assertEquals('fixture_tests', $Fixture->table);
362

    
363
                $keys = array_flip(ClassRegistry::keys());
364
                $this->assertFalse(array_key_exists('fixtureimporttestmodel', $keys));
365

    
366
                $Source->drop($this->db);
367
        }
368

    
369
/**
370
 * testImport
371
 *
372
 * @return void
373
 */
374
        public function testImport() {
375
                $testSuiteDb = ConnectionManager::getDataSource('test');
376
                $testSuiteConfig = $testSuiteDb->config;
377
                ConnectionManager::create('new_test_suite', array_merge($testSuiteConfig, array('prefix' => 'new_' . $testSuiteConfig['prefix'])));
378
                $newTestSuiteDb = ConnectionManager::getDataSource('new_test_suite');
379

    
380
                $Source = new CakeTestFixtureTestFixture();
381
                $Source->create($newTestSuiteDb);
382
                $Source->insert($newTestSuiteDb);
383

    
384
                $Fixture = new CakeTestFixtureDefaultImportFixture();
385
                $Fixture->fields = $Fixture->records = null;
386
                $Fixture->import = array('model' => 'FixtureImportTestModel', 'connection' => 'new_test_suite');
387
                $Fixture->init();
388
                $this->assertEquals(array('id', 'name', 'created'), array_keys($Fixture->fields));
389

    
390
                $keys = array_flip(ClassRegistry::keys());
391
                $this->assertFalse(array_key_exists('fixtureimporttestmodel', $keys));
392

    
393
                $Source->drop($newTestSuiteDb);
394
        }
395

    
396
/**
397
 * test that importing with records works. Make sure to try with postgres as its
398
 * handling of aliases is a workaround at best.
399
 *
400
 * @return void
401
 */
402
        public function testImportWithRecords() {
403
                $testSuiteDb = ConnectionManager::getDataSource('test');
404
                $testSuiteConfig = $testSuiteDb->config;
405
                ConnectionManager::create('new_test_suite', array_merge($testSuiteConfig, array('prefix' => 'new_' . $testSuiteConfig['prefix'])));
406
                $newTestSuiteDb = ConnectionManager::getDataSource('new_test_suite');
407

    
408
                $Source = new CakeTestFixtureTestFixture();
409
                $Source->create($newTestSuiteDb);
410
                $Source->insert($newTestSuiteDb);
411

    
412
                $Fixture = new CakeTestFixtureDefaultImportFixture();
413
                $Fixture->fields = $Fixture->records = null;
414
                $Fixture->import = array(
415
                        'model' => 'FixtureImportTestModel', 'connection' => 'new_test_suite', 'records' => true
416
                );
417
                $Fixture->init();
418
                $this->assertEquals(array('id', 'name', 'created'), array_keys($Fixture->fields));
419
                $this->assertFalse(empty($Fixture->records[0]), 'No records loaded on importing fixture.');
420
                $this->assertTrue(isset($Fixture->records[0]['name']), 'No name loaded for first record');
421

    
422
                $Source->drop($newTestSuiteDb);
423
        }
424

    
425
/**
426
 * test create method
427
 *
428
 * @return void
429
 */
430
        public function testCreate() {
431
                $Fixture = new CakeTestFixtureTestFixture();
432
                $this->criticDb->expects($this->atLeastOnce())->method('execute');
433
                $this->criticDb->expects($this->atLeastOnce())->method('createSchema');
434
                $return = $Fixture->create($this->criticDb);
435
                $this->assertTrue($this->criticDb->fullDebug);
436
                $this->assertTrue($return);
437

    
438
                unset($Fixture->fields);
439
                $return = $Fixture->create($this->criticDb);
440
                $this->assertFalse($return);
441
        }
442

    
443
/**
444
 * test the insert method
445
 *
446
 * @return void
447
 */
448
        public function testInsert() {
449
                $Fixture = new CakeTestFixtureTestFixture();
450
                $this->criticDb->expects($this->atLeastOnce())
451
                        ->method('insertMulti')
452
                        ->will($this->returnCallback(array($this, 'insertCallback')));
453

    
454
                $return = $Fixture->insert($this->criticDb);
455
                $this->assertTrue(!empty($this->insertMulti));
456
                $this->assertTrue($this->criticDb->fullDebug);
457
                $this->assertTrue($return);
458
                $this->assertEquals('fixture_tests', $this->insertMulti['table']);
459
                $this->assertEquals(array('name', 'created'), $this->insertMulti['fields']);
460
                $expected = array(
461
                        array('Gandalf', '2009-04-28 19:20:00'),
462
                        array('Captain Picard', '2009-04-28 19:20:00'),
463
                        array('Chewbacca', '2009-04-28 19:20:00')
464
                );
465
                $this->assertEquals($expected, $this->insertMulti['values']);
466
        }
467

    
468
/**
469
 * Helper function to be used as callback and store the parameters of an insertMulti call
470
 *
471
 * @param string $table
472
 * @param string $fields
473
 * @param string $values
474
 * @return bool true
475
 */
476
        public function insertCallback($table, $fields, $values) {
477
                $this->insertMulti['table'] = $table;
478
                $this->insertMulti['fields'] = $fields;
479
                $this->insertMulti['values'] = $values;
480
                $this->insertMulti['fields_values'] = array();
481
                foreach ($values as $record) {
482
                        $this->insertMulti['fields_values'][] = array_combine($fields, $record);
483
                }
484
                return true;
485
        }
486

    
487
/**
488
 * test the insert method
489
 *
490
 * @return void
491
 */
492
        public function testInsertStrings() {
493
                $Fixture = new StringsTestFixture();
494
                $this->criticDb->expects($this->atLeastOnce())
495
                        ->method('insertMulti')
496
                        ->will($this->returnCallback(array($this, 'insertCallback')));
497

    
498
                $return = $Fixture->insert($this->criticDb);
499
                $this->assertTrue($this->criticDb->fullDebug);
500
                $this->assertTrue($return);
501
                $this->assertEquals('strings', $this->insertMulti['table']);
502
                $this->assertEquals(array('name', 'email', 'age'), array_values($this->insertMulti['fields']));
503
                $expected = array(
504
                        array('Mark Doe', 'mark.doe@email.com', null),
505
                        array('John Doe', 'john.doe@email.com', 20),
506
                        array('Jane Doe', 'jane.doe@email.com', 30),
507
                );
508
                $this->assertEquals($expected, $this->insertMulti['values']);
509
                $expected = array(
510
                        array(
511
                                'name' => 'Mark Doe',
512
                                'email' => 'mark.doe@email.com',
513
                                'age' => null
514
                        ),
515
                        array(
516
                                'name' => 'John Doe',
517
                                'email' => 'john.doe@email.com',
518
                                'age' => 20
519
                        ),
520
                        array(
521
                                'name' => 'Jane Doe',
522
                                'email' => 'jane.doe@email.com',
523
                                'age' => 30
524
                        ),
525
                );
526
                $this->assertEquals($expected, $this->insertMulti['fields_values']);
527
        }
528

    
529
/**
530
 * test the insert method with invalid fixture
531
 *
532
 * @expectedException CakeException
533
 * @return void
534
 */
535
        public function testInsertInvalid() {
536
                $Fixture = new InvalidTestFixture();
537
                $Fixture->insert($this->criticDb);
538
        }
539

    
540
/**
541
 * Test the drop method
542
 *
543
 * @return void
544
 */
545
        public function testDrop() {
546
                $Fixture = new CakeTestFixtureTestFixture();
547
                $this->criticDb->expects($this->at(1))->method('execute')->will($this->returnValue(true));
548
                $this->criticDb->expects($this->at(3))->method('execute')->will($this->returnValue(false));
549
                $this->criticDb->expects($this->exactly(2))->method('dropSchema');
550

    
551
                $return = $Fixture->drop($this->criticDb);
552
                $this->assertTrue($this->criticDb->fullDebug);
553
                $this->assertTrue($return);
554

    
555
                $return = $Fixture->drop($this->criticDb);
556
                $this->assertTrue($return);
557

    
558
                unset($Fixture->fields);
559
                $return = $Fixture->drop($this->criticDb);
560
                $this->assertFalse($return);
561
        }
562

    
563
/**
564
 * Test the truncate method.
565
 *
566
 * @return void
567
 */
568
        public function testTruncate() {
569
                $Fixture = new CakeTestFixtureTestFixture();
570
                $this->criticDb->expects($this->atLeastOnce())->method('truncate');
571
                $Fixture->truncate($this->criticDb);
572
                $this->assertTrue($this->criticDb->fullDebug);
573
        }
574
}