module Test.Main ( main ) where import Prelude import Control.Monad.Aff (launchAff) import Control.Monad.Eff (Eff) import Control.Monad.Eff.Class (liftEff) import Control.Monad.Eff.Exception (EXCEPTION, error) import Control.Monad.Error.Class (throwError, try) import Data.Maybe (Maybe(..)) import Database.PostgreSQL (POSTGRESQL, Query(..), PoolConfiguration, execute, newPool, query, Row0(..), Row1(..), Row2(..), Row6(..), scalar, withConnection, withTransaction) import Test.Assert (ASSERT, assert) main :: ∀ eff. Eff (assert :: ASSERT, exception :: EXCEPTION, postgreSQL :: POSTGRESQL | eff) Unit main = void $ launchAff do pool <- newPool config withConnection pool \conn → do execute conn (Query """ CREATE TEMPORARY TABLE foods ( name text NOT NULL, delicious boolean NOT NULL, PRIMARY KEY (name) ) """) Row0 execute conn (Query """ INSERT INTO foods (name, delicious) VALUES ($1, $2), ($3, $4), ($5, $6) """) (Row6 "pork" true "sauerkraut" false "rookworst" true) names <- query conn (Query """ SELECT name FROM foods WHERE delicious ORDER BY name ASC """) Row0 liftEff <<< assert $ names == [Row1 "pork", Row1 "rookworst"] testTransactionCommit conn testTransactionRollback conn pure unit 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 config :: PoolConfiguration config = { user: "postgres" , password: "lol123" , host: "127.0.0.1" , port: 5432 , database: "purspg" , max: 10 , idleTimeoutMillis: 1000 }