2006-10-26 01:12:30 +04:00
|
|
|
<?php
|
|
|
|
class M2MTest extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('name', 'string', 200);
|
|
|
|
$this->hasColumn('child_id', 'integer');
|
|
|
|
}
|
|
|
|
public function setUp() {
|
2007-03-22 01:11:18 +03:00
|
|
|
|
2006-10-26 01:12:30 +04:00
|
|
|
$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');
|
2006-10-30 02:24:50 +03:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
class RelationErrorTest extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('name', 'string', 200);
|
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
$this->hasMany('RTCUnknown', 'JC1.c1_id');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
class M2MTest2 extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('oid', 'integer', 11, array('autoincrement', 'primary'));
|
|
|
|
$this->hasColumn('name', 'string', 20);
|
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
$this->hasMany('RTC4 as RTC5', 'JC3.c1_id');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
class RTCUnknown extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('name', 'string', 200);
|
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
$this->hasMany('M2MTest', 'JC2.c2_id');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
class JC3 extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('c1_id', 'integer');
|
|
|
|
$this->hasColumn('c2_id', 'integer');
|
2006-10-26 01:12:30 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
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');
|
|
|
|
}
|
|
|
|
}
|
2006-10-30 02:24:50 +03:00
|
|
|
class RTC4 extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('oid', 'integer', 11, array('autoincrement', 'primary'));
|
|
|
|
$this->hasColumn('name', 'string', 20);
|
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
$this->hasMany('M2MTest2', 'JC3.c2_id');
|
|
|
|
}
|
|
|
|
}
|
2006-10-26 01:12:30 +04:00
|
|
|
|
|
|
|
class Doctrine_Relation_ManyToMany_TestCase extends Doctrine_UnitTestCase {
|
|
|
|
public function prepareData() { }
|
|
|
|
public function prepareTables() {
|
|
|
|
parent::prepareTables();
|
|
|
|
}
|
2006-10-30 02:24:50 +03:00
|
|
|
|
|
|
|
public function testManyToManyRelationWithAliasesAndCustomPKs() {
|
|
|
|
$component = new M2MTest2();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('RTC5');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertTrue($rel instanceof Doctrine_Relation_Association);
|
|
|
|
|
|
|
|
$this->assertTrue($component->RTC5 instanceof Doctrine_Collection);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('JC3');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertEqual($rel->getLocal(), 'oid');
|
|
|
|
}
|
|
|
|
public function testJoinComponent() {
|
|
|
|
$component = new JC3();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('M2MTest2');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertEqual($rel->getForeign(), 'oid');
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('RTC4');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertEqual($rel->getForeign(), 'oid');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testManyToManyRelationFetchingWithAliasesAndCustomPKs() {
|
|
|
|
$q = new Doctrine_Query();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$q->from('M2MTest2 m LEFT JOIN m.RTC5');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
$q->execute();
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUnknownManyToManyRelation() {
|
|
|
|
try {
|
2007-03-22 01:11:18 +03:00
|
|
|
$component = new RelationErrorTest();
|
|
|
|
|
|
|
|
|
2006-10-30 02:24:50 +03:00
|
|
|
$rel = $component->getTable()->getRelation('RTCUnknown');
|
|
|
|
$this->fail();
|
|
|
|
} catch(Doctrine_Table_Exception $e) {
|
|
|
|
$this->pass();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
public function testManyToManyRelationFetchingWithAliasesAndCustomPKs2() {
|
|
|
|
$q = new Doctrine_Query();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$q->from('M2MTest2 m INNER JOIN m.JC3');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
$q->execute();
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
}
|
2006-10-26 01:12:30 +04:00
|
|
|
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();
|
|
|
|
|
|
|
|
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);
|
2006-11-18 23:27:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testManyToManySimpleUpdate() {
|
|
|
|
$component = $this->connection->getTable('M2MTest')->find(1);
|
|
|
|
|
|
|
|
$this->assertEqual($component->name, 2);
|
|
|
|
|
|
|
|
$component->name = 'changed name';
|
|
|
|
|
|
|
|
$component->save();
|
|
|
|
|
|
|
|
$this->assertEqual($component->name, 'changed name');
|
2006-10-26 01:12:30 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|