1
0
mirror of synced 2025-01-19 06:51:40 +03:00

Fixes #194, added Doctrine_Relation_ManyToMany_TestCase

Ticket: 194
This commit is contained in:
zYne 2006-10-25 21:12:30 +00:00
parent 0835a57ce1
commit ff85f8c668
6 changed files with 273 additions and 125 deletions

View File

@ -140,11 +140,6 @@ class Doctrine_Lib {
$r[] = "<pre>"; $r[] = "<pre>";
$r[] = "Component : ".$table->getComponentName(); $r[] = "Component : ".$table->getComponentName();
$r[] = "Table : ".$table->getTableName(); $r[] = "Table : ".$table->getTableName();
$r[] = "Repository : ".$table->getRepository()->count()." objects";
if($table->getCache() instanceof Doctrine_Cache_File) {
$r[] = "Cache : ".$table->getCache()->count()." objects";
$r[] = "Cache hits : ".array_sum($table->getCache()->getStats())." hits";
}
$r[] = "</pre>"; $r[] = "</pre>";
return implode("\n",$r)."<br>"; return implode("\n",$r)."<br>";
} }

View File

@ -496,7 +496,7 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* @see Doctrine_Record::STATE_* constants * @see Doctrine_Record::STATE_* constants
* @return integer * @return integer
*/ */
final public function getState() { public function getState() {
return $this->_state; return $this->_state;
} }
/** /**
@ -504,6 +504,7 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* returns / assigns the state of this record * returns / assigns the state of this record
* *
* @param integer|string $state if set, this method tries to set the record state to $state * @param integer|string $state if set, this method tries to set the record state to $state
* @see Doctrine_Record::STATE_* constants
* *
* @throws Doctrine_Record_State_Exception if trying to set an unknown state * @throws Doctrine_Record_State_Exception if trying to set an unknown state
* @return null|integer * @return null|integer

View File

@ -460,7 +460,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* *
* @return array * @return array
*/ */
final public function getBounds() { public function getBounds() {
return $this->bound; return $this->bound;
} }
/** /**
@ -469,7 +469,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @param string $name * @param string $name
* @return array * @return array
*/ */
final public function getBound($name) { public function getBound($name) {
if( ! isset($this->bound[$name])) if( ! isset($this->bound[$name]))
throw new Doctrine_Table_Exception('Unknown bound '.$name); throw new Doctrine_Table_Exception('Unknown bound '.$name);
@ -481,9 +481,11 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @param string $name * @param string $name
* @return array * @return array
*/ */
final public function getBoundForName($name) { public function getBoundForName($name, $component) {
foreach($this->bound as $k => $bound) { foreach($this->bound as $k => $bound) {
if($bound[3] == $name) { $e = explode('.', $bound[0]);
if($bound[3] == $name && $e[0] == $component) {
return $this->bound[$k]; return $this->bound[$k];
} }
} }
@ -518,7 +520,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* *
* @return void * @return void
*/ */
final public function unbindAll() { public function unbindAll() {
$this->bound = array(); $this->bound = array();
$this->relations = array(); $this->relations = array();
$this->boundAliases = array(); $this->boundAliases = array();
@ -530,7 +532,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @param $name * @param $name
* @return boolean * @return boolean
*/ */
final public function unbind($name) { public function unbind($name) {
if( ! isset($this->bound[$name])) if( ! isset($this->bound[$name]))
return false; return false;
@ -551,9 +553,9 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* @param string $field * @param string $field
* @return void * @return void
*/ */
final public function bind($name,$field,$type,$localKey) { final public function bind($name, $field, $type, $localKey) {
if(isset($this->relations[$name])) if(isset($this->relations[$name]))
throw new Doctrine_Table_Exception('Relation already set for '.$name); unset($this->relations[$name]);
$e = explode(" as ",$name); $e = explode(" as ",$name);
$name = $e[0]; $name = $e[0];
@ -571,21 +573,15 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
* getComponentName * getComponentName
* @return string the component name * @return string the component name
*/ */
final public function getComponentName() { public function getComponentName() {
return $this->options['name']; return $this->options['name'];
} }
/** /**
* @return Doctrine_Connection * @return Doctrine_Connection
*/ */
final public function getConnection() { public function getConnection() {
return $this->connection; return $this->connection;
} }
/**
* @return Doctrine_Cache
*/
final public function getCache() {
return $this->cache;
}
/** /**
* hasRelatedComponent * hasRelatedComponent
* @return boolean * @return boolean
@ -662,7 +658,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
foreach(array_reverse($classes) as $class) { foreach(array_reverse($classes) as $class) {
try { try {
$bound = $table->getBoundForName($class); $bound = $table->getBoundForName($class, $component);
break; break;
} catch(Doctrine_Table_Exception $exc) { } } catch(Doctrine_Table_Exception $exc) { }
@ -670,11 +666,11 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
if( ! isset($local)) if( ! isset($local))
$local = $this->identifier; $local = $this->identifier;
$e2 = explode(".",$bound[0]); $e2 = explode('.', $bound[0]);
$fields = explode("-",$e2[1]); $fields = explode('-', $e2[1]);
if($e2[0] != $component) if($e2[0] != $component)
throw new Doctrine_Table_Exception($e2[0]." doesn't match ".$component); throw new Doctrine_Table_Exception($e2[0] . ' doesn\'t match ' . $component);
$associationTable = $this->connection->getTable($e2[0]); $associationTable = $this->connection->getTable($e2[0]);

View File

@ -0,0 +1,194 @@
<?php
class M2MTest extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('name', 'string', 200);
$this->hasColumn('child_id', 'integer');
}
public function setUp() {
$this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id');
$this->hasMany('RTC1 as RTC1', 'JC1.c1_id');
$this->hasMany('RTC2 as RTC2', 'JC1.c1_id');
$this->hasMany('RTC3 as RTC3', 'JC2.c1_id');
$this->hasMany('RTC3 as RTC4', 'JC1.c1_id');
}
}
class JC1 extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('c1_id', 'integer');
$this->hasColumn('c2_id', 'integer');
}
}
class JC2 extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('c1_id', 'integer');
$this->hasColumn('c2_id', 'integer');
}
}
class RTC1 extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('name', 'string', 200);
}
public function setUp() {
$this->hasMany('M2MTest as RTC1', 'JC1.c2_id');
}
}
class RTC2 extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('name', 'string', 200);
}
public function setUp() {
$this->hasMany('M2MTest as RTC2', 'JC1.c2_id');
}
}
class RTC3 extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('name', 'string', 200);
}
public function setUp() {
$this->hasMany('M2MTest as RTC3', 'JC2.c2_id');
$this->hasMany('M2MTest as RTC4', 'JC1.c2_id');
}
}
class Doctrine_Relation_ManyToMany_TestCase extends Doctrine_UnitTestCase {
public function prepareData() { }
public function prepareTables() {
parent::prepareTables();
}
public function testManyToManyHasRelationWithAliases4() {
$component = new M2MTest();
try {
$rel = $component->getTable()->getRelation('RTC4');
$this->pass();
} catch(Doctrine_Exception $e) {
$this->fail();
}
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
$this->assertTrue($component->RTC4 instanceof Doctrine_Collection);
}
public function testManyToManyHasRelationWithAliases3() {
$component = new M2MTest();
try {
$rel = $component->getTable()->getRelation('RTC3');
$this->pass();
} catch(Doctrine_Exception $e) {
$this->fail();
}
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
$this->assertTrue($component->RTC3 instanceof Doctrine_Collection);
}
public function testManyToManyHasRelationWithAliases() {
$component = new M2MTest();
$component->AliasO2M;
try {
$rel = $component->getTable()->getRelation('RTC1');
$this->pass();
} catch(Doctrine_Exception $e) {
$this->fail();
}
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
$this->assertTrue($component->RTC1 instanceof Doctrine_Collection);
}
public function testManyToManyHasRelationWithAliases2() {
$component = new M2MTest();
try {
$rel = $component->getTable()->getRelation('RTC2');
$this->pass();
} catch(Doctrine_Exception $e) {
$this->fail();
}
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
$this->assertTrue($component->RTC1 instanceof Doctrine_Collection);
}
public function testManyToManyRelationSaving() {
$component = new M2MTest();
$component->RTC1[0]->name = '1';
$component->RTC1[1]->name = '2';
$component->name = '2';
$count = $this->dbh->count();
$component->save();
$this->assertEqual($this->dbh->count(), ($count + 5));
$this->assertEqual($component->RTC1->count(), 2);
$component = $component->getTable()->find($component->id);
$this->assertEqual($component->RTC1->count(), 2);
// check that it doesn't matter saving the other M2M components as well
$component->RTC2[0]->name = '1';
$component->RTC2[1]->name = '2';
$count = $this->dbh->count();
$component->save();
$this->assertEqual($this->dbh->count(), ($count + 4));
$this->assertEqual($component->RTC2->count(), 2);
$component = $component->getTable()->find($component->id);
$this->assertEqual($component->RTC2->count(), 2);
}
public function testManyToManyRelationSaving2() {
$component = new M2MTest();
$component->RTC2[0]->name = '1';
$component->RTC2[1]->name = '2';
$component->name = '2';
$count = $this->dbh->count();
$component->save();
$this->assertEqual($this->dbh->count(), ($count + 5));
$this->assertEqual($component->RTC2->count(), 2);
$component = $component->getTable()->find($component->id);
$this->assertEqual($component->RTC2->count(), 2);
// check that it doesn't matter saving the other M2M components as well
$component->RTC1[0]->name = '1';
$component->RTC1[1]->name = '2';
$count = $this->dbh->count();
$component->save();
$this->assertEqual($this->dbh->count(), ($count + 4));
$this->assertEqual($component->RTC1->count(), 2);
$component = $component->getTable()->find($component->id);
$this->assertEqual($component->RTC1->count(), 2);
}
}
?>

View File

@ -7,8 +7,6 @@ class RelationTest extends Doctrine_Record {
} }
public function setUp() { public function setUp() {
$this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id'); $this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id');
$this->hasMany('M2M as AliasM2M', 'JoinTable.c1_id');
// $this->hasMany('M2M as AliasM2M2', 'JoinTable.c1_id');
} }
} }
class RelationTestChild extends RelationTest { class RelationTestChild extends RelationTest {
@ -25,12 +23,7 @@ class HasOneToOne extends Doctrine_Record {
class HasOneToOneWithAlias extends Doctrine_Record { class HasOneToOneWithAlias extends Doctrine_Record {
} }
class JoinTable extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('c1_id', 'integer');
$this->hasColumn('c2_id', 'integer');
}
}
class HasManyWithAlias extends Doctrine_Record { class HasManyWithAlias extends Doctrine_Record {
} }
@ -42,21 +35,14 @@ class OwnsOneToManyWithAlias extends Doctrine_Record {
} }
} }
class M2M extends Doctrine_Record {
public function setTableDefinition() {
$this->hasColumn('name', 'string', 200);
}
public function setUp() {
$this->hasMany('RelationTest as AliasM2M', 'JoinTable.c2_id');
}
}
class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase { class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
public function prepareData() { } public function prepareData() { }
public function prepareTables() { public function prepareTables() {
$this->tables = array('M2M', 'RelationTest', 'JoinTable');
parent::prepareTables(); parent::prepareTables();
} }
public function testOneToManyTreeRelationWithConcreteInheritance() { public function testOneToManyTreeRelationWithConcreteInheritance() {
$component = new RelationTestChild(); $component = new RelationTestChild();
@ -98,36 +84,6 @@ class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
$this->assertTrue($rel instanceof Doctrine_Relation_ForeignKey); $this->assertTrue($rel instanceof Doctrine_Relation_ForeignKey);
} }
public function testManyToManyHasRelationWithAliases() {
$component = new RelationTest();
try {
$rel = $component->getTable()->getRelation('AliasM2M');
$this->pass();
} catch(Doctrine_Exception $e) {
$this->fail();
}
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
$this->assertTrue($component->AliasM2M instanceof Doctrine_Collection);
$component->AliasM2M[0]->name = '1';
$component->AliasM2M[1]->name = '2';
$component->name = '2';
$count = $this->dbh->count();
$component->save();
$this->assertEqual($this->dbh->count(), ($count + 5));
$this->assertEqual($component->AliasM2M->count(), 2);
$component = $component->getTable()->find($component->id);
$this->assertEqual($component->AliasM2M->count(), 2);
}
public function testManyToManyRelation() { public function testManyToManyRelation() {
$this->manager->setAttribute(Doctrine::ATTR_CREATE_TABLES, false); $this->manager->setAttribute(Doctrine::ATTR_CREATE_TABLES, false);

View File

@ -2,64 +2,70 @@
ob_start(); ob_start();
require_once("ConfigurableTestCase.php"); require_once('ConfigurableTestCase.php');
require_once("ManagerTestCase.php"); require_once('ManagerTestCase.php');
require_once("ConnectionTestCase.php"); require_once('ConnectionTestCase.php');
require_once("ConnectionTransactionTestCase.php"); require_once('ConnectionTransactionTestCase.php');
require_once("TableTestCase.php"); require_once('TableTestCase.php');
require_once("EventListenerTestCase.php"); require_once('EventListenerTestCase.php');
require_once("BatchIteratorTestCase.php"); require_once('BatchIteratorTestCase.php');
require_once("CacheFileTestCase.php"); require_once('CacheFileTestCase.php');
require_once("RecordTestCase.php"); require_once('RecordTestCase.php');
require_once("RecordStateTestCase.php"); require_once('RecordStateTestCase.php');
require_once("RecordFilterTestCase.php"); require_once('RecordFilterTestCase.php');
require_once("AccessTestCase.php"); require_once('AccessTestCase.php');
require_once("ValidatorTestCase.php"); require_once('ValidatorTestCase.php');
require_once("CollectionTestCase.php"); require_once('CollectionTestCase.php');
require_once("PessimisticLockingTestCase.php"); require_once('PessimisticLockingTestCase.php');
require_once("EventListenerChainTestCase.php"); require_once('EventListenerChainTestCase.php');
require_once("CacheSqliteTestCase.php"); require_once('CacheSqliteTestCase.php');
require_once("CollectionOffsetTestCase.php"); require_once('CollectionOffsetTestCase.php');
require_once("CacheQuerySqliteTestCase.php"); require_once('CacheQuerySqliteTestCase.php');
require_once("ViewTestCase.php"); require_once('ViewTestCase.php');
require_once("RawSqlTestCase.php"); require_once('RawSqlTestCase.php');
require_once("CustomPrimaryKeyTestCase.php"); require_once('CustomPrimaryKeyTestCase.php');
require_once("FilterTestCase.php"); require_once('FilterTestCase.php');
require_once("QueryTestCase.php"); require_once('QueryTestCase.php');
require_once("QueryLimitTestCase.php"); require_once('QueryLimitTestCase.php');
require_once("QueryMultiJoinTestCase.php"); require_once('QueryMultiJoinTestCase.php');
require_once("QueryReferenceModelTestCase.php"); require_once('QueryReferenceModelTestCase.php');
require_once("QueryWhereTestCase.php"); require_once('QueryWhereTestCase.php');
require_once("QueryFromTestCase.php"); require_once('QueryFromTestCase.php');
require_once("QueryConditionTestCase.php"); require_once('QueryConditionTestCase.php');
require_once("QueryComponentAliasTestCase.php"); require_once('QueryComponentAliasTestCase.php');
require_once("QuerySubqueryTestCase.php"); require_once('QuerySubqueryTestCase.php');
require_once("QuerySelectTestCase.php"); require_once('QuerySelectTestCase.php');
require_once("QueryDeleteTestCase.php"); require_once('QueryDeleteTestCase.php');
require_once("QueryUpdateTestCase.php"); require_once('QueryUpdateTestCase.php');
require_once("DBTestCase.php"); require_once('RelationAccessTestCase.php');
require_once("SchemaTestCase.php"); require_once('RelationTestCase.php');
require_once("ImportTestCase.php"); require_once('RelationManyToManyTestCase.php');
require_once("BooleanTestCase.php");
require_once("EnumTestCase.php");
require_once("RelationAccessTestCase.php"); require_once('DBTestCase.php');
require_once("RelationTestCase.php"); require_once('SchemaTestCase.php');
require_once("DataDictSqliteTestCase.php"); require_once('ImportTestCase.php');
require_once("CustomResultSetOrderTestCase.php"); require_once('BooleanTestCase.php');
require_once('EnumTestCase.php');
require_once('DataDictSqliteTestCase.php');
require_once('CustomResultSetOrderTestCase.php');
error_reporting(E_ALL); error_reporting(E_ALL);
print "<pre>"; print '<pre>';
$test = new GroupTest("Doctrine Framework Unit Tests"); $test = new GroupTest('Doctrine Framework Unit Tests');
$test->addTestCase(new Doctrine_Relation_TestCase()); $test->addTestCase(new Doctrine_Relation_TestCase());
$test->addTestCase(new Doctrine_Relation_ManyToMany_TestCase());
$test->addTestCase(new Doctrine_Record_TestCase()); $test->addTestCase(new Doctrine_Record_TestCase());
$test->addTestCase(new Doctrine_Record_State_TestCase()); $test->addTestCase(new Doctrine_Record_State_TestCase());
@ -174,9 +180,9 @@ if (TextReporter::inCli()) {
} else { } else {
if (isset($_POST)) if (isset($_POST))
{ {
$dsn = isset($_POST['dsn'])?$_POST['dsn']:null; $dsn = isset($_POST["dsn"])?$_POST["dsn"]:null;
$username = isset($_POST['username'])?$_POST['username']:null; $username = isset($_POST["username"])?$_POST["username"]:null;
$password = isset($_POST['password'])?$_POST['password']:null; $password = isset($_POST["password"])?$_POST["password"]:null;
} }
$test->run(new MyReporter()); $test->run(new MyReporter());
$output = ob_get_clean(); $output = ob_get_clean();