diff options
author | Joey Hess <joey@kitenet.net> | 2012-12-19 16:15:39 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2012-12-19 16:15:39 -0400 |
commit | 271bec8c70920322fee13a052df4a9279255e698 (patch) | |
tree | 0cd67d713c46945687a9995034d0aa9d3c262e27 | |
parent | 40fcead8d1378f5d821bdd08e99c3103e5a4b316 (diff) |
quickcheck test for transfer info read/write code
Fixed a bug the quickcheck turned up.
-rw-r--r-- | Logs/Transfer.hs | 14 | ||||
-rw-r--r-- | test.hs | 26 |
2 files changed, 37 insertions, 3 deletions
diff --git a/Logs/Transfer.hs b/Logs/Transfer.hs index 76412cf39..fa85846bb 100644 --- a/Logs/Transfer.hs +++ b/Logs/Transfer.hs @@ -294,7 +294,9 @@ readTransferInfo mpid s = TransferInfo <*> pure False where (firstline, rest) = separate (== '\n') s - (filename, _) = separate (== '\n') rest + filename + | end rest == "\n" = beginning rest + | otherwise = rest bits = split " " firstline numbits = length bits time = if numbits > 0 @@ -304,6 +306,16 @@ readTransferInfo mpid s = TransferInfo then Just <$> readish =<< headMaybe (drop 1 bits) else pure Nothing -- not failure +{- for quickcheck -} +prop_read_write_transferinfo :: TransferInfo -> Bool +prop_read_write_transferinfo info + | associatedFile info == Just "" = True -- file cannot be empty + | transferRemote info /= Nothing = True -- remote not stored + | transferTid info /= Nothing = True -- tid not stored + | otherwise = Just (info { transferPaused = False }) == info' + where + info' = readTransferInfo (transferPid info) (writeTransferInfo info) + parsePOSIXTime :: String -> Maybe POSIXTime parsePOSIXTime s = utcTimeToPOSIXSeconds <$> parseTime defaultTimeLocale "%s%Qs" s @@ -1,11 +1,12 @@ {- git-annex test suite - - - Copyright 2010,2011 Joey Hess <joey@kitenet.net> + - Copyright 2010-2012 Joey Hess <joey@kitenet.net> - - Licensed under the GNU GPL version 3 or higher. -} {-# OPTIONS_GHC -fno-warn-orphans #-} +{-# LANGUAGE TypeSynonymInstances #-} import Test.HUnit import Test.HUnit.Tools @@ -36,6 +37,7 @@ import qualified Logs.UUIDBased import qualified Logs.Trust import qualified Logs.Remote import qualified Logs.Unused +import qualified Logs.Transfer import qualified Remote import qualified Types.Key import qualified Types.Messages @@ -50,7 +52,10 @@ import qualified Utility.Verifiable import qualified Utility.Process import qualified Utility.Misc --- for quickcheck +import Data.Time.Clock.POSIX +import System.Posix.Types + +-- instances for quickcheck instance Arbitrary Types.Key.Key where arbitrary = do n <- arbitrary @@ -62,6 +67,22 @@ instance Arbitrary Types.Key.Key where Types.Key.keyMtime = Nothing } +instance Arbitrary Logs.Transfer.TransferInfo where + arbitrary = Logs.Transfer.TransferInfo + <$> arbitrary + <*> arbitrary + <*> pure Nothing -- cannot generate a ThreadID + <*> pure Nothing -- remote not needed + <*> arbitrary + <*> arbitrary + <*> arbitrary + +instance Arbitrary POSIXTime where + arbitrary = arbitrarySizedIntegral + +instance Arbitrary ProcessID where + arbitrary = arbitraryBoundedIntegral + main :: IO () main = do prepare @@ -93,6 +114,7 @@ quickcheck = TestLabel "quickcheck" $ TestList , qctest "prop_addLog_sane" Logs.UUIDBased.prop_addLog_sane , qctest "prop_verifiable_sane" Utility.Verifiable.prop_verifiable_sane , qctest "prop_segment_regressionTest" Utility.Misc.prop_segment_regressionTest + , qctest "prop_read_write_transferinfo" Logs.Transfer.prop_read_write_transferinfo ] blackbox :: Test |