parent
e06f0be65d
commit
0835a57ce1
@ -512,9 +512,14 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
|
|||||||
if($state == null) {
|
if($state == null) {
|
||||||
return $this->_state;
|
return $this->_state;
|
||||||
}
|
}
|
||||||
|
$err = false;
|
||||||
if(is_integer($state)) {
|
if(is_integer($state)) {
|
||||||
|
|
||||||
if($state >= 1 && $state <= 6)
|
if($state >= 1 && $state <= 6)
|
||||||
$this->_state = $state;
|
$this->_state = $state;
|
||||||
|
else
|
||||||
|
$err = true;
|
||||||
|
|
||||||
} elseif(is_string($state)) {
|
} elseif(is_string($state)) {
|
||||||
$upper = strtoupper($state);
|
$upper = strtoupper($state);
|
||||||
switch($upper) {
|
switch($upper) {
|
||||||
@ -526,9 +531,12 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
|
|||||||
case 'DELETED':
|
case 'DELETED':
|
||||||
$this->_state = constant('Doctrine_Record::STATE_' . $upper);
|
$this->_state = constant('Doctrine_Record::STATE_' . $upper);
|
||||||
break;
|
break;
|
||||||
|
default:
|
||||||
|
$err = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($err)
|
||||||
throw new Doctrine_Record_State_Exception('Unknown record state ' . $state);
|
throw new Doctrine_Record_State_Exception('Unknown record state ' . $state);
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
@ -177,7 +177,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
|
|||||||
$names = array_reverse($names);
|
$names = array_reverse($names);
|
||||||
|
|
||||||
// create database table
|
// create database table
|
||||||
if(method_exists($record,"setTableDefinition")) {
|
if(method_exists($record, 'setTableDefinition')) {
|
||||||
$record->setTableDefinition();
|
$record->setTableDefinition();
|
||||||
|
|
||||||
$this->columnCount = count($this->columns);
|
$this->columnCount = count($this->columns);
|
||||||
@ -185,7 +185,7 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
|
|||||||
if(isset($this->columns)) {
|
if(isset($this->columns)) {
|
||||||
|
|
||||||
// get the declaring class of setTableDefinition method
|
// get the declaring class of setTableDefinition method
|
||||||
$method = new ReflectionMethod($this->options['name'],"setTableDefinition");
|
$method = new ReflectionMethod($this->options['name'], 'setTableDefinition');
|
||||||
$class = $method->getDeclaringClass();
|
$class = $method->getDeclaringClass();
|
||||||
|
|
||||||
if( ! isset($this->options['tableName']))
|
if( ! isset($this->options['tableName']))
|
||||||
@ -193,9 +193,17 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
|
|||||||
|
|
||||||
switch(count($this->primaryKeys)):
|
switch(count($this->primaryKeys)):
|
||||||
case 0:
|
case 0:
|
||||||
$this->columns = array_merge(array("id" => array("integer", 20, array("autoincrement" => true, "primary" => true))), $this->columns);
|
$this->columns = array_merge(array('id' =>
|
||||||
$this->primaryKeys[] = "id";
|
array('integer',
|
||||||
$this->identifier = "id";
|
20,
|
||||||
|
array('autoincrement' => true,
|
||||||
|
'primary' => true
|
||||||
|
)
|
||||||
|
)
|
||||||
|
), $this->columns);
|
||||||
|
|
||||||
|
$this->primaryKeys[] = 'id';
|
||||||
|
$this->identifier = 'id';
|
||||||
$this->identifierType = Doctrine_Identifier::AUTO_INCREMENT;
|
$this->identifierType = Doctrine_Identifier::AUTO_INCREMENT;
|
||||||
$this->columnCount++;
|
$this->columnCount++;
|
||||||
break;
|
break;
|
||||||
@ -964,9 +972,8 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
|
|||||||
*/
|
*/
|
||||||
final public function enumValue($field, $index) {
|
final public function enumValue($field, $index) {
|
||||||
if ($index instanceof Doctrine_Null)
|
if ($index instanceof Doctrine_Null)
|
||||||
{
|
|
||||||
return $index;
|
return $index;
|
||||||
}
|
|
||||||
return isset($this->options['enumMap'][$field][$index]) ? $this->options['enumMap'][$field][$index] : $index;
|
return isset($this->options['enumMap'][$field][$index]) ? $this->options['enumMap'][$field][$index] : $index;
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
@ -343,10 +343,16 @@ $menu = array("Getting started" =>
|
|||||||
"Transactions" => array(
|
"Transactions" => array(
|
||||||
"Introduction",
|
"Introduction",
|
||||||
"Unit of work",
|
"Unit of work",
|
||||||
|
"Nesting",
|
||||||
|
"Savepoints",
|
||||||
"Locking strategies" =>
|
"Locking strategies" =>
|
||||||
array("Pessimistic locking",
|
array("Pessimistic locking",
|
||||||
"Optimistic locking"),
|
"Optimistic locking"),
|
||||||
"Nesting"
|
|
||||||
|
"Lock modes",
|
||||||
|
"Isolation levels",
|
||||||
|
"Deadlocks",
|
||||||
|
|
||||||
),
|
),
|
||||||
/**
|
/**
|
||||||
"Developer components" => array(
|
"Developer components" => array(
|
||||||
@ -466,12 +472,12 @@ $menu = array("Getting started" =>
|
|||||||
if( ! file_exists("docs/$title - $k - $v2.php")) {
|
if( ! file_exists("docs/$title - $k - $v2.php")) {
|
||||||
$missing[0]++;
|
$missing[0]++;
|
||||||
$str .= " [ <font color='red'>doc</font> ] ";
|
$str .= " [ <font color='red'>doc</font> ] ";
|
||||||
touch("docs/$title - $k - $v2.php");
|
//touch("docs/$title - $k - $v2.php");
|
||||||
}
|
}
|
||||||
if( ! file_exists("codes/$title - $k - $v2.php")) {
|
if( ! file_exists("codes/$title - $k - $v2.php")) {
|
||||||
$missing[1]++;
|
$missing[1]++;
|
||||||
$str .= " [ <font color='red'>code</font> ] ";
|
$str .= " [ <font color='red'>code</font> ] ";
|
||||||
touch("codes/$title - $k - $v2.php");
|
//touch("codes/$title - $k - $v2.php");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -486,12 +492,12 @@ $menu = array("Getting started" =>
|
|||||||
if( ! file_exists("docs/$title - $t.php")) {
|
if( ! file_exists("docs/$title - $t.php")) {
|
||||||
$missing[0]++;
|
$missing[0]++;
|
||||||
$str .= " [ <font color='red'>doc</font> ] ";
|
$str .= " [ <font color='red'>doc</font> ] ";
|
||||||
touch("docs/$title - $t.php");
|
//touch("docs/$title - $t.php");
|
||||||
}
|
}
|
||||||
if( ! file_exists("codes/$title - $t.php")) {
|
if( ! file_exists("codes/$title - $t.php")) {
|
||||||
$missing[1]++;
|
$missing[1]++;
|
||||||
$str .= " [ <font color='red'>code</font> ] ";
|
$str .= " [ <font color='red'>code</font> ] ";
|
||||||
touch("codes/$title - $t.php");
|
//touch("codes/$title - $t.php");
|
||||||
}
|
}
|
||||||
print "<dt>".$e." <a href=\"".$_SERVER['PHP_SELF']."?index=$i#$e\">".$t."</a>$str</dt>\n";
|
print "<dt>".$e." <a href=\"".$_SERVER['PHP_SELF']."?index=$i#$e\">".$t."</a>$str</dt>\n";
|
||||||
}
|
}
|
||||||
|
@ -90,6 +90,7 @@ class Doctrine_Import_TestCase extends Doctrine_UnitTestCase {
|
|||||||
unlink('tmp' . DIRECTORY_SEPARATOR . 'ImportTest.php');
|
unlink('tmp' . DIRECTORY_SEPARATOR . 'ImportTest.php');
|
||||||
}
|
}
|
||||||
public function testForeignKeySupport() {
|
public function testForeignKeySupport() {
|
||||||
|
/**
|
||||||
$this->dbh->query('CREATE TABLE album (
|
$this->dbh->query('CREATE TABLE album (
|
||||||
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||||
title VARCHAR(100),
|
title VARCHAR(100),
|
||||||
@ -109,7 +110,7 @@ class Doctrine_Import_TestCase extends Doctrine_UnitTestCase {
|
|||||||
$sql = "PRAGMA table_info(track)";
|
$sql = "PRAGMA table_info(track)";
|
||||||
$sql = "PRAGMA foreign_key_list(track)";
|
$sql = "PRAGMA foreign_key_list(track)";
|
||||||
$result = $this->dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
|
$result = $this->dbh->query($sql)->fetchAll(PDO::FETCH_ASSOC);
|
||||||
|
*/
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
80
tests/RecordStateTestCase.php
Normal file
80
tests/RecordStateTestCase.php
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
<?php
|
||||||
|
class Doctrine_Record_State_TestCase extends Doctrine_UnitTestCase {
|
||||||
|
public function prepareTables() { }
|
||||||
|
public function prepareData() { }
|
||||||
|
|
||||||
|
public function testAssignUnknownState() {
|
||||||
|
$user = new User();
|
||||||
|
try {
|
||||||
|
$user->state(123123);
|
||||||
|
$this->fail();
|
||||||
|
} catch(Doctrine_Record_State_Exception $e) {
|
||||||
|
$this->pass();
|
||||||
|
}
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TCLEAN);
|
||||||
|
try {
|
||||||
|
$user->state('some unknown state');
|
||||||
|
$this->fail();
|
||||||
|
} catch(Doctrine_Record_State_Exception $e) {
|
||||||
|
$this->pass();
|
||||||
|
}
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TCLEAN);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testAssignDirtyState() {
|
||||||
|
$user = new User();
|
||||||
|
|
||||||
|
$user->state(Doctrine_Record::STATE_DIRTY);
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_DIRTY);
|
||||||
|
|
||||||
|
$user->state('dirty');
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_DIRTY);
|
||||||
|
}
|
||||||
|
public function testAssignCleanState() {
|
||||||
|
$user = new User();
|
||||||
|
|
||||||
|
$user->state(Doctrine_Record::STATE_CLEAN);
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_CLEAN);
|
||||||
|
|
||||||
|
$user->state('clean');
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_CLEAN);
|
||||||
|
}
|
||||||
|
public function testAssignTransientCleanState() {
|
||||||
|
$user = new User();
|
||||||
|
|
||||||
|
$user->state(Doctrine_Record::STATE_TCLEAN);
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TCLEAN);
|
||||||
|
|
||||||
|
$user->state('tclean');
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TCLEAN);
|
||||||
|
}
|
||||||
|
public function testAssignTransientDirtyState() {
|
||||||
|
$user = new User();
|
||||||
|
|
||||||
|
$user->state(Doctrine_Record::STATE_TDIRTY);
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TDIRTY);
|
||||||
|
|
||||||
|
$user->state('tdirty');
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_TDIRTY);
|
||||||
|
}
|
||||||
|
public function testAssignProxyState() {
|
||||||
|
$user = new User();
|
||||||
|
|
||||||
|
$user->state(Doctrine_Record::STATE_PROXY);
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_PROXY);
|
||||||
|
|
||||||
|
$user->state('proxy');
|
||||||
|
|
||||||
|
$this->assertEqual($user->state(), Doctrine_Record::STATE_PROXY);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
@ -1,7 +1,7 @@
|
|||||||
<?php
|
<?php
|
||||||
require_once("UnitTestCase.php");
|
require_once("UnitTestCase.php");
|
||||||
|
|
||||||
class Doctrine_RecordTestCase extends Doctrine_UnitTestCase {
|
class Doctrine_Record_TestCase extends Doctrine_UnitTestCase {
|
||||||
|
|
||||||
public function prepareTables() {
|
public function prepareTables() {
|
||||||
$this->tables[] = "enumTest";
|
$this->tables[] = "enumTest";
|
||||||
|
@ -3,11 +3,12 @@
|
|||||||
class RelationTest extends Doctrine_Record {
|
class RelationTest extends Doctrine_Record {
|
||||||
public function setTableDefinition() {
|
public function setTableDefinition() {
|
||||||
$this->hasColumn('name', 'string', 200);
|
$this->hasColumn('name', 'string', 200);
|
||||||
$this->hasColumn("child_id", "integer");
|
$this->hasColumn('child_id', 'integer');
|
||||||
}
|
}
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
$this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id');
|
$this->ownsMany('OwnsOneToManyWithAlias as AliasO2M', 'AliasO2M.component_id');
|
||||||
$this->hasMany('HasManyToManyWithAlias as AliasM2M', 'JoinTable.c1_id');
|
$this->hasMany('M2M as AliasM2M', 'JoinTable.c1_id');
|
||||||
|
// $this->hasMany('M2M as AliasM2M2', 'JoinTable.c1_id');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class RelationTestChild extends RelationTest {
|
class RelationTestChild extends RelationTest {
|
||||||
@ -41,7 +42,7 @@ class OwnsOneToManyWithAlias extends Doctrine_Record {
|
|||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
class HasManyToManyWithAlias extends Doctrine_Record {
|
class M2M extends Doctrine_Record {
|
||||||
public function setTableDefinition() {
|
public function setTableDefinition() {
|
||||||
$this->hasColumn('name', 'string', 200);
|
$this->hasColumn('name', 'string', 200);
|
||||||
}
|
}
|
||||||
@ -52,7 +53,7 @@ class HasManyToManyWithAlias extends Doctrine_Record {
|
|||||||
class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
|
class Doctrine_Relation_TestCase extends Doctrine_UnitTestCase {
|
||||||
public function prepareData() { }
|
public function prepareData() { }
|
||||||
public function prepareTables() {
|
public function prepareTables() {
|
||||||
$this->tables = array('HasManyToManyWithAlias', 'RelationTest', 'JoinTable');
|
$this->tables = array('M2M', 'RelationTest', 'JoinTable');
|
||||||
|
|
||||||
parent::prepareTables();
|
parent::prepareTables();
|
||||||
}
|
}
|
||||||
|
@ -12,6 +12,7 @@ require_once("BatchIteratorTestCase.php");
|
|||||||
require_once("CacheFileTestCase.php");
|
require_once("CacheFileTestCase.php");
|
||||||
|
|
||||||
require_once("RecordTestCase.php");
|
require_once("RecordTestCase.php");
|
||||||
|
require_once("RecordStateTestCase.php");
|
||||||
require_once("RecordFilterTestCase.php");
|
require_once("RecordFilterTestCase.php");
|
||||||
|
|
||||||
require_once("AccessTestCase.php");
|
require_once("AccessTestCase.php");
|
||||||
@ -57,14 +58,16 @@ print "<pre>";
|
|||||||
$test = new GroupTest("Doctrine Framework Unit Tests");
|
$test = new GroupTest("Doctrine Framework Unit Tests");
|
||||||
|
|
||||||
|
|
||||||
|
$test->addTestCase(new Doctrine_Relation_TestCase());
|
||||||
|
|
||||||
|
$test->addTestCase(new Doctrine_Record_TestCase());
|
||||||
|
|
||||||
|
$test->addTestCase(new Doctrine_Record_State_TestCase());
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_Import_TestCase());
|
$test->addTestCase(new Doctrine_Import_TestCase());
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_SchemaTestCase());
|
$test->addTestCase(new Doctrine_SchemaTestCase());
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_Relation_TestCase());
|
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_RecordTestCase());
|
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_ValidatorTestCase());
|
$test->addTestCase(new Doctrine_ValidatorTestCase());
|
||||||
|
|
||||||
$test->addTestCase(new Doctrine_Query_MultiJoin_TestCase());
|
$test->addTestCase(new Doctrine_Query_MultiJoin_TestCase());
|
||||||
|
Loading…
x
Reference in New Issue
Block a user