summaryrefslogtreecommitdiff
path: root/test.hs
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2011-01-11 15:43:29 -0400
committerGravatar Joey Hess <joey@kitenet.net>2011-01-11 15:43:29 -0400
commit3a844b1f3c5eb85d4571857ac10aa8183996513a (patch)
tree8edf720ca74864a6615364b630c3765ae1f24323 /test.hs
parentc2b13a88bf2e8bdeb126e4f13a5aeb0fbe09a0c5 (diff)
test locationlog contents too
Diffstat (limited to 'test.hs')
-rw-r--r--test.hs30
1 files changed, 28 insertions, 2 deletions
diff --git a/test.hs b/test.hs
index 8c9298e67..20e8bc28a 100644
--- a/test.hs
+++ b/test.hs
@@ -18,11 +18,15 @@ import System.Posix.Env
import qualified Control.Exception.Extensible as E
import Control.Exception (throw)
+import qualified Annex
+import qualified BackendList
+import qualified Backend
import qualified GitRepo as Git
import qualified Locations
import qualified Utility
import qualified TypeInternals
import qualified GitAnnex
+import qualified LocationLog
main :: IO ()
main = do
@@ -359,6 +363,26 @@ checkdangling f = do
Left _ -> return () -- expected; dangling link
Right _ -> assertFailure $ f ++ " was not a dangling link as expected"
+checklocationlog :: FilePath -> Bool -> Assertion
+checklocationlog f expected = do
+ g <- Git.repoFromCwd
+ g' <- Git.configRead g
+ let thisuuid = Git.configGet g' "annex.uuid" ""
+ s <- Annex.new g BackendList.allBackends
+ r <- Annex.eval s $ Backend.lookupFile f
+ case r of
+ Just (k, _) -> do
+ uuids <- LocationLog.keyLocations g' k
+ assertEqual ("location log for " ++ f ++ " " ++ (show k) ++ " " ++ thisuuid)
+ expected (elem thisuuid uuids)
+ _ -> assertFailure $ f ++ " failed to look up key"
+
+inlocationlog :: FilePath -> Assertion
+inlocationlog f = checklocationlog f True
+
+notinlocationlog :: FilePath -> Assertion
+notinlocationlog f = checklocationlog f False
+
runchecks :: [FilePath -> Assertion] -> FilePath -> Assertion
runchecks [] _ = return ()
runchecks (a:as) f = do
@@ -366,10 +390,12 @@ runchecks (a:as) f = do
runchecks as f
annexed_notpresent :: FilePath -> Assertion
-annexed_notpresent = runchecks [checklink, checkdangling, checkunwritable]
+annexed_notpresent = runchecks
+ [checklink, checkdangling, checkunwritable, notinlocationlog]
annexed_present :: FilePath -> Assertion
-annexed_present = runchecks [checklink, checkcontent, checkunwritable]
+annexed_present = runchecks
+ [checklink, checkcontent, checkunwritable, inlocationlog]
unannexed :: FilePath -> Assertion
unannexed = runchecks [checkregularfile, checkcontent, checkwritable]