Stranezze con cabala, HTF, e asserzioni HUnit
Domanda
Così sto cercando di utilizzare HTF per eseguire alcune asserzioni HUnit stile
% cat tests/TestDemo.hs
{-# OPTIONS_GHC -Wall -F -pgmF htfpp #-}
module Main where
import Test.Framework
import Test.HUnit.Base ((@?=))
import System.Environment (getArgs)
-- just run some tests
main :: IO ()
main = getArgs >>= flip runTestWithArgs Main.allHTFTests
-- all these tests should fail
test_fail_int1 :: Assertion
test_fail_int1 = (0::Int) @?= (1::Int)
test_fail_bool1 :: Assertion
test_fail_bool1 = True @?= False
test_fail_string1 :: Assertion
test_fail_string1 = "0" @?= "1"
test_fail_int2 :: Assertion
test_fail_int2 = [0::Int] @?= [1::Int]
test_fail_string2 :: Assertion
test_fail_string2 = "true" @?= "false"
test_fail_bool2 :: Assertion
test_fail_bool2 = [True] @?= [False]
E quando lo uso ghc --make
, sembra funzionare correttamente.
% ghc --make tests/TestDemo.hs
[1 of 1] Compiling Main ( tests/TestDemo.hs, tests/TestDemo.o )
Linking tests/TestDemo ...
% tests/TestDemoA
...
* Tests: 6
* Passed: 0
* Failures: 6
* Errors: 0
Failures:
* Main:fail_int1 (tests/TestDemo.hs:9)
* Main:fail_bool1 (tests/TestDemo.hs:12)
* Main:fail_string1 (tests/TestDemo.hs:15)
* Main:fail_int2 (tests/TestDemo.hs:19)
* Main:fail_string2 (tests/TestDemo.hs:22)
* Main:fail_bool2 (tests/TestDemo.hs:25)
Ma quando io uso cabala costruirlo, non tutti i test che dovrebbero fallire, fallire.
% cat Demo.cabal
...
executable test-demo
build-depends: base >= 4, HUnit, HTF
main-is: TestDemo.hs
hs-source-dirs: tests
% cabal configure
Resolving dependencies...
Configuring Demo-0.0.0...
% cabal build
Preprocessing executables for Demo-0.0.0...
Building Demo-0.0.0...
[1 of 1] Compiling Main ( tests/TestDemo.hs, dist/build/test-demo/test-demo-tmp/Main.o )
Linking dist/build/test-demo/test-demo ...
% dist/build/test-demo/test-demo
...
* Tests: 6
* Passed: 3
* Failures: 3
* Errors: 0
Failures:
* Main:fail_int2 (tests/TestDemo.hs:23)
* Main:fail_string2 (tests/TestDemo.hs:26)
* Main:fail_bool2 (tests/TestDemo.hs:29)
Che cosa c'è che non va e come posso risolvere il problema?
Soluzione
Questo è un bug in alcune versioni di GHC, legati alla rimozione ottimizzatore generare eccezioni IO in alcuni casi. E 'molto comune con il codice di HUnit, se le ottimizzazioni sono abilitati. E set Cabal -O1
per impostazione predefinita, che consente il bug.
Aggiornamento a GHC 7 fissa (non molto raccomandato fino a quando le biblioteche hanno preso con esso, vale a dire una versione della piattaforma Haskell è fatto per GHC 7).
Si può anche mettere -O0
nelle opzioni del compilatore nel file strofa .cabal relative al vostro eseguibile di prova. Questo è quello che ho fatto per il mio codice di prova, fino a quando io sono pronto a spostare il mio progetto per GHC 7.