1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46
|
<?php
namespace Illuminate\Tests\View\Blade;
class BladePhpStatementsTest extends AbstractBladeTestCase
{
public function testPhpStatementsWithExpressionAreCompiled()
{
$string = '@php($set = true)';
$expected = '<?php ($set = true); ?>';
$this->assertEquals($expected, $this->compiler->compileString($string));
}
public function testPhpStatementsWithoutExpressionAreIgnored()
{
$string = '@php';
$expected = '@php';
$this->assertEquals($expected, $this->compiler->compileString($string));
$string = '{{ "Ignore: @php" }}';
$expected = '<?php echo e("Ignore: @php"); ?>';
$this->assertEquals($expected, $this->compiler->compileString($string));
}
public function testPhpStatementsDontParseBladeCode()
{
$string = '@php echo "{{ This is a blade tag }}" @endphp';
$expected = '<?php echo "{{ This is a blade tag }}" ?>';
$this->assertEquals($expected, $this->compiler->compileString($string));
}
public function testVerbatimAndPhpStatementsDontGetMixedUp()
{
$string = "@verbatim {{ Hello, I'm not blade! }}"
."\n@php echo 'And I'm not PHP!' @endphp"
."\n@endverbatim {{ 'I am Blade' }}"
."\n@php echo 'I am PHP {{ not Blade }}' @endphp";
$expected = " {{ Hello, I'm not blade! }}"
."\n@php echo 'And I'm not PHP!' @endphp"
."\n <?php echo e('I am Blade'); ?>"
."\n\n<?php echo 'I am PHP {{ not Blade }}' ?>";
$this->assertEquals($expected, $this->compiler->compileString($string));
}
}
|