2006-10-01 14:10:11 +04:00
|
|
|
<?php
|
2006-10-23 23:55:30 +04:00
|
|
|
|
2006-10-20 22:21:42 +04:00
|
|
|
class RelationTest extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
2006-10-23 23:55:30 +04:00
|
|
|
$this->hasColumn('name', 'string', 200);
|
2006-10-26 00:02:40 +04:00
|
|
|
$this->hasColumn('child_id', 'integer');
|
2006-10-20 22:21:42 +04:00
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
$this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id');
|
2006-10-26 00:02:40 +04:00
|
|
|
$this->hasMany('M2M as AliasM2M', 'JoinTable.c1_id');
|
|
|
|
// $this->hasMany('M2M as AliasM2M2', 'JoinTable.c1_id');
|
2006-10-20 22:21:42 +04:00
|
|
|
}
|
|
|
|
}
|
2006-10-23 20:19:47 +04:00
|
|
|
class RelationTestChild extends RelationTest {
|
|
|
|
public function setUp() {
|
2006-10-23 23:55:30 +04:00
|
|
|
$this->hasOne('RelationTest as Parent', 'RelationTestChild.child_id');
|
2006-10-23 20:19:47 +04:00
|
|
|
|
|
|
|
$this->ownsMany('RelationTestChild as Children', 'RelationTestChild.child_id');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-10-20 22:21:42 +04:00
|
|
|
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 {
|
|
|
|
|
|
|
|
}
|
|
|
|
class OwnsOneToManyWithAlias extends Doctrine_Record {
|
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('component_id', 'integer');
|
|
|
|
}
|
|
|
|
public function setUp() {
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
2006-10-26 00:02:40 +04:00
|
|
|
class M2M extends Doctrine_Record {
|
2006-10-23 23:55:30 +04:00
|
|
|
public function setTableDefinition() {
|
|
|
|
$this->hasColumn('name', 'string', 200);
|
|
|
|
}
|
2006-10-20 22:21:42 +04:00
|
|
|
public function setUp() {
|
|
|
|
$this->hasMany('RelationTest as AliasM2M', 'JoinTable.c2_id');
|
|
|
|
}
|
|
|
|
}
|
2006-10-01 14:10:11 +04:00
|
|
|
class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
|
|
|
|
public function prepareData() { }
|
2006-10-23 20:19:47 +04:00
|
|
|
public function prepareTables() {
|
2006-10-26 00:02:40 +04:00
|
|
|
$this->tables = array('M2M', 'RelationTest', 'JoinTable');
|
2006-10-23 23:55:30 +04:00
|
|
|
|
|
|
|
parent::prepareTables();
|
2006-10-20 22:21:42 +04:00
|
|
|
}
|
2006-10-23 20:19:47 +04:00
|
|
|
public function testOneToManyTreeRelationWithConcreteInheritance() {
|
|
|
|
$component = new RelationTestChild();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('Children');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertTrue($rel instanceof Doctrine_Relation_ForeignKey);
|
|
|
|
|
|
|
|
$this->assertTrue($component->Children instanceof Doctrine_Collection);
|
|
|
|
$this->assertTrue($component->Children[0] instanceof RelationTestChild);
|
|
|
|
}
|
2006-10-20 22:21:42 +04:00
|
|
|
|
2006-10-23 20:19:47 +04:00
|
|
|
|
|
|
|
public function testOneToOneTreeRelationWithConcreteInheritance() {
|
|
|
|
$component = new RelationTestChild();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('Parent');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertTrue($rel instanceof Doctrine_Relation_LocalKey);
|
|
|
|
}
|
2006-10-20 22:21:42 +04:00
|
|
|
public function testOneToManyOwnsRelationWithAliases() {
|
2006-10-23 23:55:30 +04:00
|
|
|
|
2006-10-20 22:21:42 +04:00
|
|
|
|
|
|
|
$component = new RelationTest();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('AliasO2M');
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
|
|
|
|
$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);
|
2006-10-23 20:19:47 +04:00
|
|
|
|
|
|
|
$this->assertTrue($component->AliasM2M instanceof Doctrine_Collection);
|
|
|
|
|
2006-10-23 23:55:30 +04:00
|
|
|
$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);
|
2006-10-01 14:10:11 +04:00
|
|
|
}
|
2006-10-23 20:19:47 +04:00
|
|
|
|
|
|
|
|
2006-10-01 14:10:11 +04:00
|
|
|
public function testManyToManyRelation() {
|
2006-10-23 23:55:30 +04:00
|
|
|
$this->manager->setAttribute(Doctrine::ATTR_CREATE_TABLES, false);
|
2006-10-01 14:10:11 +04:00
|
|
|
$user = new User();
|
2006-10-23 20:19:47 +04:00
|
|
|
|
2006-10-01 14:10:11 +04:00
|
|
|
// test that join table relations can be initialized even before the association have been initialized
|
|
|
|
try {
|
|
|
|
$user->Groupuser;
|
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Table_Exception $e) {
|
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertTrue($user->getTable()->getRelation('Groupuser') instanceof Doctrine_Relation_ForeignKey);
|
|
|
|
$this->assertTrue($user->getTable()->getRelation('Group') instanceof Doctrine_Relation_Association);
|
|
|
|
}
|
|
|
|
public function testOneToOneLocalKeyRelation() {
|
|
|
|
$user = new User();
|
|
|
|
|
|
|
|
$this->assertTrue($user->getTable()->getRelation('Email') instanceof Doctrine_Relation_LocalKey);
|
|
|
|
}
|
|
|
|
public function testOneToOneForeignKeyRelation() {
|
|
|
|
$user = new User();
|
|
|
|
|
|
|
|
$this->assertTrue($user->getTable()->getRelation('Account') instanceof Doctrine_Relation_ForeignKey);
|
|
|
|
}
|
|
|
|
public function testOneToManyForeignKeyRelation() {
|
|
|
|
$user = new User();
|
|
|
|
|
|
|
|
$this->assertTrue($user->getTable()->getRelation('Phonenumber') instanceof Doctrine_Relation_ForeignKey);
|
2006-10-20 22:21:42 +04:00
|
|
|
$this->manager->setAttribute(Doctrine::ATTR_CREATE_TABLES, true);
|
2006-10-01 14:10:11 +04:00
|
|
|
}
|
2006-10-20 22:21:42 +04:00
|
|
|
|
2006-10-23 20:19:47 +04:00
|
|
|
|
2006-10-01 14:10:11 +04:00
|
|
|
}
|