2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
{-
|
|
|
|
These are the tests for the query expression components apart from the
|
|
|
|
table refs which are in a separate file.
|
|
|
|
|
|
|
|
|
|
|
|
These are a few misc tests which don't fit anywhere else.
|
|
|
|
-}
|
|
|
|
|
2024-01-10 08:40:24 +01:00
|
|
|
{-# LANGUAGE OverloadedStrings #-}
|
2024-01-09 01:07:47 +01:00
|
|
|
module Language.SQL.SimpleSQL.QueryExprComponents (queryExprComponentTests) where
|
|
|
|
|
|
|
|
import Language.SQL.SimpleSQL.TestTypes
|
|
|
|
import Language.SQL.SimpleSQL.Syntax
|
2024-02-04 17:00:59 +01:00
|
|
|
import Language.SQL.SimpleSQL.TestRunners
|
|
|
|
import Data.Text (Text)
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
queryExprComponentTests :: TestItem
|
|
|
|
queryExprComponentTests = Group "queryExprComponentTests"
|
|
|
|
[duplicates
|
|
|
|
,selectLists
|
|
|
|
,whereClause
|
|
|
|
,having
|
|
|
|
,orderBy
|
|
|
|
,offsetFetch
|
|
|
|
,combos
|
|
|
|
,withQueries
|
|
|
|
,values
|
|
|
|
,tables
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
duplicates :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
duplicates = Group "duplicates"
|
|
|
|
[q "select a from t" $ ms SQDefault
|
|
|
|
,q "select all a from t" $ ms All
|
|
|
|
,q "select distinct a from t" $ ms Distinct
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
where
|
2024-01-11 15:45:20 +01:00
|
|
|
ms d = toQueryExpr $ makeSelect
|
|
|
|
{msSetQuantifier = d
|
|
|
|
,msSelectList = [(Iden [Name Nothing "a"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
selectLists :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
selectLists = Group "selectLists"
|
|
|
|
[q "select 1"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(NumLit "1",Nothing)]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a,b"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)
|
|
|
|
,(Iden [Name Nothing "b"],Nothing)]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select 1+2,3+4"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList =
|
2024-01-09 01:07:47 +01:00
|
|
|
[(BinOp (NumLit "1") [Name Nothing "+"] (NumLit "2"),Nothing)
|
2024-02-04 17:00:59 +01:00
|
|
|
,(BinOp (NumLit "3") [Name Nothing "+"] (NumLit "4"),Nothing)]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a as a, /*comment*/ b as b"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"], Just $ Name Nothing "a")
|
|
|
|
,(Iden [Name Nothing "b"], Just $ Name Nothing "b")]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a a, b b"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"], Just $ Name Nothing "a")
|
|
|
|
,(Iden [Name Nothing "b"], Just $ Name Nothing "b")]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a + b * c"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList =
|
2024-01-09 01:07:47 +01:00
|
|
|
[(BinOp (Iden [Name Nothing "a"]) [Name Nothing "+"]
|
|
|
|
(BinOp (Iden [Name Nothing "b"]) [Name Nothing "*"] (Iden [Name Nothing "c"]))
|
2024-02-04 17:00:59 +01:00
|
|
|
,Nothing)]}
|
2024-02-08 11:43:11 +01:00
|
|
|
,q "select * from t"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Star,Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]}
|
|
|
|
|
|
|
|
,q "select t.* from t"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(QStar [Name Nothing "t"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]}
|
|
|
|
|
|
|
|
,q "select t.*, a as b, u.* from t"
|
|
|
|
$ toQueryExpr $ makeSelect
|
|
|
|
{msSelectList =
|
|
|
|
[(QStar [Name Nothing "t"],Nothing)
|
|
|
|
,(Iden [Name Nothing "a"], Just $ Name Nothing "b")
|
|
|
|
,(QStar [Name Nothing "u"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]}
|
|
|
|
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
whereClause :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
whereClause = Group "whereClause"
|
|
|
|
[q "select a from t where a = 5"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)]
|
2024-01-11 15:45:20 +01:00
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]
|
2024-02-04 17:00:59 +01:00
|
|
|
,msWhere = Just $ BinOp (Iden [Name Nothing "a"]) [Name Nothing "="] (NumLit "5")}
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
having :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
having = Group "having"
|
|
|
|
[q "select a,sum(b) from t group by a having sum(b) > 5"
|
|
|
|
$ toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)
|
2024-01-09 01:07:47 +01:00
|
|
|
,(App [Name Nothing "sum"] [Iden [Name Nothing "b"]],Nothing)]
|
2024-01-11 15:45:20 +01:00
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]
|
|
|
|
,msGroupBy = [SimpleGroup $ Iden [Name Nothing "a"]]
|
|
|
|
,msHaving = Just $ BinOp (App [Name Nothing "sum"] [Iden [Name Nothing "b"]])
|
2024-01-09 01:07:47 +01:00
|
|
|
[Name Nothing ">"] (NumLit "5")
|
2024-02-04 17:00:59 +01:00
|
|
|
}
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
orderBy :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
orderBy = Group "orderBy"
|
|
|
|
[q "select a from t order by a"
|
|
|
|
$ ms [SortSpec (Iden [Name Nothing "a"]) DirDefault NullsOrderDefault]
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t order by a, b"
|
|
|
|
$ ms [SortSpec (Iden [Name Nothing "a"]) DirDefault NullsOrderDefault
|
|
|
|
,SortSpec (Iden [Name Nothing "b"]) DirDefault NullsOrderDefault]
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t order by a asc"
|
|
|
|
$ ms [SortSpec (Iden [Name Nothing "a"]) Asc NullsOrderDefault]
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t order by a desc, b desc"
|
|
|
|
$ ms [SortSpec (Iden [Name Nothing "a"]) Desc NullsOrderDefault
|
|
|
|
,SortSpec (Iden [Name Nothing "b"]) Desc NullsOrderDefault]
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t order by a desc nulls first, b desc nulls last"
|
|
|
|
$ ms [SortSpec (Iden [Name Nothing "a"]) Desc NullsFirst
|
|
|
|
,SortSpec (Iden [Name Nothing "b"]) Desc NullsLast]
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
]
|
|
|
|
where
|
2024-01-11 15:45:20 +01:00
|
|
|
ms o = toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]
|
|
|
|
,msOrderBy = o}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
offsetFetch :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
offsetFetch = Group "offsetFetch"
|
2024-01-09 01:07:47 +01:00
|
|
|
[-- ansi standard
|
2024-02-04 17:00:59 +01:00
|
|
|
q "select a from t offset 5 rows fetch next 10 rows only"
|
|
|
|
$ ms (Just $ NumLit "5") (Just $ NumLit "10")
|
|
|
|
,q "select a from t offset 5 rows;"
|
|
|
|
$ ms (Just $ NumLit "5") Nothing
|
|
|
|
,q "select a from t fetch next 10 row only;"
|
|
|
|
$ ms Nothing (Just $ NumLit "10")
|
|
|
|
,q "select a from t offset 5 row fetch first 10 row only"
|
|
|
|
$ ms (Just $ NumLit "5") (Just $ NumLit "10")
|
2024-01-09 01:07:47 +01:00
|
|
|
-- postgres: disabled, will add back when postgres
|
|
|
|
-- dialect is added
|
2024-02-04 17:00:59 +01:00
|
|
|
--,q "select a from t limit 10 offset 5"
|
|
|
|
-- $ ms (Just $ NumLit "5") (Just $ NumLit "10"))
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
where
|
2024-01-11 15:45:20 +01:00
|
|
|
ms o l = toQueryExpr $ makeSelect
|
|
|
|
{msSelectList = [(Iden [Name Nothing "a"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]
|
|
|
|
,msOffset = o
|
|
|
|
,msFetchFirst = l}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
combos :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
combos = Group "combos"
|
|
|
|
[q "select a from t union select b from u"
|
|
|
|
$ QueryExprSetOp mst Union SQDefault Respectively msu
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t intersect select b from u"
|
|
|
|
$ QueryExprSetOp mst Intersect SQDefault Respectively msu
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t except all select b from u"
|
|
|
|
$ QueryExprSetOp mst Except All Respectively msu
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t union distinct corresponding \
|
2024-01-09 01:07:47 +01:00
|
|
|
\select b from u"
|
2024-02-04 17:00:59 +01:00
|
|
|
$ QueryExprSetOp mst Union Distinct Corresponding msu
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "select a from t union select a from t union select a from t"
|
|
|
|
$ QueryExprSetOp (QueryExprSetOp mst Union SQDefault Respectively mst)
|
|
|
|
Union SQDefault Respectively mst
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
where
|
2024-01-11 15:45:20 +01:00
|
|
|
mst = toQueryExpr $ makeSelect
|
|
|
|
{msSelectList = [(Iden [Name Nothing "a"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "t"]]}
|
|
|
|
msu = toQueryExpr $ makeSelect
|
|
|
|
{msSelectList = [(Iden [Name Nothing "b"],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing "u"]]}
|
2024-01-09 01:07:47 +01:00
|
|
|
|
|
|
|
|
|
|
|
withQueries :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
withQueries = Group "with queries"
|
|
|
|
[q "with u as (select a from t) select a from u"
|
|
|
|
$ With False [(Alias (Name Nothing "u") Nothing, ms1)] ms2
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "with u(b) as (select a from t) select a from u"
|
|
|
|
$ With False [(Alias (Name Nothing "u") (Just [Name Nothing "b"]), ms1)] ms2
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "with x as (select a from t),\n\
|
2024-01-09 01:07:47 +01:00
|
|
|
\ u as (select a from x)\n\
|
|
|
|
\select a from u"
|
2024-02-04 17:00:59 +01:00
|
|
|
$ With False [(Alias (Name Nothing "x") Nothing, ms1), (Alias (Name Nothing "u") Nothing,ms3)] ms2
|
2024-01-09 01:07:47 +01:00
|
|
|
|
2024-02-04 17:00:59 +01:00
|
|
|
,q "with recursive u as (select a from t) select a from u"
|
|
|
|
$ With True [(Alias (Name Nothing "u") Nothing, ms1)] ms2
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
where
|
2024-01-11 15:45:20 +01:00
|
|
|
ms c t = toQueryExpr $ makeSelect
|
|
|
|
{msSelectList = [(Iden [Name Nothing c],Nothing)]
|
|
|
|
,msFrom = [TRSimple [Name Nothing t]]}
|
2024-01-09 01:07:47 +01:00
|
|
|
ms1 = ms "a" "t"
|
|
|
|
ms2 = ms "a" "u"
|
|
|
|
ms3 = ms "a" "x"
|
|
|
|
|
|
|
|
values :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
values = Group "values"
|
|
|
|
[q "values (1,2),(3,4)"
|
|
|
|
$ Values [[NumLit "1", NumLit "2"]
|
|
|
|
,[NumLit "3", NumLit "4"]]
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
tables :: TestItem
|
2024-02-04 17:00:59 +01:00
|
|
|
tables = Group "tables"
|
|
|
|
[q "table tbl" $ Table [Name Nothing "tbl"]
|
2024-01-09 01:07:47 +01:00
|
|
|
]
|
2024-02-04 17:00:59 +01:00
|
|
|
|
|
|
|
q :: HasCallStack => Text -> QueryExpr -> TestItem
|
|
|
|
q src ast = testQueryExpr ansi2011 src ast
|