Commit 1fcddf72 authored by pookey's avatar pookey

Refs #375

parent 96c1f16c
...@@ -36,7 +36,7 @@ class Doctrine_Enum_TestCase extends Doctrine_UnitTestCase ...@@ -36,7 +36,7 @@ class Doctrine_Enum_TestCase extends Doctrine_UnitTestCase
{ } { }
public function prepareTables() public function prepareTables()
{ {
$this->tables = array("EnumTest"); $this->tables = array("EnumTest", "EnumTest2", "EnumTest3");
parent::prepareTables(); parent::prepareTables();
} }
...@@ -171,5 +171,22 @@ class Doctrine_Enum_TestCase extends Doctrine_UnitTestCase ...@@ -171,5 +171,22 @@ class Doctrine_Enum_TestCase extends Doctrine_UnitTestCase
$this->assertTrue($f); $this->assertTrue($f);
} }
public function testEnumWithLeftJoin()
{
// sorry, odd I know, best I can do... pookey!
try {
$q = new Doctrine_Query($this->connection);
$q->select('e.*, f.*, g.status')
->from('EnumTest e')
->innerjoin('e.Enum2 g')
->leftjoin('e.Enum3 f')
->where("e.status = 'verified'")
->limit(1)
->execute();
$this->assertNotEqual($q->getQuery(), "SELECT e.id AS e__id, e.status AS e__status, e.text AS e__text, e2.id AS e2__id, e2.status AS e2__status, e3.text AS e3__text FROM enum_test e INNER JOIN enum_test2 e2 ON e.id = e2.enum_test_id LEFT JOIN enum_test3 e3 ON e.text = e3.text WHERE e.id IN (SELECT DISTINCT e4.id FROM enum_test e4 INNER JOIN enum_test2 e5 ON e4.id = e5.enum_test_id LEFT JOIN enum_test3 e6 ON e4.text = e6.text WHERE e4.status = 'verified' LIMIT 1) AND e.status = 'verified'");
} catch (Exception $e) {
$this->fail();
}
}
} }
?> ?>
...@@ -412,9 +412,26 @@ class ORM_AccessControlsGroups extends Doctrine_Record ...@@ -412,9 +412,26 @@ class ORM_AccessControlsGroups extends Doctrine_Record
} }
class EnumTest extends Doctrine_Record class EnumTest extends Doctrine_Record
{ {
public function setTableDefinition() public function setTableDefinition() {
{ $this->hasColumn('status', 'enum', 11, array('values' => array('open', 'verified', 'closed')));
$this->hasColumn('text', 'string');
}
public function setUp() {
$this->ownsMany('EnumTest2 as Enum2', array('local' => 'id', 'foreign' => 'enum_test_id'));
$this->ownsMany('EnumTest3 as Enum3', array('local' => 'text', 'foreign' => 'text'));
}
}
class EnumTest2 extends Doctrine_Record
{
public function setTableDefinition() {
$this->hasColumn('status', 'enum', 11, array('values' => array('open', 'verified', 'closed'))); $this->hasColumn('status', 'enum', 11, array('values' => array('open', 'verified', 'closed')));
$this->hasColumn('enum_test_id', 'integer');
}
}
class EnumTest3 extends Doctrine_Record
{
public function setTableDefinition() {
$this->hasColumn('text', 'string', 10, array('primary' => true));
} }
} }
class FilterTest extends Doctrine_Record { class FilterTest extends Doctrine_Record {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment