mirror of
https://github.com/chaisql/chai.git
synced 2025-10-05 23:57:01 +08:00
49 lines
1.1 KiB
Go
49 lines
1.1 KiB
Go
package parser_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/chaisql/chai/internal/expr"
|
|
"github.com/chaisql/chai/internal/query/statement"
|
|
"github.com/chaisql/chai/internal/sql/parser"
|
|
)
|
|
|
|
func TestParserMultiStatement(t *testing.T) {
|
|
var slct statement.SelectStmt
|
|
slct.CompoundSelect = []*statement.SelectCoreStmt{
|
|
{TableName: "foo", ProjectionExprs: []expr.Expr{expr.Wildcard{}}},
|
|
}
|
|
|
|
var dlt statement.DeleteStmt
|
|
dlt.TableName = "foo"
|
|
|
|
tests := []struct {
|
|
name string
|
|
s string
|
|
expected []statement.Statement
|
|
}{
|
|
{"OnlyCommas", ";;;", nil},
|
|
{"TrailingComma", "SELECT * FROM foo;;;DELETE FROM foo;", []statement.Statement{
|
|
&slct,
|
|
&dlt,
|
|
}},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
t.Run(test.name, func(t *testing.T) {
|
|
stmts, err := parser.ParseQuery(test.s)
|
|
require.NoError(t, err)
|
|
require.EqualValues(t, test.expected, stmts)
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestParserDivideByZero(t *testing.T) {
|
|
// See https://github.com/chaisql/chai/issues/268
|
|
require.NotPanics(t, func() {
|
|
_, _ = parser.ParseQuery("SELECT * FROM t LIMIT 0 % .5")
|
|
})
|
|
}
|