1
0
mirror of synced 2025-01-18 22:41:43 +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[] = "Component : ".$table->getComponentName();
$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>";
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
* @return integer
*/
final public function getState() {
public function getState() {
return $this->_state;
}
/**
@ -504,6 +504,7 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* returns / assigns the state of this record
*
* @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
* @return null|integer
@ -514,7 +515,7 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
}
$err = false;
if(is_integer($state)) {
if($state >= 1 && $state <= 6)
$this->_state = $state;
else

View File

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

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() {
$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 {
@ -25,12 +23,7 @@ class HasOneToOne 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 {
}
@ -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 {
public function prepareData() { }
public function prepareTables() {
$this->tables = array('M2M', 'RelationTest', 'JoinTable');
parent::prepareTables();
}
public function testOneToManyTreeRelationWithConcreteInheritance() {
$component = new RelationTestChild();
@ -98,36 +84,6 @@ class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
$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() {
$this->manager->setAttribute(Doctrine::ATTR_CREATE_TABLES, false);

View File

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