1
Fork 0
simple-sql-parser/tests/Language/SQL/SimpleSQL/Odbc.hs

61 lines
2.5 KiB
Haskell
Raw Permalink Normal View History

{-# LANGUAGE OverloadedStrings #-}
module Language.SQL.SimpleSQL.Odbc (odbcTests) where
import Language.SQL.SimpleSQL.TestTypes
import Language.SQL.SimpleSQL.Syntax
import Language.SQL.SimpleSQL.TestRunners
import Data.Text (Text)
odbcTests :: TestItem
odbcTests = Group "odbc" [
Group "datetime" [
e "{d '2000-01-01'}" (OdbcLiteral OLDate "2000-01-01")
,e "{t '12:00:01.1'}" (OdbcLiteral OLTime "12:00:01.1")
,e "{ts '2000-01-01 12:00:01.1'}"
(OdbcLiteral OLTimestamp "2000-01-01 12:00:01.1")
]
,Group "functions" [
e "{fn CHARACTER_LENGTH(string_exp)}"
$ OdbcFunc (ap "CHARACTER_LENGTH" [iden "string_exp"])
,e "{fn EXTRACT(day from t)}"
$ OdbcFunc (SpecialOpK [Name Nothing "extract"] (Just $ Iden [Name Nothing "day"]) [("from", Iden [Name Nothing "t"])])
,e "{fn now()}"
$ OdbcFunc (ap "now" [])
,e "{fn CONVERT('2000-01-01', SQL_DATE)}"
$ OdbcFunc (ap "CONVERT"
[StringLit "'" "'" "2000-01-01"
,iden "SQL_DATE"])
,e "{fn CONVERT({fn CURDATE()}, SQL_DATE)}"
$ OdbcFunc (ap "CONVERT"
[OdbcFunc (ap "CURDATE" [])
,iden "SQL_DATE"])
]
,Group "outer join" [
q
"select * from {oj t1 left outer join t2 on expr}"
$ toQueryExpr $ makeSelect
{msSelectList = [(Star,Nothing)]
,msFrom = [TROdbc $ TRJoin (TRSimple [Name Nothing "t1"]) False JLeft (TRSimple [Name Nothing "t2"])
(Just $ JoinOn $ Iden [Name Nothing "expr"])]}]
,Group "check parsing bugs" [
q
"select {fn CONVERT(cint,SQL_BIGINT)} from t;"
$ toQueryExpr $ makeSelect
{msSelectList = [(OdbcFunc (ap "CONVERT"
[iden "cint"
,iden "SQL_BIGINT"]), Nothing)]
,msFrom = [TRSimple [Name Nothing "t"]]}]
]
where
e :: HasCallStack => Text -> ScalarExpr -> TestItem
e src ast = testScalarExpr ansi2011{diOdbc = True} src ast
q :: HasCallStack => Text -> QueryExpr -> TestItem
q src ast = testQueryExpr ansi2011{diOdbc = True} src ast
--tsql = ParseProcSql defaultParseFlags {pfDialect=sqlServerDialect}
ap n = App [Name Nothing n]
iden n = Iden [Name Nothing n]