. */ /** * Doctrine_Boolean_TestCase * * @package Doctrine * @author Konsta Vesterinen * @license http://www.opensource.org/licenses/lgpl-license.php LGPL * @category Object Relational Mapping * @link www.phpdoctrine.com * @since 1.0 * @version $Revision$ */ class Doctrine_Boolean_TestCase extends Doctrine_UnitTestCase { public function prepareData() { } public function prepareTables() { $this->tables = array("BooleanTest"); parent::prepareTables(); } public function testSetFalse() { $test = new BooleanTest(); $test->is_working = false; $this->assertIdentical($test->is_working, false); $this->assertEqual($test->state(), Doctrine_Record::STATE_TDIRTY); $test->save(); $test->refresh(); $this->assertIdentical($test->is_working, false); } public function testSetTrue() { $test = new BooleanTest(); $test->is_working = true; $this->assertIdentical($test->is_working, true); $test->save(); $test->refresh(); $this->assertIdentical($test->is_working, true); $this->connection->clear(); $test = $test->getTable()->find($test->id); $this->assertIdentical($test->is_working, true); } public function testNormalQuerying() { $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = 0'); $this->assertEqual(count($ret), 1); $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = 1'); Doctrine_Lib::formatSql($query->getQuery()); $this->assertEqual(count($ret), 1); } public function testPreparedQueries() { $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = ?', array(false)); $this->assertEqual(count($ret), 1); $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = ?', array(true)); $this->assertEqual(count($ret), 1); } public function testFetchingWithSmartConversion() { $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = false'); $this->assertEqual(count($ret), 1); $query = new Doctrine_Query($this->connection); $ret = $query->query('FROM BooleanTest WHERE BooleanTest.is_working = true'); Doctrine_Lib::formatSql($query->getQuery()); $this->assertEqual(count($ret), 1); } public function testSavingNullValue() { $test = new BooleanTest(); $this->is_working = null; $this->assertIdentical($this->is_working, null); $this->assertEqual($test->state(), Doctrine_Record::STATE_TDIRTY); $test->save(); $test->refresh(); $this->assertIdentical($test->is_working, null); $test = new BooleanTest(); $this->is_working_notnull = null; $this->assertIdentical($this->is_working_notnull, false); $this->assertEqual($test->state(), Doctrine_Record::STATE_TDIRTY); $test->save(); $test->refresh(); $this->assertIdentical($test->is_working_notnull, false); } } ?>