Files
chaisql/internal/sql/parser/parser_test.go
2021-05-23 23:50:18 +04:00

46 lines
1.0 KiB
Go

package parser_test
import (
"testing"
"github.com/stretchr/testify/require"
"github.com/genjidb/genji/internal/expr"
"github.com/genjidb/genji/internal/query"
"github.com/genjidb/genji/internal/sql/parser"
)
func TestParserMultiStatement(t *testing.T) {
tests := []struct {
name string
s string
expected []query.Statement
}{
{"OnlyCommas", ";;;", nil},
{"TrailingComma", "SELECT * FROM foo;;;DELETE FROM foo;", []query.Statement{
&query.SelectStmt{
TableName: "foo",
ProjectionExprs: []expr.Expr{expr.Wildcard{}},
},
&query.DeleteStmt{
TableName: "foo",
},
}},
}
for _, test := range tests {
t.Run(test.name, func(t *testing.T) {
q, err := parser.ParseQuery(test.s)
require.NoError(t, err)
require.EqualValues(t, test.expected, q.Statements)
})
}
}
func TestParserDivideByZero(t *testing.T) {
// See https://github.com/genjidb/genji/issues/268
require.NotPanics(t, func() {
_, _ = parser.ParseQuery("SELECT * FROM t LIMIT 0 % .5")
})
}