2006-08-26 22:27:16 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ImportTestCase.php - 24.8.2006 2.37.14
|
2006-08-27 02:21:20 +00:00
|
|
|
*
|
|
|
|
* Note that some shortcuts maybe used here
|
2006-10-23 19:55:30 +00:00
|
|
|
* i.e. these tests depends that exporting is working
|
2006-08-26 22:27:16 +00:00
|
|
|
*
|
|
|
|
* @author Jukka Hassinen <Jukka.Hassinen@BrainAlliance.com>
|
|
|
|
* @version $Id$
|
2006-08-27 02:21:20 +00:00
|
|
|
* @package Doctrine
|
2006-08-26 22:27:16 +00:00
|
|
|
*/
|
2006-10-24 08:56:47 +00:00
|
|
|
class Doctrine_Import_TestCase extends Doctrine_UnitTestCase {
|
2006-08-27 02:21:20 +00:00
|
|
|
private $tmpdir;
|
|
|
|
|
|
|
|
private $suffix;
|
|
|
|
|
|
|
|
private $schema;
|
|
|
|
|
2006-10-24 08:56:47 +00:00
|
|
|
public function prepareTables() { }
|
|
|
|
public function prepareData() { }
|
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
public function setUp()
|
2006-08-26 22:27:16 +00:00
|
|
|
{
|
2006-08-27 02:21:20 +00:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
//reading
|
|
|
|
$reader = new Doctrine_Import_Reader_Db();
|
|
|
|
$reader->setPdo($this->dbh);
|
|
|
|
$this->schema = $reader->read();
|
2006-10-23 19:55:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testBadImport() {
|
|
|
|
$builder = new Doctrine_Import_Builder();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$builder->buildRecord(new Doctrine_Schema_Table());
|
2006-08-27 02:21:20 +00:00
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
$this->fail();
|
|
|
|
} catch(Doctrine_Import_Builder_Exception $e) {
|
|
|
|
$this->pass();
|
|
|
|
}
|
2006-08-27 02:21:20 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
public function testImportTable() {
|
2006-10-24 08:56:47 +00:00
|
|
|
$definition = array('name' => 'import_test');
|
2006-10-23 19:55:30 +00:00
|
|
|
|
|
|
|
$table = new Doctrine_Schema_Table($definition);
|
|
|
|
$def = array('name' => 'name',
|
|
|
|
'type' => 'string',
|
2006-10-24 08:56:47 +00:00
|
|
|
'length' => 20,
|
|
|
|
'default' => 'someone');
|
2006-10-23 19:55:30 +00:00
|
|
|
|
|
|
|
$table->addColumn(new Doctrine_Schema_Column($def));
|
2006-10-24 08:56:47 +00:00
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
$def = array('name' => 'created',
|
2006-10-24 08:56:47 +00:00
|
|
|
'type' => 'integer',
|
|
|
|
'notnull' => true);
|
2006-10-23 19:55:30 +00:00
|
|
|
|
|
|
|
$table->addColumn(new Doctrine_Schema_Column($def));
|
|
|
|
|
|
|
|
$builder = new Doctrine_Import_Builder();
|
|
|
|
|
|
|
|
$builder->setTargetPath('tmp');
|
|
|
|
try {
|
|
|
|
$builder->buildRecord($table);
|
|
|
|
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Import_Builder_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
2006-10-24 08:56:47 +00:00
|
|
|
$this->assertTrue(file_exists('tmp' . DIRECTORY_SEPARATOR . 'ImportTest.php'));
|
|
|
|
}
|
|
|
|
public function testImportedComponent() {
|
|
|
|
require_once('tmp' . DIRECTORY_SEPARATOR . 'ImportTest.php');
|
|
|
|
|
|
|
|
$r = new ImportTest();
|
|
|
|
$columns = $r->getTable()->getColumns();
|
|
|
|
|
|
|
|
// id column is auto-created
|
|
|
|
|
|
|
|
$this->assertEqual($columns['id'][0], 'integer');
|
|
|
|
$this->assertEqual($columns['id'][1], 20);
|
|
|
|
|
|
|
|
$this->assertEqual($columns['name'][0], 'string');
|
|
|
|
$this->assertEqual($columns['name'][1], 20);
|
|
|
|
|
|
|
|
$this->assertEqual($columns['created'][0], 'integer');
|
|
|
|
|
|
|
|
unlink('tmp' . DIRECTORY_SEPARATOR . 'ImportTest.php');
|
|
|
|
}
|
|
|
|
public function testForeignKeySupport() {
|
2006-10-25 20:02:40 +00:00
|
|
|
/**
|
2006-10-24 08:56:47 +00:00
|
|
|
$this->dbh->query('CREATE TABLE album (
|
|
|
|
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
|
|
title VARCHAR(100),
|
|
|
|
artist VARCHAR(100)
|
|
|
|
)');
|
|
|
|
|
|
|
|
$this->dbh->query('CREATE TABLE track (
|
|
|
|
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
|
|
album_id INTEGER,
|
|
|
|
dsk INTEGER,
|
|
|
|
posn INTEGER,
|
|
|
|
song VARCHAR(255),
|
|
|
|
FOREIGN KEY (album_id) REFERENCES album(id)
|
|
|
|
)');
|
|
|
|
|
|
|
|
|
|
|
|
$sql = "PRAGMA table_info(track)";
|
|
|
|
$sql = "PRAGMA foreign_key_list(track)";
|
|
|
|
$result = $this->dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
|
2006-10-25 20:02:40 +00:00
|
|
|
*/
|
2006-10-23 19:55:30 +00:00
|
|
|
|
|
|
|
}
|
2006-10-24 08:56:47 +00:00
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
/**
|
2006-08-27 02:21:20 +00:00
|
|
|
public function testDatabaseConnectionIsReverseEngineeredToSchema()
|
|
|
|
{
|
|
|
|
|
|
|
|
$this->assertTrue($this->schema instanceof Doctrine_Schema);
|
2006-08-26 22:27:16 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
//table count should match
|
|
|
|
$this->assertEqual(count($this->schema), count($this->tables));
|
|
|
|
|
2006-08-26 22:27:16 +00:00
|
|
|
}
|
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
public function testBaseClassesAreWritten()
|
|
|
|
{
|
|
|
|
//now lets match the original with the result
|
|
|
|
foreach($this->tables as $name)
|
|
|
|
{
|
|
|
|
$name = ucwords($name);
|
|
|
|
$filename = $this->tmpdir.$name.$this->suffix.'.php';
|
|
|
|
$this->assertTrue(file_exists($filename));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function testNativeColumnDefinitionsAreTranslatedCorrectly()
|
|
|
|
{
|
|
|
|
$transArr = array();
|
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
$transArr['sqlite'] = array(
|
2006-10-23 19:55:30 +00:00
|
|
|
// array(native type, native length, doctrine type, doctrine length),
|
2006-08-27 02:21:20 +00:00
|
|
|
array('int', 11, 'int', 11),
|
|
|
|
//array('varchar', 255, 'string', 255),
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
|
|
foreach ($transArr as $dbType => $colArr)
|
|
|
|
{
|
|
|
|
foreach($colArr as $colDef)
|
|
|
|
{
|
|
|
|
list($natType, $natLen, $expType, $expLen) = $colDef;
|
|
|
|
list($resType, $resLen) = Doctrine_DataDict::getDoctrineType($natType, $natLen, $dbType);
|
|
|
|
$this->assertEqual($resType, $expType);
|
|
|
|
$this->assertEqual($resLen, $expLen);
|
|
|
|
}
|
|
|
|
}
|
2006-08-26 22:27:16 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
public function testDoctrineRecordBaseClassesAreBuildCorrectly()
|
2006-08-26 22:27:16 +00:00
|
|
|
{
|
2006-08-27 02:21:20 +00:00
|
|
|
foreach($this->tables as $name)
|
|
|
|
{
|
|
|
|
$name = ucwords($name);
|
|
|
|
$filename = $this->tmpdir.$name.$this->suffix.'.php';
|
|
|
|
if(file_exists($filename))
|
|
|
|
{
|
|
|
|
require_once $filename;
|
|
|
|
$obj = new $name.$this->suffix;
|
|
|
|
|
|
|
|
list($oType, $oLength,) = $this->connection->getTable($name)->getColumns();
|
|
|
|
list($rType, $rLength,) = $this->connection->getTable($name.$this->suffix)->getColumns();
|
|
|
|
|
|
|
|
$this->assertEquals($rType, $oType);
|
|
|
|
$this->assertEquals($rLength, $oLength);
|
|
|
|
}
|
|
|
|
}
|
2006-08-26 22:27:16 +00:00
|
|
|
}
|
2006-08-27 02:21:20 +00:00
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
*/
|
2006-08-27 02:21:20 +00:00
|
|
|
|
2006-10-23 19:55:30 +00:00
|
|
|
// Gets the system temporary directory name
|
|
|
|
// @return null on failure to resolve the system temp dir
|
2006-08-27 02:21:20 +00:00
|
|
|
|
|
|
|
private function getTempDir()
|
|
|
|
{
|
2006-10-23 19:55:30 +00:00
|
|
|
/**
|
2006-08-27 02:21:20 +00:00
|
|
|
if(function_exists('sys_get_temp_dir')) {
|
2006-10-23 19:55:30 +00:00
|
|
|
$tempdir = sys_get_temp_dir();
|
2006-08-27 02:21:20 +00:00
|
|
|
} elseif (!empty($_ENV['TMP'])) {
|
|
|
|
$tempdir = $_ENV['TMP'];
|
|
|
|
} elseif (!empty($_ENV['TMPDIR'])) {
|
|
|
|
$tempdir = $_ENV['TMPDIR'];
|
|
|
|
} elseif (!empty($_ENV['TEMP'])) {
|
|
|
|
$tempdir = $_ENV['TEMP'];
|
|
|
|
} else {
|
|
|
|
//a little bit of chewing gum here will do the trick
|
|
|
|
$tempdir = dirname(tempnam('/THIS_REALLY_SHOULD_NOT_EXISTS', 'na'));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (empty($tempdir)) { return null; }
|
2006-10-23 19:55:30 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
$tempdir = rtrim($tempdir, '/');
|
|
|
|
$tempdir .= DIRECTORY_SEPARATOR;
|
2006-10-23 19:55:30 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
if (is_writable($tempdir) == false) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
$dir = tempnam($tempdir, 'doctrine_tests');
|
2006-10-23 19:55:30 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
@unlink($dir);
|
|
|
|
@rmdir($dir);
|
2006-10-23 19:55:30 +00:00
|
|
|
|
2006-08-27 02:21:20 +00:00
|
|
|
mkdir($dir);
|
|
|
|
$dir .= DIRECTORY_SEPARATOR;
|
2006-10-23 19:55:30 +00:00
|
|
|
|
|
|
|
return $dir;
|
|
|
|
*/
|
2006-08-27 02:21:20 +00:00
|
|
|
}
|
2006-10-23 19:55:30 +00:00
|
|
|
}
|