mirror of
https://github.com/kataras/iris.git
synced 2025-01-26 03:56:34 +01:00
126c4de29b
1. Fix index, including both start and end. So Literal[start:end+1] will be a valid part. 2. Replace any with string, add file param type 3. Start of making the evaluator, starting with regexp for param types (these expression can be changed or/and overriden by user later on) Former-commit-id: ab95265f953dadbf84170b543e1ff8840f9c4a14
133 lines
3.1 KiB
Go
133 lines
3.1 KiB
Go
package parser
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
"strings"
|
|
"testing"
|
|
|
|
"gopkg.in/kataras/iris.v6/_future/ipel/ast"
|
|
)
|
|
|
|
func TestParseError(t *testing.T) {
|
|
// fail
|
|
illegalChar := '$'
|
|
|
|
input := "{id" + string(illegalChar) + "int range(1,5) else 404}"
|
|
p := New(input)
|
|
|
|
_, err := p.Parse()
|
|
|
|
if err == nil {
|
|
t.Fatalf("expecting not empty error on input '%s'", input)
|
|
}
|
|
|
|
// println(input[8:9])
|
|
// println(input[13:17])
|
|
|
|
illIdx := strings.IndexRune(input, illegalChar)
|
|
expectedErr := fmt.Sprintf("[%d:%d] illegal token: %s", illIdx, illIdx, "$")
|
|
if got := err.Error(); got != expectedErr {
|
|
t.Fatalf("expecting error to be '%s' but got: %s", expectedErr, got)
|
|
}
|
|
//
|
|
|
|
// success
|
|
input2 := "{id:int range(1,5) else 404}"
|
|
p.Reset(input2)
|
|
_, err = p.Parse()
|
|
|
|
if err != nil {
|
|
t.Fatalf("expecting empty error on input '%s', but got: %s", input2, err.Error())
|
|
}
|
|
//
|
|
}
|
|
|
|
func TestParse(t *testing.T) {
|
|
tests := []struct {
|
|
input string
|
|
valid bool
|
|
expectedStatement ast.ParamStatement
|
|
}{
|
|
{"{id:int min(1) max(5) else 404}", true,
|
|
ast.ParamStatement{
|
|
Name: "id",
|
|
Type: ast.ParamTypeInt,
|
|
Funcs: []ast.ParamFunc{
|
|
ast.ParamFunc{
|
|
Name: "min",
|
|
Args: []ast.ParamFuncArg{1}},
|
|
ast.ParamFunc{
|
|
Name: "max",
|
|
Args: []ast.ParamFuncArg{5}},
|
|
},
|
|
ErrorCode: 404,
|
|
}}, // 0
|
|
{"{id:int range(1,5)}", true,
|
|
ast.ParamStatement{
|
|
Name: "id",
|
|
Type: ast.ParamTypeInt,
|
|
Funcs: []ast.ParamFunc{
|
|
ast.ParamFunc{
|
|
Name: "range",
|
|
Args: []ast.ParamFuncArg{1, 5}},
|
|
},
|
|
ErrorCode: 404,
|
|
}}, // 1
|
|
{"{file:path contains(.)}", true,
|
|
ast.ParamStatement{
|
|
Name: "file",
|
|
Type: ast.ParamTypePath,
|
|
Funcs: []ast.ParamFunc{
|
|
ast.ParamFunc{
|
|
Name: "contains",
|
|
Args: []ast.ParamFuncArg{"."}},
|
|
},
|
|
ErrorCode: 404,
|
|
}}, // 2
|
|
{"{username:alphabetical}", true,
|
|
ast.ParamStatement{
|
|
Name: "username",
|
|
Type: ast.ParamTypeAlphabetical,
|
|
ErrorCode: 404,
|
|
}}, // 3
|
|
{"{myparam}", true,
|
|
ast.ParamStatement{
|
|
Name: "myparam",
|
|
Type: ast.ParamTypeString,
|
|
ErrorCode: 404,
|
|
}}, // 4
|
|
{"{myparam_:thisianunexpected}", false,
|
|
ast.ParamStatement{
|
|
Name: "myparam_",
|
|
Type: ast.ParamTypeUnExpected,
|
|
ErrorCode: 404,
|
|
}}, // 5
|
|
{"{myparam2}", false, // false because it will give an error of unexpeced token type with value 2
|
|
ast.ParamStatement{
|
|
Name: "myparam", // expected "myparam" because we don't allow integers to the parameter names.
|
|
Type: ast.ParamTypeString,
|
|
ErrorCode: 404,
|
|
}}, // 6
|
|
|
|
}
|
|
var p *Parser = new(Parser)
|
|
for i, tt := range tests {
|
|
p.Reset(tt.input)
|
|
resultStmt, err := p.Parse()
|
|
|
|
if tt.valid && err != nil {
|
|
t.Fatalf("tests[%d] - error %s", i, err.Error())
|
|
} else if !tt.valid && err == nil {
|
|
t.Fatalf("tests[%d] - expected to be a failure", i)
|
|
}
|
|
|
|
if resultStmt != nil { // is valid here
|
|
if !reflect.DeepEqual(tt.expectedStatement, *resultStmt) {
|
|
t.Fatalf("tests[%d] - wrong statement, expected and result differs. Details:\n%#v\n%#v", i, tt.expectedStatement, *resultStmt)
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|