/
BladePhpStatementsTest.php
94 lines (69 loc) · 3.23 KB
/
BladePhpStatementsTest.php
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
<?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));
}
public function testStringWithParenthesisCannotBeCompiled()
{
$string = "@php(\$data = ['test' => ')'])";
$expected = "<?php (\$data = ['test' => ')']); ?>";
$actual = "<?php (\$data = ['test' => '); ?>'])";
$this->assertEquals($actual, $this->compiler->compileString($string));
}
public function testStringWithEmptyStringDataValue()
{
$string = "@php(\$data = ['test' => ''])";
$expected = "<?php (\$data = ['test' => '']); ?>";
$this->assertEquals($expected, $this->compiler->compileString($string));
$string = "@php(\$data = ['test' => \"\"])";
$expected = "<?php (\$data = ['test' => \"\"]); ?>";
$this->assertEquals($expected, $this->compiler->compileString($string));
}
public function testStringWithEscapingDataValue()
{
$string = "@php(\$data = ['test' => 'won\\'t break'])";
$expected = "<?php (\$data = ['test' => 'won\\'t break']); ?>";
$this->assertEquals($expected, $this->compiler->compileString($string));
$string = "@php(\$data = ['test' => \"\\\"escaped\\\"\"])";
$expected = "<?php (\$data = ['test' => \"\\\"escaped\\\"\"]); ?>";
$this->assertEquals($expected, $this->compiler->compileString($string));
}
public function testCompilationOfMixedPhpStatements()
{
$string = '@php($set = true) @php ($hello = \'hi\') @php echo "Hello world" @endphp';
$expected = '<?php ($set = true); ?> <?php ($hello = \'hi\'); ?> <?php echo "Hello world" ?>';
$this->assertEquals($expected, $this->compiler->compileString($string));
}
}