Files
chaisql/internal/sql/parser/parser_test.go
2025-08-31 17:45:17 +08:00

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")
})
}