cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/Db/Select/Pdo/PgsqlTest.php

133 lines
3.5 KiB
PHP
Raw Permalink Normal View History

<?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));
}
}