{- These are the tests for parsing focusing on the from part of query expression -} {-# LANGUAGE OverloadedStrings #-} module Language.SQL.SimpleSQL.TableRefs (tableRefTests) where import Language.SQL.SimpleSQL.TestTypes import Language.SQL.SimpleSQL.Syntax tableRefTests :: TestItem tableRefTests = Group "tableRefTests" $ map (uncurry (TestQueryExpr ansi2011)) [("select a from t" ,ms [TRSimple [Name Nothing "t"]]) ,("select a from f(a)" ,ms [TRFunction [Name Nothing "f"] [Iden [Name Nothing "a"]]]) ,("select a from t,u" ,ms [TRSimple [Name Nothing "t"], TRSimple [Name Nothing "u"]]) ,("select a from s.t" ,ms [TRSimple [Name Nothing "s", Name Nothing "t"]]) -- these lateral queries make no sense but the syntax is valid ,("select a from lateral a" ,ms [TRLateral $ TRSimple [Name Nothing "a"]]) ,("select a from lateral a,b" ,ms [TRLateral $ TRSimple [Name Nothing "a"], TRSimple [Name Nothing "b"]]) ,("select a from a, lateral b" ,ms [TRSimple [Name Nothing "a"], TRLateral $ TRSimple [Name Nothing "b"]]) ,("select a from a natural join lateral b" ,ms [TRJoin (TRSimple [Name Nothing "a"]) True JInner (TRLateral $ TRSimple [Name Nothing "b"]) Nothing]) ,("select a from lateral a natural join lateral b" ,ms [TRJoin (TRLateral $ TRSimple [Name Nothing "a"]) True JInner (TRLateral $ TRSimple [Name Nothing "b"]) Nothing]) ,("select a from t inner join u on expr" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JInner (TRSimple [Name Nothing "u"]) (Just $ JoinOn $ Iden [Name Nothing "expr"])]) ,("select a from t join u on expr" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JInner (TRSimple [Name Nothing "u"]) (Just $ JoinOn $ Iden [Name Nothing "expr"])]) ,("select a from t left join u on expr" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JLeft (TRSimple [Name Nothing "u"]) (Just $ JoinOn $ Iden [Name Nothing "expr"])]) ,("select a from t right join u on expr" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JRight (TRSimple [Name Nothing "u"]) (Just $ JoinOn $ Iden [Name Nothing "expr"])]) ,("select a from t full join u on expr" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JFull (TRSimple [Name Nothing "u"]) (Just $ JoinOn $ Iden [Name Nothing "expr"])]) ,("select a from t cross join u" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JCross (TRSimple [Name Nothing "u"]) Nothing]) ,("select a from t natural inner join u" ,ms [TRJoin (TRSimple [Name Nothing "t"]) True JInner (TRSimple [Name Nothing "u"]) Nothing]) ,("select a from t inner join u using(a,b)" ,ms [TRJoin (TRSimple [Name Nothing "t"]) False JInner (TRSimple [Name Nothing "u"]) (Just $ JoinUsing [Name Nothing "a", Name Nothing "b"])]) ,("select a from (select a from t)" ,ms [TRQueryExpr $ ms [TRSimple [Name Nothing "t"]]]) ,("select a from t as u" ,ms [TRAlias (TRSimple [Name Nothing "t"]) (Alias (Name Nothing "u") Nothing)]) ,("select a from t u" ,ms [TRAlias (TRSimple [Name Nothing "t"]) (Alias (Name Nothing "u") Nothing)]) ,("select a from t u(b)" ,ms [TRAlias (TRSimple [Name Nothing "t"]) (Alias (Name Nothing "u") $ Just [Name Nothing "b"])]) ,("select a from (t cross join u) as u" ,ms [TRAlias (TRParens $ TRJoin (TRSimple [Name Nothing "t"]) False JCross (TRSimple [Name Nothing "u"]) Nothing) (Alias (Name Nothing "u") Nothing)]) -- todo: not sure if the associativity is correct ,("select a from t cross join u cross join v", ms [TRJoin (TRJoin (TRSimple [Name Nothing "t"]) False JCross (TRSimple [Name Nothing "u"]) Nothing) False JCross (TRSimple [Name Nothing "v"]) Nothing]) ] where ms f = toQueryExpr $ makeSelect {msSelectList = [(Iden [Name Nothing "a"],Nothing)] ,msFrom = f}