1
0
mirror of synced 2024-12-15 07:36:03 +03:00

new attribute: Doctrine::ATTR_ACCESSORS, DQL subquery support, accessor invoking support

This commit is contained in:
zYne 2006-10-06 16:50:00 +00:00
parent 4408774100
commit 847bd1ade6
17 changed files with 359 additions and 130 deletions

View File

@ -145,6 +145,10 @@ final class Doctrine {
* query limit * query limit
*/ */
const ATTR_QUERY_LIMIT = 17; const ATTR_QUERY_LIMIT = 17;
/**
* accessor invoking attribute
*/
const ATTR_ACCESSORS = 18;
/** /**
@ -213,54 +217,24 @@ final class Doctrine {
*/ */
const FETCH_ARRAY = 3; const FETCH_ARRAY = 3;
/** /**
* FETCH COLUMN * ACCESSOR CONSTANTS
* Specifies that the fetch method shall return only a single
* requested column from the next row in the result set.
*
*/ */
const FETCH_COLUMN = 4;
/** /**
* FETCH ASSOC * constant for get accessors
*
* Specifies that the fetch method shall return each row as an
* array indexed by column name as returned in the corresponding
* result set. If the result set contains multiple columns with
* the same name, PDO::FETCH_ASSOC returns only a single value per column name.
*
*/ */
const FETCH_ASSOC = 5; const ACCESSOR_GET = 1;
/** /**
* FETCH NAMED * constant for set accessors
*
* Specifies that the fetch method shall return each row as an array indexed
* by column name as returned in the corresponding result set. If the result set
* contains multiple columns with the same name, PDO::FETCH_NAMED returns an
* array of values per column name.
*
*/ */
const FETCH_NAMED = 6; const ACCESSOR_SET = 2;
/** /**
* FETCH NUM * constant for both accessors get and set
*
* Specifies that the fetch method shall return each row as an array indexed by
* column number as returned in the corresponding result set, starting at column 0.
*/ */
const FETCH_NUM = 7; const ACCESSOR_BOTH = 4;
/**
* FETCH BOTH
*
* Specifies that the fetch method shall return each row as an array indexed by both
* column name and number as returned in the corresponding result set, starting at column 0.
*/
const FETCH_BOTH = 8;
/**
* FETCH OBJ
*
* Specifies that the fetch method shall return each row as an object with property names
* that correspond to the column names returned in the result set.
*/
const FETCH_OBJ = 9;
/** /**

View File

@ -93,6 +93,13 @@ abstract class Doctrine_Configurable {
case Doctrine::ATTR_CREATE_TABLES: case Doctrine::ATTR_CREATE_TABLES:
$value = (bool) $value; $value = (bool) $value;
break; break;
case Doctrine::ATTR_ACCESSORS:
$accessors = array('none','get','set','both');
// if( ! in_array($value,$accessors))
// throw new Doctrine_Exception();
break;
case Doctrine::ATTR_COLL_LIMIT: case Doctrine::ATTR_COLL_LIMIT:
if($value < 1) { if($value < 1) {
throw new Doctrine_Exception("Collection limit should be a value greater than or equal to 1."); throw new Doctrine_Exception("Collection limit should be a value greater than or equal to 1.");
@ -166,7 +173,7 @@ abstract class Doctrine_Configurable {
public function setListener($listener) { public function setListener($listener) {
if( ! ($listener instanceof Doctrine_EventListener_Interface) && if( ! ($listener instanceof Doctrine_EventListener_Interface) &&
! ($listener instanceof Doctrine_Overloadable)) ! ($listener instanceof Doctrine_Overloadable))
throw new Doctrine_DB_Exception("Couldn't set eventlistener. EventListeners should implement either Doctrine_EventListener_Interface or Doctrine_Overloadable"); throw new Doctrine_Exception("Couldn't set eventlistener. EventListeners should implement either Doctrine_EventListener_Interface or Doctrine_Overloadable");
$this->attributes[Doctrine::ATTR_LISTENER] = $listener; $this->attributes[Doctrine::ATTR_LISTENER] = $listener;
@ -181,7 +188,7 @@ abstract class Doctrine_Configurable {
public function getAttribute($attribute) { public function getAttribute($attribute) {
$attribute = (int) $attribute; $attribute = (int) $attribute;
if($attribute < 1 || $attribute > 17) if($attribute < 1 || $attribute > 18)
throw new InvalidKeyException(); throw new InvalidKeyException();
if( ! isset($this->attributes[$attribute])) { if( ! isset($this->attributes[$attribute])) {

View File

@ -1,7 +1,71 @@
<?php <?php
require_once("Common.php"); /*
/** * $Id$
* sqlite driver *
* 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::autoload("Doctrine_Connection_Common");
/**
* Doctrine_Connection_Sqlite
*
* @package Doctrine ORM
* @url www.phpdoctrine.com
* @license LGPL
*/ */
class Doctrine_Connection_Sqlite extends Doctrine_Connection_Common { }
class Doctrine_Connection_Sqlite extends Doctrine_Connection_Common {
/**
* Return string to call a variable with the current timestamp inside an SQL statement
* There are three special variables for current date and time.
*
* @return string sqlite function as string
*/
public function now($type = 'timestamp') {
switch ($type) {
case 'time':
return 'time(\'now\')';
case 'date':
return 'date(\'now\')';
case 'timestamp':
default:
return 'datetime(\'now\')';
}
}
/**
* return string to call a function to get a substring inside an SQL statement
*
* @return string to call a function to get a substring
* @access public
*/
public function substring($value, $position = 1, $length = null) {
if($length !== null)
return "substr($value,$position,$length)";
return "substr($value,$position,length($value))";
}
/**
* return string to call a function to get random value inside an SQL statement
*
* @return string to generate float between 0 and 1
*/
public function random()
{
return '((RANDOM() + 2147483648) / 4294967296)';
}
}

View File

@ -55,6 +55,8 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
/** /**
* constructor * constructor
*
* this is private constructor (use getInstance to get an instance of this class)
*/ */
private function __construct() { private function __construct() {
$this->root = dirname(__FILE__); $this->root = dirname(__FILE__);
@ -137,6 +139,7 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
* *
* @param PDO $pdo PDO database driver * @param PDO $pdo PDO database driver
* @param string $name name of the connection, if empty numeric key is used * @param string $name name of the connection, if empty numeric key is used
* @throws Doctrine_Manager_Exception if trying to bind a connection with an existing name
* @return Doctrine_Connection * @return Doctrine_Connection
*/ */
public function openConnection(PDO $pdo, $name = null) { public function openConnection(PDO $pdo, $name = null) {
@ -146,7 +149,7 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
if($name !== null) { if($name !== null) {
$name = (string) $name; $name = (string) $name;
if(isset($this->connections[$name])) if(isset($this->connections[$name]))
throw new Doctrine_Exception("Connection with $name already exists!"); throw new Doctrine_Manager_Exception("Connection with $name already exists!");
} else { } else {
$name = $this->index; $name = $this->index;
@ -187,7 +190,7 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
* getConnection * getConnection
* @param integer $index * @param integer $index
* @return object Doctrine_Connection * @return object Doctrine_Connection
* @throws InvalidKeyException * @throws Doctrine_Manager_Exception if trying to get a non-existent connection
*/ */
public function getConnection($name) { public function getConnection($name) {
if (!isset($this->connections[$name])) { if (!isset($this->connections[$name])) {
@ -211,8 +214,6 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
public function addDSN($dsn, $name) { public function addDSN($dsn, $name) {
$this->dataSourceNames[$name] = $dsn; $this->dataSourceNames[$name] = $dsn;
} }
public function getSession($index) { return $this->getConnection($index); }
/** /**
* closes the connection * closes the connection
* *
@ -223,7 +224,6 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
$connection->close(); $connection->close();
unset($connection); unset($connection);
} }
public function closeSession(Doctrine_Connection $connection) { $this->closeConnection($connection); }
/** /**
* getConnections * getConnections
* returns all opened connections * returns all opened connections
@ -233,9 +233,6 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
public function getConnections() { public function getConnections() {
return $this->connections; return $this->connections;
} }
public function getSessions() {
return $this->connections;
}
/** /**
* setCurrentConnection * setCurrentConnection
* sets the current connection to $key * sets the current connection to $key
@ -251,9 +248,6 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
$this->currIndex = $key; $this->currIndex = $key;
} }
public function setCurrentSession($key) {
$this->setCurrentConnection($key);
}
/** /**
* count * count
* returns the number of opened connections * returns the number of opened connections
@ -286,7 +280,6 @@ class Doctrine_Manager extends Doctrine_Configurable implements Countable, Itera
return $this->connections[$i]; return $this->connections[$i];
} }
public function getCurrentSession() { return $this->getCurrentConnection(); }
/** /**
* __toString * __toString
* returns a string representation of this object * returns a string representation of this object

View File

@ -1,5 +1,29 @@
<?php <?php
/*
* $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_Manager_Exception
*
* @package Doctrine ORM
* @url www.phpdoctrine.com
* @license LGPL
*/
class Doctrine_Manager_Exception extends Doctrine_Exception { } class Doctrine_Manager_Exception extends Doctrine_Exception { }
?>

View File

@ -543,7 +543,7 @@ class Doctrine_Query extends Doctrine_Hydrate implements Countable {
* @param string $e1 the first bracket, usually '(' * @param string $e1 the first bracket, usually '('
* @param string $e2 the second bracket, usually ')' * @param string $e2 the second bracket, usually ')'
*/ */
public static function bracketTrim($str,$e1,$e2) { public static function bracketTrim($str,$e1 = '(',$e2 = ')') {
if(substr($str,0,1) == $e1 && substr($str,-1) == $e2) if(substr($str,0,1) == $e1 && substr($str,-1) == $e2)
return substr($str,1,-1); return substr($str,1,-1);
else else

View File

@ -1,5 +1,5 @@
<?php <?php
require_once("Part.php"); Doctrine::autoload("Doctrine_Query_Part");
class Doctrine_Query_From extends Doctrine_Query_Part { class Doctrine_Query_From extends Doctrine_Query_Part {

View File

@ -9,13 +9,12 @@ class Doctrine_Query_Where extends Doctrine_Query_Condition {
* @param string $where * @param string $where
* @return string * @return string
*/ */
final public function load($where) { public function load($where) {
$e = explode(" ",$where); $e = Doctrine_Query::sqlExplode($where);
$r = array_shift($e); $r = array_shift($e);
$a = explode(".",$r); $a = explode(".",$r);
if(count($a) > 1) { if(count($a) > 1) {
$field = array_pop($a); $field = array_pop($a);
$count = count($e); $count = count($e);
@ -34,7 +33,7 @@ class Doctrine_Query_Where extends Doctrine_Query_Condition {
if($pos !== false) { if($pos !== false) {
$func = substr($field, 0, $pos); $func = substr($field, 0, $pos);
$value = substr($field, ($pos + 1), -1); $value = trim(substr($field, ($pos + 1), -1));
$values = Doctrine_Query::sqlExplode($value, ','); $values = Doctrine_Query::sqlExplode($value, ',');
@ -76,10 +75,16 @@ class Doctrine_Query_Where extends Doctrine_Query_Condition {
$alias = $this->query->getTableAlias($reference); $alias = $this->query->getTableAlias($reference);
$table = $this->query->getTable($alias); $table = $this->query->getTable($alias);
if(trim($value) == 'true')
if($value == 'true')
$value = 1; $value = 1;
elseif(trim($value) == 'false') elseif($value == 'false')
$value = 0; $value = 0;
elseif(substr($value,0,5) == '(FROM') {
$sub = Doctrine_Query::bracketTrim($value);
$q = new Doctrine_Query();
$value = '(' . $q->parseQuery($sub)->getQuery() . ')';
}
switch($operator) { switch($operator) {
case '<': case '<':

View File

@ -586,12 +586,13 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
* this method does NOT load it * this method does NOT load it
* *
* @param $name name of the property * @param $name name of the property
* @throws Doctrine_Record_Exception if trying to get an unknown property
* @return mixed * @return mixed
*/ */
public function rawGet($name) { public function rawGet($name) {
if( ! isset($this->data[$name])) if( ! isset($this->data[$name]))
throw new InvalidKeyException(); throw new Doctrine_Record_Exception('Unknown property '. $name);
if($this->data[$name] === self::$null) if($this->data[$name] === self::$null)
return null; return null;
@ -654,9 +655,14 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
if($value !== self::$null) { if($value !== self::$null) {
if($invoke && $name !== $this->table->getIdentifier()) {
$value = $this->table->invokeGet($this, $name, $value);
if($invoke && $name !== $this->table->getIdentifier())
return $this->table->getAttribute(Doctrine::ATTR_LISTENER)->onGetProperty($this, $name, $value); return $this->table->getAttribute(Doctrine::ATTR_LISTENER)->onGetProperty($this, $name, $value);
} else else
return $value;
return $value; return $value;
} }
@ -712,7 +718,8 @@ abstract class Doctrine_Record extends Doctrine_Access implements Countable, Ite
if($old !== $value) { if($old !== $value) {
// invoke the onPreSetProperty listener $value = $this->table->invokeSet($this, $name, $value);
$value = $this->table->getAttribute(Doctrine::ATTR_LISTENER)->onSetProperty($this, $name, $value); $value = $this->table->getAttribute(Doctrine::ATTR_LISTENER)->onSetProperty($this, $name, $value);
if($value === null) if($value === null)

View File

@ -945,6 +945,40 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
final public function enumValue($field, $index) { final public function enumValue($field, $index) {
return isset($this->enum[$field][$index])?$this->enum[$field][$index]:$index; return isset($this->enum[$field][$index])?$this->enum[$field][$index]:$index;
} }
/**
* invokeSet
*
* @param mixed $value
*/
public function invokeSet(Doctrine_Record $record, $name, $value) {
if( ! ($this->getAttribute(Doctrine::ATTR_ACCESSORS) | Doctrine::ACCESSOR_SET))
return $value;
$method = 'set' . $name;
if(method_exists($record, $method)) {
return $record->$method($value);
}
return $value;
}
/**
* invokeGet
*
* @param mixed $value
*/
public function invokeGet(Doctrine_Record $record, $name, $value) {
if( ! ($this->getAttribute(Doctrine::ATTR_ACCESSORS) | Doctrine::ACCESSOR_GET))
return $value;
$method = 'get' . $name;
if(method_exists($record, $method)) {
return $record->$method($value);
}
return $value;
}
/** /**
* enumIndex * enumIndex
* *
@ -961,7 +995,20 @@ class Doctrine_Table extends Doctrine_Configurable implements Countable {
return array_search($value, $values); return array_search($value, $values);
} }
/** /**
* @return integer * getDefinitionOf
*
* @return string ValueWrapper class name on success, false on failure
*/
public function getValueWrapperOf($column) {
if(isset($this->columns[$column][2]['wrapper']))
return $this->columns[$column][2]['wrapper'];
return false;
}
/**
* getColumnCount
*
* @return integer the number of columns in this table
*/ */
final public function getColumnCount() { final public function getColumnCount() {
return $this->columnCount; return $this->columnCount;

View File

@ -17,3 +17,31 @@ When compared to using raw SQL, DQL has several benefits: <br \>
</ul> </ul>
If the power of DQL isn't enough, you should consider using the rawSql API for object population. If the power of DQL isn't enough, you should consider using the rawSql API for object population.
Standard DQL query consists of the following parts:
<ul>
<li \> a FROM clause, which provides declarations that designate the domain to which the expressions
specified in the other clauses of the query apply.
</ul>
<ul>
<li \> an optional WHERE clause, which may be used to restrict the results that are returned by the
query.
</ul>
<ul>
<li \> an optional GROUP BY clause, which allows query results to be aggregated in terms of
groups.
</ul>
<ul>
<li \> an optional HAVING clause, which allows filtering over aggregated groups.
</ul>
<ul>
<li \> an optional ORDER BY clause, which may be used to order the results that are returned by the
query.
</ul>
<br \>
In BNF syntax, a select statement is defined as:
select_statement :: = select_clause from_clause [where_clause] [groupby_clause]
[having_clause] [orderby_clause]
<br \>
A select statement must always have a SELECT and a FROM clause. The square brackets [] indicate
that the other clauses are optional.

View File

@ -3,6 +3,15 @@ Doctrine automatically creates table names from the record class names. For this
<li>Use CamelCase naming</li> <li>Use CamelCase naming</li>
<li>Underscores are allowed</li> <li>Underscores are allowed</li>
<li>The first letter must be capitalized</li> <li>The first letter must be capitalized</li>
<li>The class name cannot be one of the following (these keywords are reserved in DQL API): <br \>
SELECT, FROM, WHERE, UPDATE, DELETE, JOIN, OUTER, INNER, LEFT, GROUP, ORDER, BY, HAVING,<br \>
FETCH, DISTINCT, OBJECT, NULL, TRUE, FALSE, <br \>
NOT, AND, OR, BETWEEN, LIKE, IN,<br \>
AS, UNKNOWN, EMPTY, MEMBER, OF, IS, ASC, DESC, <br \>
AVG, MAX, MIN, SUM, COUNT,<br \>
MOD, UPPER, LOWER, TRIM, POSITION, <br \>
CHARACTER_LENGTH, CHAR_LENGTH, BIT_LENGTH, CURRENT_TIME, CURRENT_DATE, <br \>
CURRENT_TIMESTAMP, NEW, EXISTS, ALL, ANY, SOME.<br \></li>
</ul> </ul>
Example. My_PerfectClass Example. My_PerfectClass
<br /> <br />

View File

@ -307,17 +307,36 @@ $menu = array("Getting started" =>
"DQL (Doctrine Query Language)" => "DQL (Doctrine Query Language)" =>
array('Introduction', array('Introduction',
'Syntax' => 'FROM clause',
'WHERE clause',
array( 'Conditional expressions' =>
'FROM', array('Literals',
'WHERE', 'Identification variables',
'GROUP BY', 'Path expressions',
'HAVING', 'Input parameters',
'ORDER BY', 'Contidional expression composition',
'LIMIT and OFFSET', 'Operators and operator precedence',
), 'Between expressions',
'In expressions',
'Like Expressions',
'Null Comparison Expressions',
'Empty Collection Comparison Expressions',
'Collection Member Expressions',
'Exists Expressions',
'All or Any Expressions',
'Subqueries'),
'Functional Expressions' =>
array('String functions',
'Arithmetic functions',
'Datetime functions',
'Collection functions'),
'GROUP BY, HAVING clauses',
'ORDER BY clause',
'LIMIT and OFFSET clauses',
'Examples',
'BNF'),
/**
'Functions' => array( 'Functions' => array(
'Contains', 'Contains',
'Regexp', 'Regexp',
@ -326,8 +345,8 @@ $menu = array("Getting started" =>
'Logical operators') 'Logical operators')
*/
),
"Transactions" => array( "Transactions" => array(
"Introduction", "Introduction",
"Unit of work", "Unit of work",

View File

@ -39,45 +39,7 @@ class Doctrine_EventListener_TestLogger implements Doctrine_Overloadable, Counta
class Doctrine_EventListenerTestCase extends Doctrine_UnitTestCase { class Doctrine_EventListenerTestCase extends Doctrine_UnitTestCase {
private $logger; private $logger;
public function testAccessorInvoker() {
$e = new EventListenerTest;
$e->name = "something";
$e->password = "123";
$this->assertEqual($e->get('name'), 'SOMETHING');
// test repeated calls
$this->assertEqual($e->get('name'), 'SOMETHING');
$this->assertEqual($e->id, null);
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$e->save();
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$this->connection->clear();
$e->refresh();
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$this->connection->clear();
$e = $e->getTable()->find($e->id);
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
}
public function testSetListener() { public function testSetListener() {
$this->logger = new Doctrine_EventListener_TestLogger(); $this->logger = new Doctrine_EventListener_TestLogger();
@ -85,6 +47,9 @@ class Doctrine_EventListenerTestCase extends Doctrine_UnitTestCase {
$e->getTable()->setListener($this->logger); $e->getTable()->setListener($this->logger);
$e->name = 'listener';
$e->save();
$this->assertEqual($e->getTable()->getListener(), $this->logger); $this->assertEqual($e->getTable()->getListener(), $this->logger);
} }
public function testOnLoad() { public function testOnLoad() {
@ -94,6 +59,7 @@ class Doctrine_EventListenerTestCase extends Doctrine_UnitTestCase {
$e = $this->connection->getTable('EventListenerTest')->find(1); $e = $this->connection->getTable('EventListenerTest')->find(1);
$this->assertEqual($e->getTable()->getListener(), $this->logger); $this->assertEqual($e->getTable()->getListener(), $this->logger);
$this->assertEqual($this->logger->pop(), 'onLoad'); $this->assertEqual($this->logger->pop(), 'onLoad');

View File

@ -0,0 +1,16 @@
<?php
class Doctrine_Query_Subquery_TestCase extends Doctrine_UnitTestCase {
public function testSubqueryWithWherePartAndInExpression() {
$q = new Doctrine_Query();
$q->from('User')->where("User.id NOT IN (FROM User(id) WHERE User.name = 'zYne')");
$this->assertEqual($q->getQuery(),
"SELECT entity.id AS entity__id, entity.name AS entity__name, entity.loginname AS entity__loginname, entity.password AS entity__password, entity.type AS entity__type, entity.created AS entity__created, entity.updated AS entity__updated, entity.email_id AS entity__email_id FROM entity WHERE entity.id NOT IN (SELECT entity.id AS entity__id FROM entity WHERE entity.name = 'zYne' AND (entity.type = 0)) AND (entity.type = 0)");
$users = $q->execute();
$this->assertEqual($users->count(), 7);
$this->assertEqual($users[0]->name, 'Arnold Schwarzenegger');
}
}
?>

View File

@ -0,0 +1,63 @@
<?php
class RecordFilterTest extends Doctrine_Record {
public function setTableDefinition() {
$this->setAttribute(Doctrine::ATTR_ACCESSORS, Doctrine::ACCESSOR_BOTH);
$this->hasColumn("name", "string", 200);
$this->hasColumn("password", "string", 32);
}
public function setPassword($password) {
return md5($password);
}
public function getName($name) {
return strtoupper($name);
}
}
class Doctrine_Record_Filter_TestCase extends Doctrine_UnitTestCase {
public function prepareData() { }
public function prepareTables() { }
public function testValueWrapper() {
$e = new RecordFilterTest;
$e->name = "something";
$e->password = "123";
$this->assertEqual($e->get('name'), 'SOMETHING');
// test repeated calls
$this->assertEqual($e->get('name'), 'SOMETHING');
$this->assertEqual($e->id, null);
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$e->save();
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$this->connection->clear();
$e->refresh();
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
$this->connection->clear();
$e = $e->getTable()->find($e->id);
$this->assertEqual($e->id, 1);
$this->assertEqual($e->name, 'SOMETHING');
$this->assertEqual($e->rawGet('name'), 'something');
$this->assertEqual($e->password, '202cb962ac59075b964b07152d234b70');
}
}
?>

View File

@ -10,7 +10,10 @@ require_once("TableTestCase.php");
require_once("EventListenerTestCase.php"); require_once("EventListenerTestCase.php");
require_once("BatchIteratorTestCase.php"); require_once("BatchIteratorTestCase.php");
require_once("CacheFileTestCase.php"); require_once("CacheFileTestCase.php");
require_once("RecordTestCase.php"); require_once("RecordTestCase.php");
require_once("RecordFilterTestCase.php");
require_once("AccessTestCase.php"); require_once("AccessTestCase.php");
require_once("ValidatorTestCase.php"); require_once("ValidatorTestCase.php");
require_once("CollectionTestCase.php"); require_once("CollectionTestCase.php");
@ -32,6 +35,7 @@ require_once("QueryReferenceModelTestCase.php");
require_once("QueryWhereTestCase.php"); require_once("QueryWhereTestCase.php");
require_once("QueryConditionTestCase.php"); require_once("QueryConditionTestCase.php");
require_once("QueryComponentAliasTestCase.php"); require_once("QueryComponentAliasTestCase.php");
require_once("QuerySubqueryTestCase.php");
require_once("DBTestCase.php"); require_once("DBTestCase.php");
require_once("SchemaTestCase.php"); require_once("SchemaTestCase.php");
@ -117,6 +121,9 @@ $test->addTestCase(new Doctrine_EnumTestCase());
$test->addTestCase(new Doctrine_Query_ComponentAlias_TestCase()); $test->addTestCase(new Doctrine_Query_ComponentAlias_TestCase());
$test->addTestCase(new Doctrine_Query_Subquery_TestCase());
$test->addTestCase(new Doctrine_Record_Filter_TestCase());
//$test->addTestCase(new Doctrine_Cache_FileTestCase()); //$test->addTestCase(new Doctrine_Cache_FileTestCase());
//$test->addTestCase(new Doctrine_Cache_SqliteTestCase()); //$test->addTestCase(new Doctrine_Cache_SqliteTestCase());