module SpecificDBTests where import Database.HDBC import Database.HDBC.PostgreSQL import Database.HDBC.PostgreSQL.Parser(convertSQL) import Test.HUnit testp inp exp = TestCase $ case convertSQL inp of Right x -> assertEqual "" exp x Left y -> assertFailure $ show y tests = TestList [TestLabel "empty" (testp "" ""), TestLabel "simple" (testp "SELECT a from b WHERE c = ?" "SELECT a from b WHERE c = $1"), TestLabel "multi" (testp "INSERT INTO foo VALUES (?,?)" "INSERT INTO foo VALUES ($1,$2)"), TestLabel "literal" (testp "INSERT INTO foo VALUES ('?', '''?')" "INSERT INTO foo VALUES ('?', '''?')"), TestLabel "torture" (testp "-- really?\n-- yes'?\nINSERT INTO ? VALUES ('', ?, \"?asd\", '?\\'?', '?''?', /* foo? */ /* foo /* bar */ ? */ ?)" "-- really?\n-- yes'?\nINSERT INTO $1 VALUES ('', $2, \"?asd\", '?\\'?', '?''?', /* foo? */ /* foo /* bar */ ? */ $3)") ]