mirror of
				https://github.com/e107inc/e107.git
				synced 2025-10-26 19:21:54 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			459 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			459 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 	/**
 | |
| 	 * e107 website system
 | |
| 	 *
 | |
| 	 * Copyright (C) 2008-2020 e107 Inc (e107.org)
 | |
| 	 * Released under the terms and conditions of the
 | |
| 	 * GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
 | |
| 	 *
 | |
| 	 */
 | |
| 
 | |
| 
 | |
| 	class e_admin_controller_uiTest extends \Codeception\Test\Unit
 | |
| 	{
 | |
| 
 | |
| 		/** @var e_admin_controller_ui */
 | |
| 		protected $ui;
 | |
| 
 | |
| 		protected function _before()
 | |
| 		{
 | |
| 
 | |
| 			try
 | |
| 			{
 | |
| 				$this->ui = $this->make('e_admin_controller_ui');
 | |
| 			}
 | |
| 			catch(Exception $e)
 | |
| 			{
 | |
| 				$this::fail("Couldn't load e_admin_controller_ui object");
 | |
| 			}
 | |
| 
 | |
| 
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testJoinAlias()
 | |
| 		{
 | |
| 			// Simple Join --------------
 | |
| 			$qry = "SELECT u.*, ue.* FROM #user AS u LEFT JOIN #user_extended as ue on u.user_id = ue.user_extended_id";
 | |
| 			$this->ui->joinAlias($qry);
 | |
| 
 | |
| 			$actual = $this->ui->getJoinAlias();
 | |
| 			$expected = array (  'user' => 'u',  'user_extended' => 'ue',);
 | |
| 			$this->assertEquals($expected,$actual);
 | |
| 
 | |
| 			$actual = $this->ui->getJoinField();
 | |
| 			$expected = array (   'user_id' => 'u.user_id',   'user_extended_id' => 'ue.user_extended_id', );
 | |
| 			$this->assertEquals($expected,$actual);
 | |
| 
 | |
| 			// Complex Join
 | |
| 
 | |
| 			$qry2 = "SELECT e.*,m.mem_id, m.mem_firstname, m.mem_lastname, cl.cal_appointment_start FROM `#calls` AS e 
 | |
| 			LEFT JOIN `#member` as m ON 
 | |
| 			(
 | |
| 				e.calls_direction = 'Inbound' AND m.mem_status NOT LIKE '%DUP%' AND e.calls_from !='' AND 
 | |
| 				(
 | |
| 					e.calls_from = REPLACE(m.mem_phone_day, '-', '') 
 | |
| 					OR e.calls_from = REPLACE(m.mem_phone_night, '-', '')  
 | |
| 					OR e.calls_from = REPLACE(m.mem_phone_cell , '-', '') 
 | |
| 					OR e.calls_from = REPLACE(m.mem_phone_other1 , '-', '') 
 | |
| 					OR e.calls_from = REPLACE(m.mem_phone_other2 , '-', '')
 | |
| 				)
 | |
| 			
 | |
| 			) 
 | |
| 			LEFT JOIN `#member_calender` AS cl ON 
 | |
| 			(
 | |
| 				e.calls_direction = 'Outbound' AND 
 | |
| 				(
 | |
| 					cl.cal_by_phone = REPLACE(m.mem_phone_day, '-', '') 
 | |
| 					OR cl.cal_by_cell = REPLACE(m.mem_phone_cell , '-', '') 
 | |
| 				)
 | |
| 			
 | |
| 			) ";
 | |
| 
 | |
| 			$this->ui->joinAlias($qry2);
 | |
| 
 | |
| 			$actual = $this->ui->getJoinAlias();
 | |
| 			$expected = array ( 'user' => 'u',  'user_extended' => 'ue',  'calls' => 'e',  'member' => 'm', 'member_calender' => 'cl', );
 | |
| 			$this->assertEquals($expected,$actual);
 | |
| 
 | |
| 
 | |
| 			$actual = $this->ui->getJoinField();
 | |
| 			$expected = array (
 | |
| 			  'user_id' => 'u.user_id',
 | |
| 			  'user_extended_id' => 'ue.user_extended_id',
 | |
| 			  'calls_direction' => 'e.calls_direction',
 | |
| 			  'calls_from' => 'e.calls_from',
 | |
| 			  'mem_id' => 'm.mem_id',
 | |
| 			  'mem_firstname' => 'm.mem_firstname',
 | |
| 			  'mem_lastname' => 'm.mem_lastname',
 | |
| 			  'mem_status' => 'm.mem_status',
 | |
| 			  'mem_phone_day' => 'm.mem_phone_day',
 | |
| 			  'mem_phone_night' => 'm.mem_phone_night',
 | |
| 			  'mem_phone_cell' => 'm.mem_phone_cell',
 | |
| 			  'mem_phone_other1' => 'm.mem_phone_other1',
 | |
| 			  'mem_phone_other2' => 'm.mem_phone_other2',
 | |
| 			  'cal_appointment_start' => 'cl.cal_appointment_start',
 | |
| 			  'cal_by_phone' => 'cl.cal_by_phone',
 | |
| 			  'cal_by_cell' => 'cl.cal_by_cell',
 | |
| 			);
 | |
| 
 | |
| 			$this->assertEquals($expected,$actual);
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function test_ModifyListQrySearch()
 | |
| 		{
 | |
| 
 | |
| 			$listQry = 'SELECT u.* FROM `#user`  WHERE 1 ';
 | |
| 			$filterOptions = '';
 | |
| 			$tablePath = '`#user`.';
 | |
| 			$tableFrom = '`#user`';
 | |
| 			$primaryName = 'user_id';
 | |
| 			$raw = false;
 | |
| 			$orderField = null;
 | |
| 			$qryAsc = null;
 | |
| 			$forceFrom = false;
 | |
| 			$qryFrom = 0;
 | |
| 			$forceTo = false;
 | |
| 			$perPage = 10;
 | |
| 			$qryField = null;
 | |
| 			$isfilter = false;
 | |
| 			$handleAction = 'list';
 | |
| 
 | |
| 			$this->ui->setFields([
 | |
| 					'user_id'           => array('title'=>'User ID', '__tableField' => 'u.user_id', 'type'=>'int', 'data'=>'int'),
 | |
| 					'user_name' 		=> array('title' => 'Name',	'__tableField' => 'u.user_name', 'type' => 'text',	 'data'=>'safestr'), // Display name
 | |
|  		            'user_login' 		=> array('title' => 'Login','__tableField' => 'u.user_login', 'type' => 'text',	 'data'=>'safestr'), // Real name (no real vetting)
 | |
|  			]);
 | |
| 
 | |
| 			// Test single word search term.
 | |
| 			$result = $this->ui->_modifyListQrySearch($listQry, 'admin', $filterOptions, $tablePath,  $tableFrom, $primaryName, $raw, $orderField, $qryAsc, $forceFrom, $qryFrom, $forceTo, $perPage, $qryField,  $isfilter, $handleAction);
 | |
| 			$expected = "SELECT u.* FROM `#user`  WHERE 1  AND  ( u.user_name LIKE '%admin%' OR u.user_login LIKE '%admin%' )  LIMIT 0, 10";
 | |
| 			$this::assertSame($expected, $result);
 | |
| 
 | |
| 			// Test multiple word search term.
 | |
| 			$result = $this->ui->_modifyListQrySearch($listQry, 'firstname lastname', $filterOptions, $tablePath,  $tableFrom, $primaryName, $raw, $orderField, $qryAsc, $forceFrom, $qryFrom, $forceTo, $perPage, $qryField,  $isfilter, $handleAction);
 | |
| 			$expected = "SELECT u.* FROM `#user`  WHERE 1  AND (u.user_name LIKE '%firstname%' OR u.user_login LIKE '%firstname%') AND (u.user_name LIKE '%lastname%' OR u.user_login LIKE '%lastname%') LIMIT 0, 10";
 | |
| 			$this::assertSame($expected, $result);
 | |
| 
 | |
| 			// Search term in quotes.
 | |
| 			$expected = "SELECT u.* FROM `#user`  WHERE 1  AND  ( u.user_name LIKE '%firstname lastname%' OR u.user_login LIKE '%firstname lastname%' )  LIMIT 0, 10";
 | |
| 
 | |
| 			// Double-quotes.
 | |
| 			$result = $this->ui->_modifyListQrySearch($listQry, '"firstname lastname"', $filterOptions, $tablePath,  $tableFrom, $primaryName, $raw, $orderField, $qryAsc, $forceFrom, $qryFrom, $forceTo, $perPage, $qryField,  $isfilter, $handleAction);
 | |
| 			$this::assertSame($expected, $result);
 | |
| 
 | |
| 			// Single-quotes.
 | |
| 			$result = $this->ui->_modifyListQrySearch($listQry, "'firstname lastname'", $filterOptions, $tablePath,  $tableFrom, $primaryName, $raw, $orderField, $qryAsc, $forceFrom, $qryFrom, $forceTo, $perPage, $qryField,  $isfilter, $handleAction);
 | |
| 			$this::assertSame($expected, $result);
 | |
| 
 | |
| 			// Single quote as apostophie.
 | |
| 			$result = $this->ui->_modifyListQrySearch($listQry, "burt's", $filterOptions, $tablePath,  $tableFrom, $primaryName, $raw, $orderField, $qryAsc, $forceFrom, $qryFrom, $forceTo, $perPage, $qryField,  $isfilter, $handleAction);
 | |
| 			$expected = "SELECT u.* FROM `#user`  WHERE 1  AND  ( u.user_name LIKE '%burt's%' OR u.user_login LIKE '%burt's%' )  LIMIT 0, 10";
 | |
| 			$this::assertSame($expected, $result);
 | |
| 
 | |
| 		}
 | |
| /*
 | |
| 		public function testGetSortParent()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFieldPref()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTreeModelSorted()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testManageColumns()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetJoinField()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetBatchFeaturebox()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTableFromAlias()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFieldAttr()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetJoinData()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPrimaryName()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTableName()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetUrl()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetParentChildQry()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetListModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPerPage()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetSortField()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetUserPref()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFormQuery()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetBatchCopy()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTabs()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetBatchDelete()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTreePrefix()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPrefs()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| */
 | |
| /*		public function testGetConfig()
 | |
| 		{
 | |
| 			$result = $this->ui->getConfig();
 | |
| 
 | |
| 		}*/
 | |
| /*
 | |
| 		public function testGetBatchExport()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFieldVar()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetFieldAttr()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetTreeModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetEventTriggerName()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetBatchDelete()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetAfterSubmitOptions()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetValidationRules()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPrefTabs()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetDefaultOrder()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetBatchCopy()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetEventName()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFields()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testAddTab()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetTreeModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPluginName()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetPluginTitle()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetUI()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testParentChildSort_r()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetGrid()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetUI()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetJoinData()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetBatchLink()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetDefaultOrderField()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetFeaturebox()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetIfTableAlias()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetDataFields()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetListModel()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testGetBatchOptions()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 
 | |
| 		public function testSetUserPref()
 | |
| 		{
 | |
| 
 | |
| 		}
 | |
| 	*/
 | |
| 
 | |
| 	/*	public function testSetConfig()
 | |
| 		{
 | |
| 			$cfg = e107::getConfig('core',true, true);
 | |
| 
 | |
| 			$this->assertIsObject($cfg);
 | |
| 
 | |
| 			$before = $cfg->get('sitename');
 | |
| 			$this->ui->setConfig($cfg);
 | |
| 
 | |
| 			$pref = $this->ui->getConfig();
 | |
| 			$after = $pref->get('sitename');
 | |
| 
 | |
| 			$this->assertSame($after, $before);
 | |
| 
 | |
| 		}*/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 	}
 |