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)
|
|
|
|
)
|
2017-06-03 11:10:15 +00:00
|
|
|
""") Row0
|
2017-05-06 15:09:05 +00:00
|
|
|
|
|
|
|
execute conn (Query """
|
|
|
|
INSERT INTO foods (name, delicious)
|
|
|
|
VALUES ($1, $2), ($3, $4), ($5, $6)
|
2017-06-03 11:10:15 +00:00
|
|
|
""") (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
|
2017-06-03 11:10:15 +00:00
|
|
|
""") 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
|
|
|
|
}
|