From 69c8531deb1091afa4faa5a45cb8b0d0a25cc19a Mon Sep 17 00:00:00 2001 From: zYne Date: Tue, 12 Jun 2007 18:26:27 +0000 Subject: [PATCH] test files for the foreign key support --- tests/Export/PgsqlTestCase.php | 7 +++ tests/Export/_files/FooRecord.php | 89 +++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 tests/Export/_files/FooRecord.php diff --git a/tests/Export/PgsqlTestCase.php b/tests/Export/PgsqlTestCase.php index 7f512c4e6..d01a98bda 100644 --- a/tests/Export/PgsqlTestCase.php +++ b/tests/Export/PgsqlTestCase.php @@ -77,5 +77,12 @@ class Doctrine_Export_Pgsql_TestCase extends Doctrine_UnitTestCase $this->assertEqual($this->adapter->pop(), 'CREATE TABLE mytable (name CHAR(10), type INT, PRIMARY KEY(name, type))'); } + public function testExportSql() + { + $sql = $this->export->exportSql(dirname(__FILE__) . DIRECTORY_SEPARATOR . '_files'); + + print "
";
+        print_r($sql);
+    }
 }
 ?>
diff --git a/tests/Export/_files/FooRecord.php b/tests/Export/_files/FooRecord.php
new file mode 100644
index 000000000..d857fd2f2
--- /dev/null
+++ b/tests/Export/_files/FooRecord.php
@@ -0,0 +1,89 @@
+setTableName('foo');
+        
+        $this->hasColumn('name', 'string', 200, array('notnull' => true));
+        $this->hasColumn('parent_id', 'integer');
+        $this->hasColumn('local_foo', 'integer');
+    }
+    public function setUp()
+    {
+        $this->hasMany('FooRecord as FooFriend', array('local'    => 'foo1',
+                                                       'foreign'  => 'foo2',
+                                                       'equal'    => true,
+                                                       'refClass' => 'FooReferenceRecord',
+                                                       ));
+
+        $this->hasMany('FooRecord as FooParents', array('local'    => 'foo1',
+                                                        'foreign'  => 'foo2',
+                                                        'refClass' => 'FooReferenceRecord',
+                                                        'onDelete' => 'CASCADE',
+                                                        ));
+
+        $this->hasMany('FooRecord as FooChildren', array('local'    => 'foo2',
+                                                         'foreign'  => 'foo1',
+                                                         'refClass' => 'FooReferenceRecord',
+                                                         ));
+
+        $this->hasMany('FooRecord as Children', array('local' => 'id', 'foreign' => 'parent_id'));
+
+        $this->hasOne('FooRecord as Parent', array('local' => 'parent_id', 'foreign' => 'id', 'onDelete' => 'CASCADE'));
+        $this->hasOne('FooForeignlyOwnedWithPk', array('local' => 'id', 'foreign' => 'id', 'constraint' => true));
+        $this->hasOne('FooLocallyOwned', array('local' => 'local_foo', 'onDelete' => 'RESTRICT'));
+
+    }
+}
+class FooBarRecord extends Doctrine_Record
+{
+    public function setTableDefinition()
+    {
+        $this->hasColumn('fooId', 'integer', null, array('primary' => true)); 
+        $this->hasColumn('barId', 'integer', null, array('primary' => true)); 	
+    }
+}
+class BarRecord extends Doctrine_Record 
+{
+    public function setTableDefinition()
+    {
+    	$this->hasColumn('name', 'string', 200);
+    }
+}
+class FooLocallyOwned extends Doctrine_Record
+{
+    public function setTableDefinition()
+    {
+        $this->hasColumn('name', 'string', 200);
+    }
+}
+class FooForeignlyOwned extends Doctrine_Record
+{
+    public function setTableDefinition()
+    {
+        $this->hasColumn('name', 'string', 200);
+        $this->hasColumn('fooId', 'integer');
+    }
+}
+class FooForeignlyOwnedWithPk extends Doctrine_Record
+{
+    public function setTableDefinition()
+    {
+        $this->hasColumn('name', 'string', 200);
+    }
+    public function setUp()
+    {
+        $this->hasOne('FooRecord', array('local' => 'id', 'foreign' => 'id'));
+    }
+}
+class FooReferenceRecord extends Doctrine_Record
+{
+    public function setTableDefinition()
+    {
+        $this->setTableName('foo_reference');
+        
+        $this->hasColumn('foo1', 'integer', null, array('primary' => true));
+        $this->hasColumn('foo2', 'integer', null, array('primary' => true));
+    }
+}