mirror of
				https://github.com/phpbb/phpbb.git
				synced 2025-10-23 12:46:15 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
| *
 | |
| * This file is part of the phpBB Forum Software package.
 | |
| *
 | |
| * @copyright (c) phpBB Limited <https://www.phpbb.com>
 | |
| * @license GNU General Public License, version 2 (GPL-2.0)
 | |
| *
 | |
| * For full copyright and license information, please see
 | |
| * the docs/CREDITS.txt file.
 | |
| *
 | |
| */
 | |
| 
 | |
| 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));
 | |
| 	}
 | |
| }
 |