07f02e4497
now it correctly check first char of variable
212 lines
5.0 KiB
Go
212 lines
5.0 KiB
Go
package scalar_test
|
|
|
|
import (
|
|
"bytes"
|
|
"testing"
|
|
|
|
"github.com/z7zmey/php-parser/node/expr"
|
|
|
|
"github.com/z7zmey/php-parser/node"
|
|
"github.com/z7zmey/php-parser/node/scalar"
|
|
"github.com/z7zmey/php-parser/node/stmt"
|
|
"github.com/z7zmey/php-parser/php5"
|
|
"github.com/z7zmey/php-parser/php7"
|
|
)
|
|
|
|
func TestSimpleVar(t *testing.T) {
|
|
src := `<? "test $var";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "var"}},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestSimpleVarOneChar(t *testing.T) {
|
|
src := `<? "test $a";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "a"}},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestSimpleVarEndsEcapsed(t *testing.T) {
|
|
src := `<? "test $var\"";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "var"}},
|
|
&scalar.EncapsedStringPart{Value: "\\\""},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestStringVarCurveOpen(t *testing.T) {
|
|
src := `<? "=$a{$b}";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "="},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "a"}},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "b"}},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestSimpleVarPropertyFetch(t *testing.T) {
|
|
src := `<? "test $foo->bar()";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.PropertyFetch{
|
|
Variable: &expr.Variable{VarName: &node.Identifier{Value: "foo"}},
|
|
Property: &node.Identifier{Value: "bar"},
|
|
},
|
|
&scalar.EncapsedStringPart{Value: "()"},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestDollarOpenCurlyBraces(t *testing.T) {
|
|
src := `<? "test ${foo}";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.Variable{VarName: &node.Identifier{Value: "foo"}},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestDollarOpenCurlyBracesDimNumber(t *testing.T) {
|
|
src := `<? "test ${foo[0]}";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.ArrayDimFetch{
|
|
Variable: &expr.Variable{VarName: &node.Identifier{Value: "foo"}},
|
|
Dim: &scalar.Lnumber{Value: "0"},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|
|
|
|
func TestCurlyOpenMethodCall(t *testing.T) {
|
|
src := `<? "test {$foo->bar()}";`
|
|
|
|
expected := &stmt.StmtList{
|
|
Stmts: []node.Node{
|
|
&stmt.Expression{
|
|
Expr: &scalar.Encapsed{
|
|
Parts: []node.Node{
|
|
&scalar.EncapsedStringPart{Value: "test "},
|
|
&expr.MethodCall{
|
|
Variable: &expr.Variable{VarName: &node.Identifier{Value: "foo"}},
|
|
Method: &node.Identifier{Value: "bar"},
|
|
Arguments: []node.Node{},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
actual, _, _ := php7.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
|
|
actual, _, _ = php5.Parse(bytes.NewBufferString(src), "test.php")
|
|
assertEqual(t, expected, actual)
|
|
}
|