1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
|
import Test.Framework (Test, defaultMain, testGroup)
import Test.Framework.Providers.QuickCheck2 (testProperty)
import qualified Data.ByteString.Char8 as B
import qualified Data.Double.Conversion.ByteString as B
import qualified Data.Double.Conversion.Text as T
import qualified Data.Text as T
import qualified Regressions
shortest :: (Double -> String) -> Double -> Double -> Bool
shortest f a b = case read (f ab) of
ba | isNaN ba -> isNaN ab
| isInfinite ba -> isInfinite ab && signum ba == signum ab
| otherwise -> ba == ab
where ab = a / b
tests :: Test
tests = testGroup "Properties" [
testProperty "b_shortest" $ shortest (B.unpack . B.toShortest)
, testProperty "t_shortest" $ shortest (T.unpack . T.toShortest)
]
main :: IO ()
main = defaultMain [tests, Regressions.tests]
|