purescript-postgresql-client/test/Main.purs

90 lines
2.3 KiB
Haskell
Raw Normal View History

2017-05-06 15:09:05 +00:00
module Test.Main
( main
) where
2017-12-04 21:43:36 +00:00
import Prelude
2017-05-06 15:09:05 +00:00
import Control.Monad.Aff (launchAff)
import Control.Monad.Eff (Eff)
import Control.Monad.Eff.Class (liftEff)
2017-06-03 11:48:00 +00:00
import Control.Monad.Eff.Exception (EXCEPTION, error)
import Control.Monad.Error.Class (throwError, try)
import Data.Maybe (Maybe(..))
2017-12-04 21:43:36 +00:00
import Database.PostgreSQL (POSTGRESQL, Query(..), PoolConfiguration, execute, newPool, query, Row0(..), Row1(..), Row2(..), Row6(..), scalar, withConnection, withTransaction)
2017-05-06 15:09:05 +00:00
import Test.Assert (ASSERT, assert)
main :: eff. Eff (assert :: ASSERT, exception :: EXCEPTION, postgreSQL :: POSTGRESQL | eff) Unit
main = void $ launchAff do
pool <- newPool config
2017-12-05 21:12:01 +00:00
withConnection pool \conn -> do
2017-05-06 15:09:05 +00:00
execute conn (Query """
2017-12-04 21:43:36 +00:00
CREATE TEMPORARY TABLE foods (
name text NOT NULL,
delicious boolean NOT NULL,
PRIMARY KEY (name)
)
""") Row0
2017-05-06 15:09:05 +00:00
execute conn (Query """
INSERT INTO foods (name, delicious)
VALUES ($1, $2), ($3, $4), ($5, $6)
""") (Row6 "pork" true "sauerkraut" false "rookworst" true)
2017-05-06 15:09:05 +00:00
2017-06-03 11:48:00 +00:00
names <- query conn (Query """
2017-05-06 15:09:05 +00:00
SELECT name
FROM foods
WHERE delicious
ORDER BY name ASC
""") Row0
2017-12-04 21:43:36 +00:00
2017-06-03 11:48:00 +00:00
liftEff <<< assert $ names == [Row1 "pork", Row1 "rookworst"]
testTransactionCommit conn
testTransactionRollback conn
2017-05-06 15:09:05 +00:00
pure unit
2017-06-03 11:48:00 +00:00
where
testTransactionCommit conn = do
deleteAll conn
withTransaction conn do
execute conn (Query """
INSERT INTO foods (name, delicious)
VALUES ($1, $2)
""") (Row2 "pork" true)
testCount conn 1
testCount conn 1
testTransactionRollback conn = do
deleteAll conn
_ <- try $ withTransaction conn do
execute conn (Query """
INSERT INTO foods (name, delicious)
VALUES ($1, $2)
""") (Row2 "pork" true)
testCount conn 1
throwError $ error "fail"
testCount conn 0
deleteAll conn =
execute conn (Query """
DELETE FROM foods
""") Row0
testCount conn n = do
count <- scalar conn (Query """
SELECT count(*) = $1
FROM foods
""") (Row1 n)
liftEff <<< assert $ count == Just true
2017-05-06 15:09:05 +00:00
config :: PoolConfiguration
config =
{ user: "postgres"
, password: "lol123"
, host: "127.0.0.1"
, port: 5432
, database: "purspg"
, max: 10
, idleTimeoutMillis: 1000
}