Dispatcher =& new TestFixtureTaskMockShellDispatcher(); $this->Task =& new MockFixtureTask(); $this->Task->Model =& new MockFixtureModelTask(); $this->Task->Dispatch =& $this->Dispatcher; $this->Task->Template =& new TemplateTask($this->Task->Dispatch); $this->Task->Dispatch->shellPaths = App::path('shells'); $this->Task->Template->initialize(); } /** * endTest method * * @return void * @access public */ function endTest() { unset($this->Task, $this->Dispatcher); ClassRegistry::flush(); } /** * test that initialize sets the path * * @return void **/ function testConstruct() { $this->Dispatch->params['working'] = DS . 'my' . DS . 'path'; $Task =& new FixtureTask($this->Dispatch); $expected = DS . 'my' . DS . 'path' . DS . 'tests' . DS . 'fixtures' . DS; $this->assertEqual($Task->path, $expected); } /** * test import option array generation * * @return void **/ function testImportOptions() { $this->Task->setReturnValueAt(0, 'in', 'y'); $this->Task->setReturnValueAt(1, 'in', 'y'); $result = $this->Task->importOptions('Article'); $expected = array('schema' => 'Article', 'records' => true); $this->assertEqual($result, $expected); $this->Task->setReturnValueAt(2, 'in', 'n'); $this->Task->setReturnValueAt(3, 'in', 'n'); $this->Task->setReturnValueAt(4, 'in', 'n'); $result = $this->Task->importOptions('Article'); $expected = array(); $this->assertEqual($result, $expected); $this->Task->setReturnValueAt(5, 'in', 'n'); $this->Task->setReturnValueAt(6, 'in', 'n'); $this->Task->setReturnValueAt(7, 'in', 'y'); $result = $this->Task->importOptions('Article'); $expected = array('fromTable' => true); $this->assertEqual($result, $expected); } /** * test generating a fixture with database conditions. * * @return void **/ function testImportRecordsFromDatabaseWithConditions() { $this->Task->setReturnValueAt(0, 'in', 'WHERE 1=1 LIMIT 10'); $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $result = $this->Task->bake('Article', false, array('fromTable' => true, 'schema' => 'Article', 'records' => false)); $this->assertPattern('/class ArticleFixture extends CakeTestFixture/', $result); $this->assertPattern('/var \$records/', $result); $this->assertPattern('/var \$import/', $result); $this->assertPattern("/'title' => 'First Article'/", $result, 'Missing import data %s'); $this->assertPattern('/Second Article/', $result, 'Missing import data %s'); $this->assertPattern('/Third Article/', $result, 'Missing import data %s'); } /** * test that execute passes runs bake depending with named model. * * @return void **/ function testExecuteWithNamedModel() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $this->Task->args = array('article'); $filename = '/my/path/article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/class ArticleFixture/'))); $this->Task->execute(); } /** * test that execute runs all() when args[0] = all * * @return void **/ function testExecuteIntoAll() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $this->Task->args = array('all'); $this->Task->Model->setReturnValue('listAll', array('articles', 'comments')); $filename = '/my/path/article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/class ArticleFixture/'))); $this->Task->execute(); $filename = '/my/path/comment_fixture.php'; $this->Task->expectAt(1, 'createFile', array($filename, new PatternExpectation('/class CommentFixture/'))); $this->Task->execute(); } /** * test using all() with -count and -records * * @return void **/ function testAllWithCountAndRecordsFlags() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $this->Task->args = array('all'); $this->Task->params = array('count' => 10, 'records' => true); $this->Task->Model->setReturnValue('listAll', array('articles', 'comments')); $filename = '/my/path/article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/title\' => \'Third Article\'/'))); $filename = '/my/path/comment_fixture.php'; $this->Task->expectAt(1, 'createFile', array($filename, new PatternExpectation('/comment\' => \'First Comment for First Article/'))); $this->Task->expectCallCount('createFile', 2); $this->Task->all(); } /** * test interactive mode of execute * * @return void **/ function testExecuteInteractive() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $this->Task->setReturnValue('in', 'y'); $this->Task->Model->setReturnValue('getName', 'Article'); $this->Task->Model->setReturnValue('getTable', 'articles', array('Article')); $filename = '/my/path/article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/class ArticleFixture/'))); $this->Task->execute(); } /** * Test that bake works * * @return void **/ function testBake() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $result = $this->Task->bake('Article'); $this->assertPattern('/class ArticleFixture extends CakeTestFixture/', $result); $this->assertPattern('/var \$fields/', $result); $this->assertPattern('/var \$records/', $result); $this->assertNoPattern('/var \$import/', $result); $result = $this->Task->bake('Article', 'comments'); $this->assertPattern('/class ArticleFixture extends CakeTestFixture/', $result); $this->assertPattern('/var \$name \= \'Article\';/', $result); $this->assertPattern('/var \$table \= \'comments\';/', $result); $this->assertPattern('/var \$fields = array\(/', $result); $result = $this->Task->bake('Article', 'comments', array('records' => true)); $this->assertPattern("/var \\\$import \= array\('records' \=\> true\);/", $result); $this->assertNoPattern('/var \$records/', $result); $result = $this->Task->bake('Article', 'comments', array('schema' => 'Article')); $this->assertPattern("/var \\\$import \= array\('model' \=\> 'Article'\);/", $result); $this->assertNoPattern('/var \$fields/', $result); $result = $this->Task->bake('Article', 'comments', array('schema' => 'Article', 'records' => true)); $this->assertPattern("/var \\\$import \= array\('model' \=\> 'Article'\, 'records' \=\> true\);/", $result); $this->assertNoPattern('/var \$fields/', $result); $this->assertNoPattern('/var \$records/', $result); } /** * Test that file generation includes headers and correct path for plugins. * * @return void **/ function testGenerateFixtureFile() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $filename = '/my/path/article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/Article/'))); $result = $this->Task->generateFixtureFile('Article', array()); $this->Task->expectAt(1, 'createFile', array($filename, new PatternExpectation('/\<\?php(.*)\?\>/ms'))); $result = $this->Task->generateFixtureFile('Article', array()); } /** * test generating files into plugins. * * @return void **/ function testGeneratePluginFixtureFile() { $this->Task->connection = 'test_suite'; $this->Task->path = '/my/path/'; $this->Task->plugin = 'TestFixture'; $filename = APP . 'plugins' . DS . 'test_fixture' . DS . 'tests' . DS . 'fixtures' . DS . 'article_fixture.php'; $this->Task->expectAt(0, 'createFile', array($filename, new PatternExpectation('/Article/'))); $result = $this->Task->generateFixtureFile('Article', array()); } } ?>