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

pictcode / lib / Cake / Test / Case / TestSuite / CakeTestCaseTest.php @ 26d1f852

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

1
<?php
2
/**
3
 * CakeTestCaseTest file
4
 *
5
 * Test Case for CakeTestCase class
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.TestSuite
17
 * @since         CakePHP v 1.2.0.4487
18
 * @license       http://www.opensource.org/licenses/mit-license.php MIT License
19
 */
20
App::uses('CakePlugin', 'Core');
21
App::uses('Controller', 'Controller');
22
App::uses('CakeHtmlReporter', 'TestSuite/Reporter');
23
App::uses('Model', 'Model');
24

    
25
/**
26
 * Secondary Post stub class.
27
 */
28
class SecondaryPost extends Model {
29

    
30
/**
31
 * @var string
32
 */
33
        public $useTable = 'posts';
34

    
35
/**
36
 * @var string
37
 */
38
        public $useDbConfig = 'secondary';
39

    
40
}
41

    
42
/**
43
 * CakeTestCaseTest
44
 *
45
 * @package       Cake.Test.Case.TestSuite
46
 */
47
class CakeTestCaseTest extends CakeTestCase {
48

    
49
/**
50
 * fixtures property
51
 *
52
 * @var array
53
 */
54
        public $fixtures = array('core.post', 'core.author', 'core.test_plugin_comment');
55

    
56
/**
57
 * CakeTestCaseTest::setUpBeforeClass()
58
 *
59
 * @return void
60
 */
61
        public static function setUpBeforeClass() {
62
                require_once CAKE . 'Test' . DS . 'Fixture' . DS . 'AssertTagsTestCase.php';
63
                require_once CAKE . 'Test' . DS . 'Fixture' . DS . 'FixturizedTestCase.php';
64
        }
65

    
66
/**
67
 * setUp
68
 *
69
 * @return void
70
 */
71
        public function setUp() {
72
                parent::setUp();
73
                $this->Reporter = $this->getMock('CakeHtmlReporter');
74
        }
75

    
76
/**
77
 * tearDown
78
 *
79
 * @return void
80
 */
81
        public function tearDown() {
82
                parent::tearDown();
83
                unset($this->Result);
84
                unset($this->Reporter);
85
        }
86

    
87
/**
88
 * testAssertTags
89
 *
90
 * @return void
91
 */
92
        public function testAssertTagsBasic() {
93
                $test = new AssertTagsTestCase('testAssertTagsQuotes');
94
                $result = $test->run();
95
                $this->assertEquals(0, $result->errorCount());
96
                $this->assertTrue($result->wasSuccessful());
97
                $this->assertEquals(0, $result->failureCount());
98
        }
99

    
100
/**
101
 * test assertTags works with single and double quotes
102
 *
103
 * @return void
104
 */
105
        public function testAssertTagsQuoting() {
106
                $input = '<a href="/test.html" class="active">My link</a>';
107
                $pattern = array(
108
                        'a' => array('href' => '/test.html', 'class' => 'active'),
109
                        'My link',
110
                        '/a'
111
                );
112
                $this->assertTags($input, $pattern);
113

    
114
                $input = "<a href='/test.html' class='active'>My link</a>";
115
                $pattern = array(
116
                        'a' => array('href' => '/test.html', 'class' => 'active'),
117
                        'My link',
118
                        '/a'
119
                );
120
                $this->assertTags($input, $pattern);
121

    
122
                $input = "<a href='/test.html' class='active'>My link</a>";
123
                $pattern = array(
124
                        'a' => array('href' => 'preg:/.*\.html/', 'class' => 'active'),
125
                        'My link',
126
                        '/a'
127
                );
128
                $this->assertTags($input, $pattern);
129

    
130
                $input = "<span><strong>Text</strong></span>";
131
                $pattern = array(
132
                        '<span',
133
                        '<strong',
134
                        'Text',
135
                        '/strong',
136
                        '/span'
137
                );
138
                $this->assertTags($input, $pattern);
139

    
140
                $input = "<span class='active'><strong>Text</strong></span>";
141
                $pattern = array(
142
                        'span' => array('class'),
143
                        '<strong',
144
                        'Text',
145
                        '/strong',
146
                        '/span'
147
                );
148
                $this->assertTags($input, $pattern);
149
        }
150

    
151
/**
152
 * Test that assertTags runs quickly.
153
 *
154
 * @return void
155
 */
156
        public function testAssertTagsRuntimeComplexity() {
157
                $pattern = array(
158
                        'div' => array(
159
                                'attr1' => 'val1',
160
                                'attr2' => 'val2',
161
                                'attr3' => 'val3',
162
                                'attr4' => 'val4',
163
                                'attr5' => 'val5',
164
                                'attr6' => 'val6',
165
                                'attr7' => 'val7',
166
                                'attr8' => 'val8',
167
                        ),
168
                        'My div',
169
                        '/div'
170
                );
171
                $input = '<div attr8="val8" attr6="val6" attr4="val4" attr2="val2"' .
172
                        ' attr1="val1" attr3="val3" attr5="val5" attr7="val7" />' .
173
                        'My div' .
174
                        '</div>';
175
                $this->assertTags($input, $pattern);
176
        }
177

    
178
/**
179
 * testNumericValuesInExpectationForAssertTags
180
 *
181
 * @return void
182
 */
183
        public function testNumericValuesInExpectationForAssertTags() {
184
                $test = new AssertTagsTestCase('testNumericValuesInExpectationForAssertTags');
185
                $result = $test->run();
186
                $this->assertEquals(0, $result->errorCount());
187
                $this->assertTrue($result->wasSuccessful());
188
                $this->assertEquals(0, $result->failureCount());
189
        }
190

    
191
/**
192
 * testBadAssertTags
193
 *
194
 * @return void
195
 */
196
        public function testBadAssertTags() {
197
                $test = new AssertTagsTestCase('testBadAssertTags');
198
                $result = $test->run();
199
                $this->assertEquals(0, $result->errorCount());
200
                $this->assertFalse($result->wasSuccessful());
201
                $this->assertEquals(1, $result->failureCount());
202

    
203
                $test = new AssertTagsTestCase('testBadAssertTags2');
204
                $result = $test->run();
205
                $this->assertEquals(0, $result->errorCount());
206
                $this->assertFalse($result->wasSuccessful());
207
                $this->assertEquals(1, $result->failureCount());
208
        }
209

    
210
/**
211
 * testLoadFixtures
212
 *
213
 * @return void
214
 */
215
        public function testLoadFixtures() {
216
                $test = new FixturizedTestCase('testFixturePresent');
217
                $manager = $this->getMock('CakeFixtureManager');
218
                $manager->fixturize($test);
219
                $test->fixtureManager = $manager;
220
                $manager->expects($this->once())->method('load');
221
                $manager->expects($this->once())->method('unload');
222
                $result = $test->run();
223
                $this->assertEquals(0, $result->errorCount());
224
                $this->assertTrue($result->wasSuccessful());
225
                $this->assertEquals(0, $result->failureCount());
226
        }
227

    
228
/**
229
 * testLoadFixturesOnDemand
230
 *
231
 * @return void
232
 */
233
        public function testLoadFixturesOnDemand() {
234
                $test = new FixturizedTestCase('testFixtureLoadOnDemand');
235
                $test->autoFixtures = false;
236
                $manager = $this->getMock('CakeFixtureManager');
237
                $manager->fixturize($test);
238
                $test->fixtureManager = $manager;
239
                $manager->expects($this->once())->method('loadSingle');
240
                $result = $test->run();
241
                $this->assertEquals(0, $result->errorCount());
242
        }
243

    
244
/**
245
 * testLoadFixturesOnDemand
246
 *
247
 * @return void
248
 */
249
        public function testUnoadFixturesAfterFailure() {
250
                $test = new FixturizedTestCase('testFixtureLoadOnDemand');
251
                $test->autoFixtures = false;
252
                $manager = $this->getMock('CakeFixtureManager');
253
                $manager->fixturize($test);
254
                $test->fixtureManager = $manager;
255
                $manager->expects($this->once())->method('loadSingle');
256
                $result = $test->run();
257
                $this->assertEquals(0, $result->errorCount());
258
        }
259

    
260
/**
261
 * testThrowException
262
 *
263
 * @return void
264
 */
265
        public function testThrowException() {
266
                $test = new FixturizedTestCase('testThrowException');
267
                $test->autoFixtures = false;
268
                $manager = $this->getMock('CakeFixtureManager');
269
                $manager->fixturize($test);
270
                $test->fixtureManager = $manager;
271
                $manager->expects($this->once())->method('unload');
272
                $result = $test->run();
273
                $this->assertEquals(1, $result->errorCount());
274
        }
275

    
276
/**
277
 * testSkipIf
278
 *
279
 * @return void
280
 */
281
        public function testSkipIf() {
282
                $test = new FixturizedTestCase('testSkipIfTrue');
283
                $result = $test->run();
284
                $this->assertEquals(1, $result->skippedCount());
285

    
286
                $test = new FixturizedTestCase('testSkipIfFalse');
287
                $result = $test->run();
288
                $this->assertEquals(0, $result->skippedCount());
289
        }
290

    
291
/**
292
 * Test that CakeTestCase::setUp() backs up values.
293
 *
294
 * @return void
295
 */
296
        public function testSetupBackUpValues() {
297
                $this->assertArrayHasKey('debug', $this->_configure);
298
                $this->assertArrayHasKey('Plugin', $this->_pathRestore);
299
        }
300

    
301
/**
302
 * test assertTextNotEquals()
303
 *
304
 * @return void
305
 */
306
        public function testAssertTextNotEquals() {
307
                $one = "\r\nOne\rTwooo";
308
                $two = "\nOne\nTwo";
309
                $this->assertTextNotEquals($one, $two);
310
        }
311

    
312
/**
313
 * test assertTextEquals()
314
 *
315
 * @return void
316
 */
317
        public function testAssertTextEquals() {
318
                $one = "\r\nOne\rTwo";
319
                $two = "\nOne\nTwo";
320
                $this->assertTextEquals($one, $two);
321
        }
322

    
323
/**
324
 * test assertTextStartsWith()
325
 *
326
 * @return void
327
 */
328
        public function testAssertTextStartsWith() {
329
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
330

    
331
                $this->assertStringStartsWith("some\nstring", $stringDirty);
332
                $this->assertStringStartsNotWith("some\r\nstring\r\nwith", $stringDirty);
333
                $this->assertStringStartsNotWith("some\nstring\nwith", $stringDirty);
334

    
335
                $this->assertTextStartsWith("some\nstring\nwith", $stringDirty);
336
                $this->assertTextStartsWith("some\r\nstring\r\nwith", $stringDirty);
337
        }
338

    
339
/**
340
 * test assertTextStartsNotWith()
341
 *
342
 * @return void
343
 */
344
        public function testAssertTextStartsNotWith() {
345
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
346
                $this->assertTextStartsNotWith("some\nstring\nwithout", $stringDirty);
347
        }
348

    
349
/**
350
 * test assertTextEndsWith()
351
 *
352
 * @return void
353
 */
354
        public function testAssertTextEndsWith() {
355
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
356
                $this->assertTextEndsWith("string\nwith\r\ndifferent\rline endings!", $stringDirty);
357
                $this->assertTextEndsWith("string\r\nwith\ndifferent\nline endings!", $stringDirty);
358
        }
359

    
360
/**
361
 * test assertTextEndsNotWith()
362
 *
363
 * @return void
364
 */
365
        public function testAssertTextEndsNotWith() {
366
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
367
                $this->assertStringEndsNotWith("different\nline endings", $stringDirty);
368
                $this->assertTextEndsNotWith("different\rline endings", $stringDirty);
369
        }
370

    
371
/**
372
 * test assertTextContains()
373
 *
374
 * @return void
375
 */
376
        public function testAssertTextContains() {
377
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
378
                $this->assertContains("different", $stringDirty);
379
                $this->assertNotContains("different\rline", $stringDirty);
380
                $this->assertTextContains("different\rline", $stringDirty);
381
        }
382

    
383
/**
384
 * test assertTextNotContains()
385
 *
386
 * @return void
387
 */
388
        public function testAssertTextNotContains() {
389
                $stringDirty = "some\nstring\r\nwith\rdifferent\nline endings!";
390
                $this->assertTextNotContains("different\rlines", $stringDirty);
391
        }
392

    
393
/**
394
 * test getMockForModel()
395
 *
396
 * @return void
397
 */
398
        public function testGetMockForModel() {
399
                App::build(array(
400
                        'Model' => array(
401
                                CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS
402
                        )
403
                ), App::RESET);
404
                $Post = $this->getMockForModel('Post');
405
                $this->assertEquals('test', $Post->useDbConfig);
406
                $this->assertInstanceOf('Post', $Post);
407
                $this->assertNull($Post->save(array()));
408
                $this->assertNull($Post->find('all'));
409
                $this->assertEquals('posts', $Post->useTable);
410

    
411
                $Post = $this->getMockForModel('Post', array('save'));
412

    
413
                $this->assertNull($Post->save(array()));
414
                $this->assertInternalType('array', $Post->find('all'));
415
        }
416

    
417
/**
418
 * Test getMockForModel on secondary datasources.
419
 *
420
 * @return void
421
 */
422
        public function testGetMockForModelSecondaryDatasource() {
423
                App::build(array(
424
                        'Plugin' => array(CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS),
425
                        'Model/Datasource/Database' => array(
426
                                CAKE . 'Test' . DS . 'test_app' . DS . 'Model' . DS . 'Datasource' . DS . 'Database' . DS
427
                        )
428
                ), App::RESET);
429
                CakePlugin::load('TestPlugin');
430
                ConnectionManager::create('test_secondary', array(
431
                        'datasource' => 'Database/TestLocalDriver'
432
                ));
433
                $post = $this->getMockForModel('SecondaryPost', array('save'));
434
                $this->assertEquals('test_secondary', $post->useDbConfig);
435
                ConnectionManager::drop('test_secondary');
436
        }
437

    
438
/**
439
 * test getMockForModel() with plugin models
440
 *
441
 * @return void
442
 */
443
        public function testGetMockForModelWithPlugin() {
444
                App::build(array(
445
                        'Plugin' => array(
446
                                CAKE . 'Test' . DS . 'test_app' . DS . 'Plugin' . DS
447
                        )
448
                ), App::RESET);
449
                CakePlugin::load('TestPlugin');
450
                $this->getMockForModel('TestPlugin.TestPluginAppModel');
451
                $this->getMockForModel('TestPlugin.TestPluginComment');
452

    
453
                $result = ClassRegistry::init('TestPlugin.TestPluginComment');
454
                $this->assertInstanceOf('TestPluginComment', $result);
455
                $this->assertEquals('test', $result->useDbConfig);
456

    
457
                $TestPluginComment = $this->getMockForModel('TestPlugin.TestPluginComment', array('save'));
458

    
459
                $this->assertInstanceOf('TestPluginComment', $TestPluginComment);
460
                $TestPluginComment->expects($this->at(0))
461
                        ->method('save')
462
                        ->will($this->returnValue(true));
463
                $TestPluginComment->expects($this->at(1))
464
                        ->method('save')
465
                        ->will($this->returnValue(false));
466
                $this->assertTrue($TestPluginComment->save(array()));
467
                $this->assertFalse($TestPluginComment->save(array()));
468
        }
469

    
470
/**
471
 * testGetMockForModelModel
472
 *
473
 * @return void
474
 */
475
        public function testGetMockForModelModel() {
476
                $Mock = $this->getMockForModel('Model', array('save', 'setDataSource'), array('name' => 'Comment'));
477

    
478
                $result = ClassRegistry::init('Comment');
479
                $this->assertInstanceOf('Model', $result);
480

    
481
                $Mock->expects($this->at(0))
482
                        ->method('save')
483
                        ->will($this->returnValue(true));
484
                $Mock->expects($this->at(1))
485
                        ->method('save')
486
                        ->will($this->returnValue(false));
487

    
488
                $this->assertTrue($Mock->save(array()));
489
                $this->assertFalse($Mock->save(array()));
490
        }
491

    
492
/**
493
 * testGetMockForModelDoesNotExist
494
 *
495
 * @expectedException MissingModelException
496
 * @expectedExceptionMessage Model IDoNotExist could not be found
497
 * @return void
498
 */
499
        public function testGetMockForModelDoesNotExist() {
500
                $this->getMockForModel('IDoNotExist');
501
        }
502
}