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 |
} |