2006-10-01 10:10:11 +00:00
|
|
|
<?php
|
2007-06-14 21:09:01 +00:00
|
|
|
/*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
|
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
|
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
|
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
* This software consists of voluntary contributions made by many individuals
|
|
|
|
* and is licensed under the LGPL. For more information, see
|
|
|
|
* <http://www.phpdoctrine.com>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Doctrine_Relation_TestCase
|
|
|
|
*
|
|
|
|
* @package Doctrine
|
|
|
|
* @author Konsta Vesterinen <kvesteri@cc.hut.fi>
|
|
|
|
* @license http://www.opensource.org/licenses/lgpl-license.php LGPL
|
|
|
|
* @category Object Relational Mapping
|
|
|
|
* @link www.phpdoctrine.com
|
|
|
|
* @since 1.0
|
|
|
|
* @version $Revision$
|
|
|
|
*/
|
2007-09-02 17:31:35 +00:00
|
|
|
class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase
|
|
|
|
{
|
2007-04-11 19:12:52 +00:00
|
|
|
public function prepareData()
|
|
|
|
{ }
|
|
|
|
public function prepareTables()
|
2007-06-14 21:09:01 +00:00
|
|
|
{
|
|
|
|
$this->tables = array('RelationTest', 'RelationTestChild', 'Group', 'Groupuser', 'User', 'Email', 'Account', 'Phonenumber');
|
2007-08-14 21:21:41 +00:00
|
|
|
|
|
|
|
parent::prepareTables();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInitData()
|
|
|
|
{
|
|
|
|
$user = new User();
|
|
|
|
|
|
|
|
$user->name = 'zYne';
|
|
|
|
$user->Group[0]->name = 'Some Group';
|
|
|
|
$user->Group[1]->name = 'Other Group';
|
|
|
|
$user->Group[2]->name = 'Third Group';
|
|
|
|
|
|
|
|
$user->Phonenumber[0]->phonenumber = '123 123';
|
|
|
|
$user->Phonenumber[1]->phonenumber = '234 234';
|
|
|
|
$user->Phonenumber[2]->phonenumber = '456 456';
|
|
|
|
|
|
|
|
$user->Email->address = 'someone@some.where';
|
|
|
|
|
|
|
|
$user->save();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUnlinkSupportsManyToManyRelations()
|
|
|
|
{
|
|
|
|
$users = Doctrine_Query::create()->from('User u')->where('u.name = ?', array('zYne'))->execute();
|
|
|
|
|
|
|
|
$user = $users[0];
|
|
|
|
|
|
|
|
$this->assertEqual($user->Group->count(), 3);
|
|
|
|
|
|
|
|
$user->unlink('Group', array(2, 3, 4));
|
|
|
|
|
|
|
|
$this->assertEqual($user->Group->count(), 0);
|
|
|
|
|
|
|
|
$this->conn->clear();
|
|
|
|
|
|
|
|
$groups = Doctrine_Query::create()->from('Group g')->execute();
|
|
|
|
|
|
|
|
$this->assertEqual($groups->count(), 3);
|
|
|
|
|
2008-02-03 21:29:57 +00:00
|
|
|
$links = Doctrine_Query::create()->from('Groupuser gu')->execute();
|
2007-08-14 21:21:41 +00:00
|
|
|
|
|
|
|
$this->assertEqual($links->count(), 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testUnlinkSupportsOneToManyRelations()
|
|
|
|
{
|
2007-09-03 14:57:18 +00:00
|
|
|
$this->conn->clear();
|
2007-08-14 21:21:41 +00:00
|
|
|
|
|
|
|
$users = Doctrine_Query::create()->from('User u')->where('u.name = ?', array('zYne'))->execute();
|
|
|
|
|
|
|
|
$user = $users[0];
|
|
|
|
|
|
|
|
$this->assertEqual($user->Phonenumber->count(), 3);
|
|
|
|
|
|
|
|
$user->unlink('Phonenumber', array(1, 2, 3));
|
|
|
|
|
|
|
|
$this->assertEqual($user->Phonenumber->count(), 0);
|
|
|
|
|
|
|
|
$this->conn->clear();
|
|
|
|
|
|
|
|
$phonenumber = Doctrine_Query::create()->from('Phonenumber p')->execute();
|
|
|
|
|
|
|
|
$this->assertEqual($phonenumber->count(), 3);
|
|
|
|
$this->assertEqual($phonenumber[0]->entity_id, null);
|
|
|
|
$this->assertEqual($phonenumber[1]->entity_id, null);
|
|
|
|
$this->assertEqual($phonenumber[2]->entity_id, null);
|
2006-10-20 18:21:42 +00:00
|
|
|
}
|
2006-10-25 21:12:30 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
public function testOneToManyTreeRelationWithConcreteInheritance() {
|
2007-04-11 19:12:52 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
$component = new RelationTestChild();
|
2007-04-11 19:12:52 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
try {
|
|
|
|
$rel = $component->getTable()->getRelation('Children');
|
2007-04-11 19:12:52 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
$this->pass();
|
|
|
|
} catch(Doctrine_Exception $e) {
|
2007-04-11 19:12:52 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
$this->fail();
|
|
|
|
}
|
|
|
|
$this->assertTrue($rel instanceof Doctrine_Relation_ForeignKey);
|
2007-04-11 19:12:52 +00:00
|
|
|
|
2006-10-23 16:19:47 +00:00
|
|
|
$this->assertTrue($component->Children instanceof Doctrine_Collection);
|
|
|
|
$this->assertTrue($component->Children[0] instanceof RelationTestChild);
|
|
|
|
}
|
2006-10-20 18:21:42 +00:00
|
|
|
|
2006-10-23 16:19:47 +00: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-01 10:10:11 +00:00
|
|
|
public function testManyToManyRelation() {
|
|
|
|
$user = new User();
|
2007-06-14 21:26:45 +00:00
|
|
|
|
2006-10-01 10:10:11 +00:00
|
|
|
// test that join table relations can be initialized even before the association have been initialized
|
|
|
|
try {
|
2008-02-03 21:29:57 +00:00
|
|
|
$user->Groupuser;
|
2006-10-01 10:10:11 +00:00
|
|
|
$this->pass();
|
2007-06-14 21:09:01 +00:00
|
|
|
} catch(Doctrine_Exception $e) {
|
2006-10-01 10:10:11 +00:00
|
|
|
$this->fail();
|
|
|
|
}
|
2007-06-14 21:09:01 +00:00
|
|
|
//$this->assertTrue($user->getTable()->getRelation('Groupuser') instanceof Doctrine_Relation_ForeignKey);
|
2006-10-01 10:10:11 +00:00
|
|
|
$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);
|
2007-04-11 19:12:52 +00:00
|
|
|
}
|
2007-06-14 21:09:01 +00:00
|
|
|
}
|