mirror of
https://github.com/chaisql/chai.git
synced 2025-10-30 18:36:27 +08:00
63 lines
2.0 KiB
Go
63 lines
2.0 KiB
Go
package parser_test
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/genjidb/genji/internal/query/statement"
|
|
"github.com/genjidb/genji/internal/sql/parser"
|
|
"github.com/genjidb/genji/internal/stream"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestParserDelete(t *testing.T) {
|
|
tests := []struct {
|
|
name string
|
|
s string
|
|
expected *stream.Stream
|
|
}{
|
|
{"NoCond", "DELETE FROM test", stream.New(stream.SeqScan("test")).Pipe(stream.TableDelete("test"))},
|
|
{"WithCond", "DELETE FROM test WHERE age = 10",
|
|
stream.New(stream.SeqScan("test")).
|
|
Pipe(stream.Filter(parser.MustParseExpr("age = 10"))).
|
|
Pipe(stream.TableDelete("test")),
|
|
},
|
|
{"WithOffset", "DELETE FROM test WHERE age = 10 OFFSET 20",
|
|
stream.New(stream.SeqScan("test")).
|
|
Pipe(stream.Filter(parser.MustParseExpr("age = 10"))).
|
|
Pipe(stream.Skip(20)).
|
|
Pipe(stream.TableDelete("test")),
|
|
},
|
|
{"WithLimit", "DELETE FROM test LIMIT 10",
|
|
stream.New(stream.SeqScan("test")).
|
|
Pipe(stream.Take(10)).
|
|
Pipe(stream.TableDelete("test")),
|
|
},
|
|
{"WithOrderByThenOffset", "DELETE FROM test WHERE age = 10 ORDER BY age OFFSET 20",
|
|
stream.New(stream.SeqScan("test")).
|
|
Pipe(stream.Filter(parser.MustParseExpr("age = 10"))).
|
|
Pipe(stream.Sort(parser.MustParseExpr("age"))).
|
|
Pipe(stream.Skip(20)).
|
|
Pipe(stream.TableDelete("test")),
|
|
},
|
|
{"WithOrderByThenLimitThenOffset", "DELETE FROM test WHERE age = 10 ORDER BY age LIMIT 10 OFFSET 20",
|
|
stream.New(stream.SeqScan("test")).
|
|
Pipe(stream.Filter(parser.MustParseExpr("age = 10"))).
|
|
Pipe(stream.Sort(parser.MustParseExpr("age"))).
|
|
Pipe(stream.Skip(20)).
|
|
Pipe(stream.Take(10)).
|
|
Pipe(stream.TableDelete("test")),
|
|
},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
t.Run(test.name, func(t *testing.T) {
|
|
q, err := parser.ParseQuery(test.s)
|
|
require.NoError(t, err)
|
|
require.Len(t, q.Statements, 1)
|
|
stmt, err := q.Statements[0].(*statement.DeleteStmt).ToStream()
|
|
require.NoError(t, err)
|
|
require.EqualValues(t, &statement.StreamStmt{Stream: test.expected}, stmt)
|
|
})
|
|
}
|
|
}
|