Files
smarty/tests/UnitTests/TemplateSource/ValueTests/ConstantTests/ConstantsTest.php
Simon Wisselink 39b69f0142 Feature/php8 support (#629)
Adds support for PHP8.0, dropping support for PHP7.0 and below.

Backwards incompatible changes:
- Dropped support for php asp tags in templates (removed from php since php7.0)
- Dropped deprecated API calls that where only accessible through SmartyBC
- Dropped support for {php} and {include_php} tags and embedded PHP in templates. Embedded PHP will now be passed through as is.
- Removed all PHP_VERSION_ID and compare_version checks and conditional code blocks that are now no longer required
- Dropped deprecated SMARTY_RESOURCE_CHAR_SET and SMARTY_RESOURCE_DATE_FORMAT constants
- Dropped deprecated Smarty::muteExpectedErrors and Smarty::unmuteExpectedErrors API methods
- Dropped deprecated $smarty->getVariable() method. Use $smarty->getTemplateVars() instead.
- $smarty->registerResource() no longer accepts an array of callback functions

See the changelog for more details.

Switched CI from Travis to Github CI.
2021-10-13 12:15:17 +02:00

98 lines
2.7 KiB
PHP

<?php
/**
* Smarty PHPunit tests of constants
*
* @package PHPunit
* @author Uwe Tews
* @runTestsInSeparateProcess
* @preserveGlobalState disabled
* @backupStaticAttributes enabled
*/
Class TestConst
{
const CONSTVAL = 'okay';
}
/**
* class for constants tests
*/
class ConstantsTest extends PHPUnit_Smarty
{
public function setUp(): void
{
$this->setUpSmarty(dirname(__FILE__));
}
public function testInit()
{
$this->cleanDirs();
}
/**
* test constants
*/
public function testConstants()
{
define('MYCONSTANTS', 'hello world');
$tpl = $this->smarty->createTemplate('eval:{$smarty.const.MYCONSTANTS}');
$this->assertEquals("hello world", $this->smarty->fetch($tpl));
}
public function testConstants2()
{
$tpl = $this->smarty->createTemplate('eval:{MYCONSTANTS}');
$this->assertEquals("hello world", $this->smarty->fetch($tpl));
}
public function testConstants3()
{
$tpl = $this->smarty->createTemplate('eval:{$x=MYCONSTANTS}{$x}');
$this->assertEquals("hello world", $this->smarty->fetch($tpl));
}
public function testConstants4()
{
$tpl = $this->smarty->createTemplate('eval:{TestConst::CONSTVAL}');
$this->assertEquals("okay", $this->smarty->fetch($tpl));
}
public function testConstants5()
{
$tpl = $this->smarty->createTemplate('eval:{if TestConst::CONSTVAL == "okay"}yes{/if}');
$this->assertEquals("yes", $this->smarty->fetch($tpl));
}
public function testConstants6()
{
$tpl = $this->smarty->createTemplate('eval:{$obj::CONSTVAL}');
$tpl->assign('obj', new TestConst());
$this->assertEquals("okay", $this->smarty->fetch($tpl));
}
public function testConstants7()
{
$tpl = $this->smarty->createTemplate('eval:{if $obj::CONSTVAL == "okay"}yes{/if}');
$tpl->assign('obj', new TestConst());
$this->assertEquals("yes", $this->smarty->fetch($tpl));
}
public function testConstantsUndefined()
{
$tpl = $this->smarty->createTemplate('string:{$smarty.const.MYCONSTANT2}');
$this->assertEquals("", $this->smarty->fetch($tpl));
}
public function testConstantsUndefined2()
{
$tpl = $this->smarty->createTemplate('eval:{$foo = MYCONSTANT2}{$foo}');
$this->assertEquals("MYCONSTANT2", $this->smarty->fetch($tpl));
}
public function testConstantsUndefined3()
{
$tpl = $this->smarty->createTemplate('eval:{if $smarty.const.MYCONSTANT2}{$smarty.const.MYCONSTANT2}{/if}');
$this->assertEquals("", $this->smarty->fetch($tpl));
}
}