hasql/tasty/Main.hs

131 lines
4.2 KiB
Haskell
Raw Normal View History

2015-11-10 21:19:41 +03:00
module Main where
2015-11-15 12:13:45 +03:00
import Main.Prelude hiding (assert, isRight, isLeft)
2015-11-10 21:19:41 +03:00
import Test.QuickCheck.Instances
import Test.Tasty
2015-11-15 12:13:45 +03:00
import qualified Main.Queries as Queries
2015-11-10 21:19:41 +03:00
import qualified Test.Tasty.HUnit as HUnit
import qualified Test.Tasty.SmallCheck as SmallCheck
import qualified Test.Tasty.QuickCheck as QuickCheck
import qualified Test.QuickCheck as QuickCheck
2015-11-15 12:13:45 +03:00
import qualified Main.DSL as DSL
import qualified Hasql as H
import qualified Hasql.Serialization as HS
import qualified Hasql.Deserialization as HD
2015-11-10 21:19:41 +03:00
main =
defaultMain tree
tree =
2015-11-15 12:13:45 +03:00
testGroup "All tests"
2015-11-10 21:19:41 +03:00
[
2015-11-15 12:13:45 +03:00
HUnit.testCase "Enum" $
HUnit.assertEqual "" (Right "ok") $
let
actual =
unsafePerformIO $
DSL.session $ do
let
query =
(sql, mempty, HD.result HD.noResult, True)
where
sql =
"drop type if exists mood"
in DSL.query () query
let
query =
(sql, mempty, HD.result HD.noResult, True)
where
sql =
"create type mood as enum ('sad', 'ok', 'happy')"
in DSL.query () query
let
query =
(sql, serializer, deserializer, True)
where
sql =
"select ($1 :: mood)"
deserializer =
HD.result (HD.singleRow (HD.value (HD.enum (Just . id))))
serializer =
HS.value (HS.enum id)
in DSL.query "ok" query
in actual
,
HUnit.testCase "The same prepared statement used on different types" $
HUnit.assertEqual "" (Right ("ok", 1)) $
let
actual =
unsafePerformIO $
DSL.session $ do
let
effect1 =
DSL.query "ok" query
where
query =
(sql, serializer, deserializer, True)
where
sql =
"select $1"
serializer =
HS.value HS.text
deserializer =
HD.result (HD.singleRow (HD.value (HD.text)))
effect2 =
DSL.query 1 query
where
query =
(sql, serializer, deserializer, True)
where
sql =
"select $1"
serializer =
HS.value HS.int8
deserializer =
HD.result (HD.singleRow (HD.value HD.int8))
in (,) <$> effect1 <*> effect2
in actual
,
HUnit.testCase "Affected rows counting" $
HUnit.assertEqual "" (Right 100) $
let
actual =
unsafePerformIO $
DSL.session $ do
dropTable
createTable
replicateM_ 100 insertRow
deleteRows <* dropTable
where
dropTable =
DSL.query () $ Queries.plain $
"drop table if exists a"
createTable =
DSL.query () $ Queries.plain $
"create table a (id bigserial not null, name varchar not null, primary key (id))"
insertRow =
DSL.query () $ Queries.plain $
"insert into a (name) values ('a')"
deleteRows =
DSL.query () (sql, def, deserializer, False)
where
sql =
"delete from a"
deserializer =
HD.result HD.rowsAffected
in actual
,
HUnit.testCase "Result of an auto-incremented column" $
let
actualIO =
DSL.session $ do
DSL.query () $ Queries.plain $ "drop table if exists a"
DSL.query () $ Queries.plain $ "create table a (id serial not null, v char not null, primary key (id))"
id1 <- DSL.query () ("insert into a (v) values ('a') returning id", def, HD.result (HD.singleRow (HD.value HD.int4)), False)
id2 <- DSL.query () ("insert into a (v) values ('b') returning id", def, HD.result (HD.singleRow (HD.value HD.int4)), False)
DSL.query () $ Queries.plain $ "drop table if exists a"
pure (id1, id2)
in HUnit.assertEqual "" (Right (1, 2)) =<< actualIO
2015-11-10 21:19:41 +03:00
]
2015-11-15 12:13:45 +03:00