8398c9048d
code was modified slightly, so the code differs from the original downloadable 1.9.5 version
132 lines
3.5 KiB
PHP
132 lines
3.5 KiB
PHP
<?php
|
|
/**
|
|
* Zend Framework
|
|
*
|
|
* LICENSE
|
|
*
|
|
* This source file is subject to the new BSD license that is bundled
|
|
* with this package in the file LICENSE.txt.
|
|
* It is also available through the world-wide-web at this URL:
|
|
* http://framework.zend.com/license/new-bsd
|
|
* If you did not receive a copy of the license and are unable to
|
|
* obtain it through the world-wide-web, please send an email
|
|
* to license@zend.com so we can send you a copy immediately.
|
|
*
|
|
* @category Zend
|
|
* @package Zend_Db
|
|
* @subpackage UnitTests
|
|
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
* @version $Id: PgsqlTest.php 17363 2009-08-03 07:40:18Z bkarwin $
|
|
*/
|
|
|
|
|
|
/**
|
|
* @see Zend_Db_Select_TestCommon
|
|
*/
|
|
require_once 'Zend/Db/Select/TestCommon.php';
|
|
|
|
|
|
PHPUnit_Util_Filter::addFileToFilter(__FILE__);
|
|
|
|
|
|
/**
|
|
* @category Zend
|
|
* @package Zend_Db
|
|
* @subpackage UnitTests
|
|
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
|
|
* @license http://framework.zend.com/license/new-bsd New BSD License
|
|
* @group Zend_Db
|
|
* @group Zend_Db_Select
|
|
*/
|
|
class Zend_Db_Select_Pdo_PgsqlTest extends Zend_Db_Select_TestCommon
|
|
{
|
|
public function getDriver()
|
|
{
|
|
return 'Pdo_Pgsql';
|
|
}
|
|
|
|
/**
|
|
* This test must be done on string field
|
|
*/
|
|
protected function _selectColumnWithColonQuotedParameter ()
|
|
{
|
|
$product_name = $this->_db->quoteIdentifier('product_name');
|
|
|
|
$select = $this->_db->select()
|
|
->from('zfproducts')
|
|
->where($product_name . ' = ?', "as'as:x");
|
|
return $select;
|
|
}
|
|
|
|
public function testSelectGroupByExpr()
|
|
{
|
|
$this->markTestSkipped($this->getDriver() . ' does not support expressions in GROUP BY');
|
|
}
|
|
|
|
public function testSelectGroupByAutoExpr()
|
|
{
|
|
$this->markTestSkipped($this->getDriver() . ' does not support expressions in GROUP BY');
|
|
}
|
|
|
|
/**
|
|
* Ensures that from() provides expected behavior using schema specification
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSelectFromSchemaSpecified()
|
|
{
|
|
$schema = 'public';
|
|
$table = 'zfbugs';
|
|
|
|
$sql = $this->_db->select()->from($table, '*', $schema);
|
|
|
|
$this->assertRegExp("/FROM \"$schema\".\"$table\"/", $sql->__toString());
|
|
|
|
$rowset = $this->_db->fetchAll($sql);
|
|
|
|
$this->assertEquals(4, count($rowset));
|
|
}
|
|
|
|
/**
|
|
* Ensures that from() provides expected behavior using schema in the table name
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSelectFromSchemaInName()
|
|
{
|
|
$schema = 'public';
|
|
$table = 'zfbugs';
|
|
|
|
$name = "$schema.$table";
|
|
|
|
$sql = $this->_db->select()->from($name);
|
|
|
|
$this->assertRegExp("/FROM \"$schema\".\"$table\"/", $sql->__toString());
|
|
|
|
$rowset = $this->_db->fetchAll($sql);
|
|
|
|
$this->assertEquals(4, count($rowset));
|
|
}
|
|
|
|
/**
|
|
* Ensures that from() overrides schema specification with schema in the table name
|
|
*
|
|
* @return void
|
|
*/
|
|
public function testSelectFromSchemaInNameOverridesSchemaArgument()
|
|
{
|
|
$schema = 'public';
|
|
$table = 'zfbugs';
|
|
|
|
$name = "$schema.$table";
|
|
|
|
$sql = $this->_db->select()->from($name, '*', 'ignored');
|
|
|
|
$this->assertRegExp("/FROM \"$schema\".\"$table\"/", $sql->__toString());
|
|
|
|
$rowset = $this->_db->fetchAll($sql);
|
|
|
|
$this->assertEquals(4, count($rowset));
|
|
}
|
|
}
|