summaryrefslogtreecommitdiff
path: root/Command
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2014-08-01 17:16:20 -0400
committerGravatar Joey Hess <joey@kitenet.net>2014-08-01 17:16:20 -0400
commit70c55d3b42bb4650faf8626726bf17b65f16b57a (patch)
tree6cf7290da1c6f1f2996ae2f591c4ad0d35f02431 /Command
parent79eb6b4d04aa00350b60c6f1ae87c1826baa8e9a (diff)
testremote: Test retrieveKeyFile resume
And fixed a bug found by these tests; retrieveKeyFile would fail when the dest file was already complete. This commit was sponsored by Bradley Unterrheiner.
Diffstat (limited to 'Command')
-rw-r--r--Command/TestRemote.hs58
1 files changed, 42 insertions, 16 deletions
diff --git a/Command/TestRemote.hs b/Command/TestRemote.hs
index 6dde4b9f0..186d067d6 100644
--- a/Command/TestRemote.hs
+++ b/Command/TestRemote.hs
@@ -22,15 +22,19 @@ import qualified Backend.Hash
import Utility.Tmp
import Utility.Metered
import Utility.DataUnits
+import Utility.CopyFile
import Messages
import Types.Messages
import Remote.Helper.Chunked
+import Locations
import Test.Tasty
import Test.Tasty.Runners
import Test.Tasty.HUnit
+import Control.Exception
import "crypto-api" Crypto.Random
import qualified Data.ByteString as B
+import qualified Data.ByteString.Lazy as L
import qualified Data.Map as M
def :: [Command]
@@ -87,27 +91,40 @@ adjustChunkSize r chunksize = Remote.generate (Remote.remotetype r)
test :: Annex.AnnexState -> Remote -> Key -> [TestTree]
test st r k =
- [ check "removeKey when not present" $
- Remote.removeKey r k
+ [ check "removeKey when not present" remove
, present False
- , check "storeKey" $
- Remote.storeKey r k Nothing nullMeterUpdate
+ , check "storeKey" store
, present True
- , check "storeKey when already present" $
- Remote.storeKey r k Nothing nullMeterUpdate
+ , check "storeKey when already present" store
, present True
, check "retrieveKeyFile" $ do
removeAnnex k
- getViaTmp k $ \dest ->
- Remote.retrieveKeyFile r k Nothing dest nullMeterUpdate
- , check "fsck downloaded object" $ do
- case maybeLookupBackendName (keyBackendName k) of
- Nothing -> return True
- Just b -> case fsckKey b of
- Nothing -> return True
- Just fscker -> fscker k (key2file k)
- , check "removeKey when present" $
- Remote.removeKey r k
+ get
+ , check "fsck downloaded object" fsck
+ , check "retrieveKeyFile resume from 33%" $ do
+ loc <- Annex.calcRepo (gitAnnexLocation k)
+ tmp <- prepTmp k
+ partial <- liftIO $ bracket (openBinaryFile loc ReadMode) hClose $ \h -> do
+ sz <- hFileSize h
+ L.hGet h $ fromInteger $ sz `div` 3
+ liftIO $ L.writeFile tmp partial
+ removeAnnex k
+ get
+ , check "fsck downloaded object" fsck
+ , check "retrieveKeyFile resume from 0" $ do
+ tmp <- prepTmp k
+ liftIO $ writeFile tmp ""
+ removeAnnex k
+ get
+ , check "fsck downloaded object" fsck
+ , check "retrieveKeyFile resume from end" $ do
+ loc <- Annex.calcRepo (gitAnnexLocation k)
+ tmp <- prepTmp k
+ void $ liftIO $ copyFileExternal loc tmp
+ removeAnnex k
+ get
+ , check "fsck downloaded object" fsck
+ , check "removeKey when present" remove
, present False
]
where
@@ -115,6 +132,15 @@ test st r k =
Annex.eval st (Annex.setOutput QuietOutput >> a) @? "failed"
present b = check ("present " ++ show b) $
(== Right b) <$> Remote.hasKey r k
+ fsck = case maybeLookupBackendName (keyBackendName k) of
+ Nothing -> return True
+ Just b -> case fsckKey b of
+ Nothing -> return True
+ Just fscker -> fscker k (key2file k)
+ get = getViaTmp k $ \dest ->
+ Remote.retrieveKeyFile r k Nothing dest nullMeterUpdate
+ store = Remote.storeKey r k Nothing nullMeterUpdate
+ remove = Remote.removeKey r k
cleanup :: [Remote] -> [Key] -> Bool -> CommandCleanup
cleanup rs ks ok = do