2011-11-15 22:14:28 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @package testing
|
|
|
|
* @copyright (c) 2011 phpBB Group
|
2011-12-31 16:05:02 +00:00
|
|
|
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2
|
2011-11-15 22:14:28 +01:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
require_once dirname(__FILE__) . '/../../phpBB/includes/functions.php';
|
|
|
|
require_once dirname(__FILE__) . '/../../phpBB/includes/utf/utf_tools.php';
|
|
|
|
|
|
|
|
class phpbb_dbal_cross_join_test extends phpbb_database_test_case
|
|
|
|
{
|
|
|
|
public function getDataSet()
|
|
|
|
{
|
|
|
|
return $this->createXMLDataSet(dirname(__FILE__).'/fixtures/massmail_crossjoin.xml');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function test_cross_join()
|
|
|
|
{
|
|
|
|
$db = $this->new_dbal();
|
|
|
|
|
|
|
|
// http://tracker.phpbb.com/browse/PHPBB3-10296
|
|
|
|
// Test CROSS JOIN with INNER JOIN
|
|
|
|
// Failed on Postgres, MSSQL and Oracle
|
|
|
|
$db->sql_return_on_error(true);
|
|
|
|
|
|
|
|
$sql_ary = array(
|
|
|
|
'SELECT' => 'u.username',
|
|
|
|
'FROM' => array(
|
|
|
|
'phpbb_users' => 'u',
|
|
|
|
'phpbb_user_group' => 'ug',
|
|
|
|
),
|
|
|
|
'LEFT_JOIN' => array(
|
|
|
|
array(
|
|
|
|
'FROM' => array(
|
|
|
|
'phpbb_banlist' => 'b',
|
|
|
|
),
|
|
|
|
'ON' => 'u.user_id = b.ban_userid',
|
|
|
|
),
|
|
|
|
),
|
|
|
|
'WHERE' => 'ug.group_id = 1
|
|
|
|
AND u.user_id = ug.user_id
|
|
|
|
AND b.ban_id IS NULL',
|
|
|
|
'ORDER_BY' => 'u.username',
|
|
|
|
);
|
|
|
|
$sql = $db->sql_build_query('SELECT', $sql_ary);
|
|
|
|
$result = $db->sql_query($sql);
|
|
|
|
|
|
|
|
$db->sql_return_on_error(false);
|
|
|
|
|
|
|
|
$this->assertEquals(array(array('username' => 'mass email')), $db->sql_fetchrowset($result));
|
|
|
|
}
|
|
|
|
}
|