Feature #17299 » 0005613_tests_v18.patch
tests/t3lib/matchcondition/t3lib_matchcondition_frontend_testcase.php (Revision 0) | ||
---|---|---|
<?php
|
||
/***************************************************************
|
||
* Copyright notice
|
||
*
|
||
* (c) 2009 Oliver Hader <oliver@typo3.org>
|
||
* All rights reserved
|
||
*
|
||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||
* free software; you can redistribute it and/or modify
|
||
* it under the terms of the GNU General Public License as published by
|
||
* the Free Software Foundation; either version 2 of the License, or
|
||
* (at your option) any later version.
|
||
*
|
||
* The GNU General Public License can be found at
|
||
* http://www.gnu.org/copyleft/gpl.html.
|
||
*
|
||
* This script is distributed in the hope that it will be useful,
|
||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
* GNU General Public License for more details.
|
||
*
|
||
* This copyright notice MUST APPEAR in all copies of the script!
|
||
***************************************************************/
|
||
/**
|
||
* Testcase for class t3lib_matchCondition_frontend.
|
||
*
|
||
* @author Oliver Hader <oliver@typo3.org>
|
||
* @package TYPO3
|
||
* @subpackage t3lib
|
||
*/
|
||
class t3lib_matchCondition_frontend_testcase extends tx_phpunit_testcase {
|
||
/**
|
||
* @var array
|
||
*/
|
||
private $backupGlobalVariables;
|
||
/**
|
||
* @var array
|
||
*/
|
||
private $rootline;
|
||
/**
|
||
* @var t3lib_matchCondition
|
||
*/
|
||
private $matchCondition;
|
||
public function setUp() {
|
||
$this->backupGlobalVariables = array(
|
||
'_ENV' => $_ENV,
|
||
'_GET' => $_GET,
|
||
'_POST' => $_POST,
|
||
'_SERVER' => $_SERVER,
|
||
'TYPO3_CONF_VARS' => $GLOBALS['TYPO3_CONF_VARS'],
|
||
'T3_VAR' => $GLOBALS['T3_VAR'],
|
||
);
|
||
$this->testGlobalNamespace = uniqid('TEST');
|
||
$GLOBALS[$this->testGlobalNamespace] = array();
|
||
$this->setUpTSFE();
|
||
$this->matchCondition = t3lib_div::makeInstance('t3lib_matchCondition_frontend');
|
||
}
|
||
public function tearDown() {
|
||
foreach ($this->backupGlobalVariables as $key => $data) {
|
||
$GLOBALS[$key] = $data;
|
||
}
|
||
unset($this->matchCondition);
|
||
unset($this->backupGlobalVariables);
|
||
unset($GLOBALS[$this->testGlobalNamespace]);
|
||
}
|
||
private function setUpTSFE() {
|
||
$this->rootline = array(
|
||
2 => array('uid' => 121, 'pid' => 111),
|
||
1 => array('uid' => 111, 'pid' => 101,),
|
||
0 => array('uid' => 101, 'pid' => 0,),
|
||
);
|
||
$GLOBALS['TSFE'] = $this->getMock('tslib_fe', array(), array(), '', FALSE);
|
||
$GLOBALS['TSFE']->tmpl = $this->getMock('t3lib_TStemplate');
|
||
}
|
||
/**
|
||
* Tests whether a faulty expression fails.
|
||
* @test
|
||
*/
|
||
public function simulateDisabledMatchAllConditionsFailsOnFaultyExpression() {
|
||
$this->matchCondition->matchAll = false;
|
||
$this->assertFalse($this->matchCondition->match('[nullCondition = This expression would return false in general]'));
|
||
}
|
||
/**
|
||
* Tests whether simulating positive matches for all conditions succeeds.
|
||
* @test
|
||
*/
|
||
public function simulateEnabledMatchAllConditionsSucceeds() {
|
||
$this->matchCondition->setSimulateMatchResult(true);
|
||
$this->assertTrue($this->matchCondition->match('[nullCondition = This expression would return false in general]'));
|
||
}
|
||
/**
|
||
* Tests whether simulating positive matches for specific conditions succeeds.
|
||
* @test
|
||
*/
|
||
public function simulateEnabledMatchSpecificConditionsSucceeds() {
|
||
$testCondition = '[' . uniqid('test') . ' = Any condition to simulate a positive match]';
|
||
$this->matchCondition->setSimulateMatchConditions(array($testCondition));
|
||
$this->assertTrue($this->matchCondition->match($testCondition));
|
||
}
|
||
/**
|
||
* Tests whether a condition matches Internet Explorer 7 on Windows.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function conditionMatchesInternetExplorer7Windows() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)';
|
||
$result = $this->matchCondition->match('[browser = msie] && [version = 7] && [system = winNT]');
|
||
$this->assertTrue($result);
|
||
}
|
||
/**
|
||
* Tests whether a condition does not match Internet Explorer 7 on Windows.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function conditionDoesNotMatchInternetExplorer7Windows() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Opera/9.25 (Windows NT 6.0; U; en)';
|
||
$result = $this->matchCondition->match('[browser = msie] && [version = 7] && [system = winNT]');
|
||
$this->assertFalse($result);
|
||
}
|
||
/**
|
||
* Tests whether a device type condition matches a crawler.
|
||
* @test
|
||
*/
|
||
public function deviceConditionMatchesRobot() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Googlebot/2.1 (+http://www.google.com/bot.html)';
|
||
$result = $this->matchCondition->match('[device = robot]');
|
||
$this->assertTrue($result);
|
||
}
|
||
/**
|
||
* Tests whether a device type condition does not match a crawler.
|
||
* @test
|
||
*/
|
||
public function deviceConditionDoesNotMatchRobot() {
|
||
$_SERVER['HTTP_USER_AGENT'] = md5('Some strange user agent');
|
||
$result = $this->matchCondition->match('[device = robot]');
|
||
$this->assertFalse($result);
|
||
}
|
||
/**
|
||
* Tests whether the browserInfo hook is called.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function deprecatedBrowserInfoHookIsCalled() {
|
||
$classRef = uniqid('tx_browserInfoHook');
|
||
$browserInfoHookMock = $this->getMock($classRef, array('browserInfo'));
|
||
$browserInfoHookMock->expects($this->atLeastOnce())->method('browserInfo');
|
||
$GLOBALS['T3_VAR']['getUserObj'][$classRef] = $browserInfoHookMock;
|
||
$GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['t3lib/class.t3lib_matchcondition.php']['matchConditionClass'][$classRef] = $classRef;
|
||
$this->matchCondition->__construct();
|
||
$this->matchCondition->match('[browser = msie] && [version = 7] && [system = winNT]');
|
||
}
|
||
/**
|
||
* Tests whether the whichDevice hook is called.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function deprecatedWhichDeviceHookIsCalled() {
|
||
$classRef = uniqid('tx_whichDeviceHook');
|
||
$whichDeviceHookMock = $this->getMock($classRef, array('whichDevice'));
|
||
$whichDeviceHookMock->expects($this->atLeastOnce())->method('whichDevice');
|
||
$GLOBALS['T3_VAR']['getUserObj'][$classRef] = $whichDeviceHookMock;
|
||
$GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['t3lib/class.t3lib_matchcondition.php']['matchConditionClass'][$classRef] = $classRef;
|
||
$this->matchCondition->__construct();
|
||
$this->matchCondition->match('[device = robot]');
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesSingleLanguageExpression() {
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = *de*]'));
|
||
$this->assertTrue($this->matchCondition->match('[language = *de-de*]'));
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesMultipleLanguagesExpression() {
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = *en*,*de*]'));
|
||
$this->assertTrue($this->matchCondition->match('[language = *en-us*,*de-de*]'));
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesCompleteLanguagesExpression() {
|
||
$this->markTestSkipped('This comparison seems to be incomplete in t3lib_matchCondition.');
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = de-de,de;q=0.8]'));
|
||
}
|
||
/**
|
||
* Tests whether usergroup comparison matches.
|
||
* @test
|
||
*/
|
||
public function usergroupConditionMatchesSingleGroupId() {
|
||
$GLOBALS['TSFE']->gr_list = '13,14,15';
|
||
$this->assertTrue($this->matchCondition->match('[usergroup = 13]'));
|
||
}
|
||
/**
|
||
* Tests whether usergroup comparison matches.
|
||
* @test
|
||
*/
|
||
public function usergroupConditionMatchesMultipleUserGroupId() {
|
||
$GLOBALS['TSFE']->gr_list = '13,14,15';
|
||
$this->assertTrue($this->matchCondition->match('[usergroup = 999,15,14,13]'));
|
||
}
|
||
/**
|
||
* Tests whether usergroup comparison matches.
|
||
* @test
|
||
*/
|
||
public function usergroupConditionDoesNotMatchDefaulUserGroupIds() {
|
||
$GLOBALS['TSFE']->gr_list = '0,-1';
|
||
$this->assertFalse($this->matchCondition->match('[usergroup = 0,-1]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesAnyLoggedInUser() {
|
||
$GLOBALS['TSFE']->loginUser = TRUE;
|
||
$GLOBALS['TSFE']->fe_user->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = *]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesSingleLoggedInUser() {
|
||
$GLOBALS['TSFE']->loginUser = TRUE;
|
||
$GLOBALS['TSFE']->fe_user->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = 13]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesMultipleLoggedInUsers() {
|
||
$GLOBALS['TSFE']->loginUser = TRUE;
|
||
$GLOBALS['TSFE']->fe_user->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = 999,13]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionDoesNotMatchIfNotUserIsLoggedId() {
|
||
$GLOBALS['TSFE']->loginUser = FALSE;
|
||
$GLOBALS['TSFE']->fe_user->user['uid'] = 13;
|
||
$this->assertFalse($this->matchCondition->match('[loginUser = *]'));
|
||
$this->assertFalse($this->matchCondition->match('[loginUser = 13]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 = 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 = 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 == 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 == 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnNotEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 != 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 != 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnLowerThanExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 < 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 < 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnLowerThanOrEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 <= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 <= 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 <= 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 <= 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnGreaterThanExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:20 > 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.2 > 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnGreaterThanOrEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 >= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:20 >= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 >= 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.2 >= 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesOnEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3.Test.Condition]'));
|
||
$this->assertFalse($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesWildcardExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3?Test?Condition]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3.T*t.Condition]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3?T*t?Condition]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesRegularExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^[A-Za-z3.]+$/]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^TYPO3\..+Condition$/]'));
|
||
$this->assertFalse($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^FALSE/]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesEmptyRegularExpression() {
|
||
$testKey = uniqid('test');
|
||
$_SERVER[$testKey] = '';
|
||
$this->assertTrue($this->matchCondition->match('[globalString = _SERVER|' . $testKey . ' = /^$/]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionMatchesSingleValue() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$this->assertTrue($this->matchCondition->match('[treeLevel = 2]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionMatchesMultipleValues() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$this->assertTrue($this->matchCondition->match('[treeLevel = 999,998,2]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionDoesNotMatchFaultyValue() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$this->assertFalse($this->matchCondition->match('[treeLevel = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesSinglePageIdInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 111]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesMultiplePageIdsInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 999,111,101]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionDoesNotMatchPageIdNotInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertFalse($this->matchCondition->match('[PIDupinRootline = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionDoesNotMatchLastPageIdInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertFalse($this->matchCondition->match('[PIDupinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesSinglePageIdInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 111]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesMultiplePageIdsInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 999,111,101]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesLastPageIdInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionDoesNotMatchPageIdNotInRootline() {
|
||
$GLOBALS['TSFE']->tmpl->rootLine = $this->rootline;
|
||
$GLOBALS['TSFE']->id = 121;
|
||
$this->assertFalse($this->matchCondition->match('[PIDinRootline = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionMatchesOlderRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertTrue($this->matchCondition->match('[compatVersion = 4.0]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionMatchesSameRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertTrue($this->matchCondition->match('[compatVersion = 4.9]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionDoesNotMatchNewerRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertFalse($this->matchCondition->match('[compatVersion = 5.0]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'GP'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceGP() {
|
||
$_GET = array('testGet' => 'getTest');
|
||
$_POST = array('testPost' => 'postTest');
|
||
$this->assertTrue($this->matchCondition->match('[globalString = GP:testGet = getTest]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = GP:testPost = postTest]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'TSFE'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceTSFE() {
|
||
$GLOBALS['TSFE']->id = 1234567;
|
||
$GLOBALS['TSFE']->testSimpleObject = new stdClass();
|
||
$GLOBALS['TSFE']->testSimpleObject->testSimpleVariable = 'testValue';
|
||
$this->assertTrue($this->matchCondition->match('[globalString = TSFE:id = 1234567]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = TSFE:testSimpleObject|testSimpleVariable = testValue]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'ENV'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceENV() {
|
||
$testKey = uniqid('test');
|
||
putenv($testKey .'=testValue');
|
||
$this->assertTrue($this->matchCondition->match('[globalString = ENV:' . $testKey . ' = testValue]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'IENV'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceIENV() {
|
||
$_SERVER['HTTP_HOST'] = t3lib_div::getIndpEnv('TYPO3_HOST_ONLY') . ':1234567';
|
||
$this->assertTrue($this->matchCondition->match('[globalString = IENV:TYPO3_PORT = 1234567]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with any global namespace.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithAnyGlobalNamespace() {
|
||
$GLOBALS[$this->testGlobalNamespace] = array(
|
||
'first' => 'testFirst',
|
||
'second' => array('third' => 'testThird'),
|
||
);
|
||
$this->assertTrue($this->matchCondition->match(
|
||
'[globalString = ' . $this->testGlobalNamespace . '|first = testFirst]'
|
||
));
|
||
$this->assertTrue($this->matchCondition->match(
|
||
'[globalString = ' . $this->testGlobalNamespace . '|second|third = testThird]'
|
||
));
|
||
}
|
||
}
|
||
?>
|
tests/t3lib/matchcondition/t3lib_matchcondition_backend_testcase.php (Revision 0) | ||
---|---|---|
<?php
|
||
/***************************************************************
|
||
* Copyright notice
|
||
*
|
||
* (c) 2009 Oliver Hader <oliver@typo3.org>
|
||
* All rights reserved
|
||
*
|
||
* This script is part of the TYPO3 project. The TYPO3 project is
|
||
* free software; you can redistribute it and/or modify
|
||
* it under the terms of the GNU General Public License as published by
|
||
* the Free Software Foundation; either version 2 of the License, or
|
||
* (at your option) any later version.
|
||
*
|
||
* The GNU General Public License can be found at
|
||
* http://www.gnu.org/copyleft/gpl.html.
|
||
*
|
||
* This script is distributed in the hope that it will be useful,
|
||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
* GNU General Public License for more details.
|
||
*
|
||
* This copyright notice MUST APPEAR in all copies of the script!
|
||
***************************************************************/
|
||
/**
|
||
* Testcase for class t3lib_matchCondition_frontend.
|
||
*
|
||
* @author Oliver Hader <oliver@typo3.org>
|
||
* @package TYPO3
|
||
* @subpackage t3lib
|
||
*/
|
||
class t3lib_matchCondition_backend_testcase extends tx_phpunit_testcase {
|
||
/**
|
||
* @var array
|
||
*/
|
||
private $backupGlobalVariables;
|
||
/**
|
||
* @var array
|
||
*/
|
||
private $rootline;
|
||
/**
|
||
* @var t3lib_matchCondition_backend
|
||
*/
|
||
private $matchCondition;
|
||
/**
|
||
* @var string
|
||
*/
|
||
private $testTableName;
|
||
public function setUp() {
|
||
$this->backupGlobalVariables = array(
|
||
'_ENV' => $_ENV,
|
||
'_GET' => $_GET,
|
||
'_POST' => $_POST,
|
||
'_SERVER' => $_SERVER,
|
||
'TCA' => $GLOBALS['TCA'],
|
||
'TYPO3_DB' => $GLOBALS['TYPO3_DB'],
|
||
'TYPO3_CONF_VARS' => $GLOBALS['TYPO3_CONF_VARS'],
|
||
'T3_VAR' => $GLOBALS['T3_VAR'],
|
||
'BE_USER' => $GLOBALS['BE_USER'],
|
||
'SOBE' => $GLOBALS['SOBE'],
|
||
);
|
||
$this->testTableName = 't3lib_matchCondition_backend_testTable';
|
||
$this->testGlobalNamespace = uniqid('TEST');
|
||
$GLOBALS['TCA'][$this->testTableName] = array('ctrl' => array());
|
||
$GLOBALS[$this->testGlobalNamespace] = array();
|
||
$this->setUpBackend();
|
||
$this->matchCondition = t3lib_div::makeInstance('t3lib_matchCondition_backend');
|
||
}
|
||
public function tearDown() {
|
||
foreach ($this->backupGlobalVariables as $key => $data) {
|
||
$GLOBALS[$key] = $data;
|
||
}
|
||
unset($this->matchCondition);
|
||
unset($this->backupGlobalVariables);
|
||
unset($GLOBALS[$this->testGlobalNamespace]);
|
||
}
|
||
private function setUpBackend() {
|
||
$this->rootline = array(
|
||
2 => array('uid' => 121, 'pid' => 111),
|
||
1 => array('uid' => 111, 'pid' => 101,),
|
||
0 => array('uid' => 101, 'pid' => 0,),
|
||
);
|
||
$GLOBALS['BE_USER'] = $this->getMock('beUserAuth', array(), array(), '', FALSE);
|
||
}
|
||
private function setUpDatabaseMockForDeterminePageId() {
|
||
$GLOBALS['TYPO3_DB'] = $this->getMock('t3lib_DB', array('exec_SELECTquery', 'sql_fetch_assoc', 'sql_free_result'));
|
||
$GLOBALS['TYPO3_DB']->expects($this->any())->method('exec_SELECTquery')->will(
|
||
$this->returnCallback(array($this, 'determinePageIdByRecordDatabaseExecuteCallback'))
|
||
);
|
||
$GLOBALS['TYPO3_DB']->expects($this->any())->method('sql_fetch_assoc')->will(
|
||
$this->returnCallback(array($this, 'determinePageIdByRecordDatabaseFetchCallback'))
|
||
);
|
||
}
|
||
/**
|
||
* Tests whether a faulty expression fails.
|
||
* @test
|
||
*/
|
||
public function simulateDisabledMatchAllConditionsFailsOnFaultyExpression() {
|
||
$this->matchCondition->matchAll = false;
|
||
$this->assertFalse($this->matchCondition->match('[nullCondition = This expression would return false in general]'));
|
||
}
|
||
/**
|
||
* Tests whether simulating positive matches for all conditions succeeds.
|
||
* @test
|
||
*/
|
||
public function simulateEnabledMatchAllConditionsSucceeds() {
|
||
$this->matchCondition->setSimulateMatchResult(true);
|
||
$this->assertTrue($this->matchCondition->match('[nullCondition = This expression would return false in general]'));
|
||
}
|
||
/**
|
||
* Tests whether simulating positive matches for specific conditions succeeds.
|
||
* @test
|
||
*/
|
||
public function simulateEnabledMatchSpecificConditionsSucceeds() {
|
||
$testCondition = '[' . uniqid('test') . ' = Any condition to simulate a positive match]';
|
||
$this->matchCondition->setSimulateMatchConditions(array($testCondition));
|
||
$this->assertTrue($this->matchCondition->match($testCondition));
|
||
}
|
||
/**
|
||
* Tests whether a condition matches Internet Explorer 7 on Windows.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function conditionMatchesInternetExplorer7Windows() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)';
|
||
$result = $this->matchCondition->match('[browser = msie] && [version = 7] && [system = winNT]');
|
||
$this->assertTrue($result);
|
||
}
|
||
/**
|
||
* Tests whether a condition does not match Internet Explorer 7 on Windows.
|
||
*
|
||
* @return void
|
||
* @test
|
||
*/
|
||
public function conditionDoesNotMatchInternetExplorer7Windows() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Opera/9.25 (Windows NT 6.0; U; en)';
|
||
$result = $this->matchCondition->match('[browser = msie] && [version = 7] && [system = winNT]');
|
||
$this->assertFalse($result);
|
||
}
|
||
/**
|
||
* Tests whether a device type condition matches a crawler.
|
||
* @test
|
||
*/
|
||
public function deviceConditionMatchesRobot() {
|
||
$_SERVER['HTTP_USER_AGENT'] = 'Googlebot/2.1 (+http://www.google.com/bot.html)';
|
||
$result = $this->matchCondition->match('[device = robot]');
|
||
$this->assertTrue($result);
|
||
}
|
||
/**
|
||
* Tests whether a device type condition does not match a crawler.
|
||
* @test
|
||
*/
|
||
public function deviceConditionDoesNotMatchRobot() {
|
||
$_SERVER['HTTP_USER_AGENT'] = md5('Some strange user agent');
|
||
$result = $this->matchCondition->match('[device = robot]');
|
||
$this->assertFalse($result);
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesSingleLanguageExpression() {
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = *de*]'));
|
||
$this->assertTrue($this->matchCondition->match('[language = *de-de*]'));
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesMultipleLanguagesExpression() {
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = *en*,*de*]'));
|
||
$this->assertTrue($this->matchCondition->match('[language = *en-us*,*de-de*]'));
|
||
}
|
||
/**
|
||
* Tests whether the language comparison matches.
|
||
* @test
|
||
*/
|
||
public function languageConditionMatchesCompleteLanguagesExpression() {
|
||
$this->markTestSkipped('This comparison seems to be incomplete in t3lib_matchCondition.');
|
||
$_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'de-de,de;q=0.8,en-us;q=0.5,en;q=0.3';
|
||
$this->assertTrue($this->matchCondition->match('[language = de-de,de;q=0.8]'));
|
||
}
|
||
/**
|
||
* Tests whether usergroup comparison matches.
|
||
* @test
|
||
*/
|
||
public function usergroupConditionMatchesSingleGroupId() {
|
||
$GLOBALS['BE_USER']->groupList = '13,14,15';
|
||
$this->assertTrue($this->matchCondition->match('[usergroup = 13]'));
|
||
}
|
||
/**
|
||
* Tests whether usergroup comparison matches.
|
||
* @test
|
||
*/
|
||
public function usergroupConditionMatchesMultipleUserGroupId() {
|
||
$GLOBALS['BE_USER']->groupList = '13,14,15';
|
||
$this->assertTrue($this->matchCondition->match('[usergroup = 999,15,14,13]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesAnyLoggedInUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = *]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesSingleLoggedInUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = 13]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionDoesNotMatchSingleLoggedInUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 13;
|
||
$this->assertFalse($this->matchCondition->match('[loginUser = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether user comparison matches.
|
||
* @test
|
||
*/
|
||
public function loginUserConditionMatchesMultipleLoggedInUsers() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 13;
|
||
$this->assertTrue($this->matchCondition->match('[loginUser = 999,13]'));
|
||
}
|
||
/**
|
||
* Tests whether checkinf for an admin user matches
|
||
* @test
|
||
*/
|
||
public function adminUserConditionMatchesAdminUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 13;
|
||
$GLOBALS['BE_USER']->user['admin'] = 1;
|
||
$this->assertTrue($this->matchCondition->match('[adminUser = 1]'));
|
||
}
|
||
/**
|
||
* Tests whether checkinf for an admin user matches
|
||
* @test
|
||
*/
|
||
public function adminUserConditionMatchesRegularUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 14;
|
||
$GLOBALS['BE_USER']->user['admin'] = 0;
|
||
$this->assertTrue($this->matchCondition->match('[adminUser = 0]'));
|
||
}
|
||
/**
|
||
* Tests whether checkinf for an admin user matches
|
||
* @test
|
||
*/
|
||
public function adminUserConditionDoesNotMatchRegularUser() {
|
||
$GLOBALS['BE_USER']->user['uid'] = 14;
|
||
$GLOBALS['BE_USER']->user['admin'] = 0;
|
||
$this->assertFalse($this->matchCondition->match('[adminUser = 1]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 = 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 = 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 == 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 == 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnNotEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 != 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 != 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnLowerThanExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 < 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 < 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnLowerThanOrEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 <= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 <= 20]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 <= 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 <= 10.2]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnGreaterThanExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:20 > 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.2 > 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether numerical comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalVarConditionMatchesOnGreaterThanOrEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10 >= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:20 >= 10]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.1 >= 10.1]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalVar = LIT:10.2 >= 10.1]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesOnEqualExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3.Test.Condition]'));
|
||
$this->assertFalse($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesWildcardExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3?Test?Condition]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3.T*t.Condition]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = TYPO3?T*t?Condition]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesRegularExpression() {
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^[A-Za-z3.]+$/]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^TYPO3\..+Condition$/]'));
|
||
$this->assertFalse($this->matchCondition->match('[globalString = LIT:TYPO3.Test.Condition = /^FALSE/]'));
|
||
}
|
||
/**
|
||
* Tests whether string comparison matches.
|
||
* @test
|
||
*/
|
||
public function globalStringConditionMatchesEmptyRegularExpression() {
|
||
$testKey = uniqid('test');
|
||
$_SERVER[$testKey] = '';
|
||
$this->assertTrue($this->matchCondition->match('[globalString = _SERVER|' . $testKey . ' = /^$/]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionMatchesSingleValue() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->assertTrue($this->matchCondition->match('[treeLevel = 2]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionMatchesMultipleValues() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->assertTrue($this->matchCondition->match('[treeLevel = 999,998,2]'));
|
||
}
|
||
/**
|
||
* Tests whether treeLevel comparison matches.
|
||
* @test
|
||
*/
|
||
public function treeLevelConditionDoesNotMatchFaultyValue() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->assertFalse($this->matchCondition->match('[treeLevel = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesSinglePageIdInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 111]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesMultiplePageIdsInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 999,111,101]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionDoesNotMatchPageIdNotInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertFalse($this->matchCondition->match('[PIDupinRootline = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionDoesNotMatchLastPageIdInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertFalse($this->matchCondition->match('[PIDupinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesCurrentPageIdWhileEditingNewPage() {
|
||
$GLOBALS['SOBE'] = $this->getMock('SC_alt_doc', array());
|
||
$GLOBALS['SOBE']->elementsData = array(
|
||
array(
|
||
'table' => 'pages',
|
||
'uid' => 'NEW4adc6021e37e7',
|
||
'pid' => 121,
|
||
'cmd' => 'new',
|
||
'deleteAccess' => 0,
|
||
),
|
||
);
|
||
$GLOBALS['SOBE']->data = array();
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in the previous rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDupinRootlineConditionMatchesCurrentPageIdWhileSavingNewPage() {
|
||
$GLOBALS['SOBE'] = $this->getMock('SC_alt_doc', array());
|
||
$GLOBALS['SOBE']->elementsData = array(
|
||
array(
|
||
'table' => 'pages',
|
||
/// 999 is the uid of the page that was just created
|
||
'uid' => 999,
|
||
'pid' => 121,
|
||
'cmd' => 'edit',
|
||
'deleteAccess' => 1,
|
||
),
|
||
);
|
||
$GLOBALS['SOBE']->data = array(
|
||
'pages' => array(
|
||
'NEW4adc6021e37e7' => array(
|
||
'pid' => 121,
|
||
),
|
||
),
|
||
);
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDupinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesSinglePageIdInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 111]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesMultiplePageIdsInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 999,111,101]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionMatchesLastPageIdInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertTrue($this->matchCondition->match('[PIDinRootline = 121]'));
|
||
}
|
||
/**
|
||
* Tests whether a page Id is found in all rootline entries.
|
||
* @test
|
||
*/
|
||
public function PIDinRootlineConditionDoesNotMatchPageIdNotInRootline() {
|
||
$this->matchCondition->setRootline($this->rootline);
|
||
$this->matchCondition->setPageId(121);
|
||
$this->assertFalse($this->matchCondition->match('[PIDinRootline = 999]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionMatchesOlderRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertTrue($this->matchCondition->match('[compatVersion = 4.0]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionMatchesSameRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertTrue($this->matchCondition->match('[compatVersion = 4.9]'));
|
||
}
|
||
/**
|
||
* Tests whether the compatibility version can be evaluated.
|
||
* (e.g. 4.9 is compatible to 4.0 but not to 5.0)
|
||
* @test
|
||
*/
|
||
public function compatVersionConditionDoesNotMatchNewerRelease() {
|
||
$GLOBALS['TYPO3_CONF_VARS']['SYS']['compat_version'] = '4.9';
|
||
$this->assertFalse($this->matchCondition->match('[compatVersion = 5.0]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'GP'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceGP() {
|
||
$_GET = array('testGet' => 'getTest');
|
||
$_POST = array('testPost' => 'postTest');
|
||
$this->assertTrue($this->matchCondition->match('[globalString = GP:testGet = getTest]'));
|
||
$this->assertTrue($this->matchCondition->match('[globalString = GP:testPost = postTest]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables does not work with the namespace 'TSFE',
|
||
* since we are in the backend context here.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesFailsWithNamespaceTSFE() {
|
||
$GLOBALS['TSFE'] = new stdClass();
|
||
$GLOBALS['TSFE']->id = 1234567;
|
||
$this->assertFalse($this->matchCondition->match('[globalString = TSFE:id = 1234567]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'ENV'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceENV() {
|
||
$testKey = uniqid('test');
|
||
putenv($testKey .'=testValue');
|
||
$this->assertTrue($this->matchCondition->match('[globalString = ENV:' . $testKey . ' = testValue]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with the namespace 'IENV'.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithNamespaceIENV() {
|
||
$_SERVER['HTTP_HOST'] = t3lib_div::getIndpEnv('TYPO3_HOST_ONLY') . ':1234567';
|
||
$this->assertTrue($this->matchCondition->match('[globalString = IENV:TYPO3_PORT = 1234567]'));
|
||
}
|
||
/**
|
||
* Tests whether the generic fetching of variables works with any global namespace.
|
||
* @test
|
||
*/
|
||
public function genericGetVariablesSucceedsWithAnyGlobalNamespace() {
|
||
$GLOBALS[$this->testGlobalNamespace] = array(
|
||
'first' => 'testFirst',
|
||
'second' => array('third' => 'testThird'),
|
||
);
|
||
$this->assertTrue($this->matchCondition->match(
|
||
'[globalString = ' . $this->testGlobalNamespace . '|first = testFirst]'
|
||
));
|
||
$this->assertTrue($this->matchCondition->match(
|
||
'[globalString = ' . $this->testGlobalNamespace . '|second|third = testThird]'
|
||
));
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileCallingModuleWithPageTree() {
|
||
$_GET['id'] = 999;
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileEditingAPageRecord() {
|
||
$_GET['edit']['pages'][999] = 'edit';
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileEditingARegularRecord() {
|
||
$this->setUpDatabaseMockForDeterminePageId();
|
||
$_GET['edit'][$this->testTableName][13] = 'edit';
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileCreatingARecord() {
|
||
$_GET['edit']['pages'][999] = 'new';
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileCreatingARecordAfterAnExistingRecord() {
|
||
$this->setUpDatabaseMockForDeterminePageId();
|
||
$_GET['edit'][$this->testTableName][-13] = 'new';
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileDeletingAPageRecord() {
|
||
$_GET['cmd']['pages'][999]['delete'] = 1;
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileCopyingARecordToAnotherPage() {
|
||
$_GET['cmd']['pages'][121]['copy'] = 999;
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileCopyingARecordAfterAnExistingRecord() {
|
||
$this->setUpDatabaseMockForDeterminePageId();
|
||
$_GET['cmd'][$this->testTableName][121]['copy'] = -13;
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Tests whether determining a pageId works.
|
||
* @test
|
||
*/
|
||
public function pageIdCanBeDeterminedWhileMovingARecordToAnotherPage() {
|
||
$_GET['cmd']['pages'][121]['move'] = 999;
|
||
$this->matchCondition->match('[globalVar = LIT:10 = 10]');
|
||
$this->assertEquals(999, $this->matchCondition->getPageId());
|
||
}
|
||
/**
|
||
* Callback method for pageIdCanBeDetermined test cases.
|
||
* Simulates TYPO3_DB->exec_SELECTquery().
|
||
*
|
||
* @param string $fields
|
||
* @param string $table
|
||
* @param string $where
|
||
* @return mixed
|
||
*/
|
||
public function determinePageIdByRecordDatabaseExecuteCallback($fields, $table, $where) {
|
||
if ($table === $this->testTableName) {
|
||
return array(
|
||
'scope' => $this->testTableName,
|
||
'processed' => false,
|
||
'data' => array(
|
||
'pid' => 999,
|
||
),
|
||
);
|
||
} else {
|
||
return FALSE;
|
||
}
|
||
}
|
||
/**
|
||
* Callback method for pageIdCanBeDetermined test cases.
|
||
* Simulates TYPO3_DB->sql_fetch_assoc().
|
||
*
|
||
* @param mixed $resource
|
||
* @return mixed
|
||
*/
|
||
public function determinePageIdByRecordDatabaseFetchCallback(&$resource) {
|
||
if (is_array($resource) && !$resource['processed'] && $resource['scope'] === $this->testTableName) {
|
||
$resource['processed'] = true;
|
||
return $resource['data'];
|
||
} else {
|
||
return FALSE;
|
||
}
|
||
}
|
||
}
|
||
?>
|