also run query tests in a readonly repo

Sponsored-by: Dartmouth College's Datalad project
This commit is contained in:
Joey Hess 2021-12-30 13:16:57 -04:00
parent ff4486b91c
commit cf61f955ad
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38
2 changed files with 45 additions and 14 deletions

28
Test.hs
View file

@ -76,7 +76,6 @@ import qualified BuildInfo
import qualified Utility.Format import qualified Utility.Format
import qualified Utility.Verifiable import qualified Utility.Verifiable
import qualified Utility.Process import qualified Utility.Process
import qualified Utility.Process.Transcript
import qualified Utility.Misc import qualified Utility.Misc
import qualified Utility.InodeCache import qualified Utility.InodeCache
import qualified Utility.Env import qualified Utility.Env
@ -312,7 +311,7 @@ unitTests :: String -> TestTree
unitTests note = testGroup ("Unit Tests " ++ note) unitTests note = testGroup ("Unit Tests " ++ note)
[ testCase "add dup" test_add_dup [ testCase "add dup" test_add_dup
, testCase "add extras" test_add_extras , testCase "add extras" test_add_extras
, testCase "readonly" test_readonly , testCase "readonly remote" test_readonly_remote
, testCase "ignore deleted files" test_ignore_deleted_files , testCase "ignore deleted files" test_ignore_deleted_files
, testCase "metadata" test_metadata , testCase "metadata" test_metadata
, testCase "export_import" test_export_import , testCase "export_import" test_export_import
@ -432,18 +431,15 @@ test_add_extras = intmpclonerepo $ do
annexed_present wormannexedfile annexed_present wormannexedfile
checkbackend wormannexedfile backendWORM checkbackend wormannexedfile backendWORM
test_readonly :: Assertion test_readonly_remote :: Assertion
test_readonly = test_readonly_remote =
#ifndef mingw32_HOST_OS #ifndef mingw32_HOST_OS
withtmpclonerepo $ \r1 -> withtmpclonerepo $ \r1 ->
withtmpclonerepo $ \r2 -> do withtmpclonerepo $ \r2 -> do
pair r1 r2 pair r1 r2
indir r1 $ do indir r1 $ do
git_annex "get" [annexedfile] "get failed in first repo" git_annex "get" [annexedfile] "get failed in first repo"
{- chmod may fail, or not be available, or the make_readonly r1
- filesystem not support permissions. -}
void $ Utility.Process.Transcript.processTranscript
"chmod" ["-R", "-w", r1] Nothing
indir r2 $ do indir r2 $ do
git_annex "sync" ["r1", "--no-push"] "sync with readonly repo" git_annex "sync" ["r1", "--no-push"] "sync with readonly repo"
git_annex "get" [annexedfile, "--from", "r1"] "get from readonly repo" git_annex "get" [annexedfile, "--from", "r1"] "get from readonly repo"
@ -469,6 +465,9 @@ test_metadata = intmpclonerepo $ do
git_annex "metadata" ["-s", "foo=bar", annexedfile] "set metadata" git_annex "metadata" ["-s", "foo=bar", annexedfile] "set metadata"
git_annex_expectoutput "find" ["--metadata", "foo=bar"] [annexedfile] git_annex_expectoutput "find" ["--metadata", "foo=bar"] [annexedfile]
git_annex_expectoutput "find" ["--metadata", "foo=other"] [] git_annex_expectoutput "find" ["--metadata", "foo=other"] []
readonly_query $ do
git_annex_expectoutput "find" ["--metadata", "foo=bar"] [annexedfile]
git_annex_expectoutput "find" ["--metadata", "foo=other"] []
writecontent annexedfiledup $ content annexedfiledup writecontent annexedfiledup $ content annexedfiledup
add_annex annexedfiledup "add of second file with same content failed" add_annex annexedfiledup "add of second file with same content failed"
annexed_present annexedfiledup annexed_present annexedfiledup
@ -1139,10 +1138,12 @@ test_find :: Assertion
test_find = intmpclonerepo $ do test_find = intmpclonerepo $ do
annexed_notpresent annexedfile annexed_notpresent annexedfile
git_annex_expectoutput "find" [] [] git_annex_expectoutput "find" [] []
readonly_query $ git_annex_expectoutput "find" [] []
git_annex "get" [annexedfile] "get" git_annex "get" [annexedfile] "get"
annexed_present annexedfile annexed_present annexedfile
annexed_notpresent sha1annexedfile annexed_notpresent sha1annexedfile
git_annex_expectoutput "find" [] [annexedfile] git_annex_expectoutput "find" [] [annexedfile]
readonly_query $ git_annex_expectoutput "find" [] [annexedfile]
git_annex_expectoutput "find" ["--exclude", annexedfile, "--and", "--exclude", sha1annexedfile] [] git_annex_expectoutput "find" ["--exclude", annexedfile, "--and", "--exclude", sha1annexedfile] []
git_annex_expectoutput "find" ["--include", annexedfile] [annexedfile] git_annex_expectoutput "find" ["--include", annexedfile] [annexedfile]
git_annex_expectoutput "find" ["--not", "--in", "origin"] [] git_annex_expectoutput "find" ["--not", "--in", "origin"] []
@ -1164,14 +1165,19 @@ test_merge = intmpclonerepo $
test_info :: Assertion test_info :: Assertion
test_info = intmpclonerepo $ do test_info = intmpclonerepo $ do
isjson
readonly_query isjson
where
isjson = do
json <- BU8.fromString <$> git_annex_output "info" ["--json"] json <- BU8.fromString <$> git_annex_output "info" ["--json"]
case Utility.Aeson.eitherDecode json :: Either String Utility.Aeson.Value of case Utility.Aeson.eitherDecode json :: Either String Utility.Aeson.Value of
Right _ -> return () Right _ -> return ()
Left e -> assertFailure e Left e -> assertFailure e
test_version :: Assertion test_version :: Assertion
test_version = intmpclonerepo $ test_version = intmpclonerepo $ do
git_annex "version" [] "version" git_annex "version" [] "version"
readonly_query $ git_annex "version" [] "readonly version"
test_sync :: Assertion test_sync :: Assertion
test_sync = intmpclonerepo $ do test_sync = intmpclonerepo $ do
@ -1697,11 +1703,15 @@ test_whereis :: Assertion
test_whereis = intmpclonerepo $ do test_whereis = intmpclonerepo $ do
annexed_notpresent annexedfile annexed_notpresent annexedfile
git_annex "whereis" [annexedfile] "whereis on non-present file" git_annex "whereis" [annexedfile] "whereis on non-present file"
readonly_query $
git_annex "whereis" [annexedfile] "readonly whereis on non-present file"
git_annex "untrust" ["origin"] "untrust" git_annex "untrust" ["origin"] "untrust"
git_annex_shouldfail "whereis" [annexedfile] "whereis should exit nonzero on non-present file only present in untrusted repo" git_annex_shouldfail "whereis" [annexedfile] "whereis should exit nonzero on non-present file only present in untrusted repo"
git_annex "get" [annexedfile] "get" git_annex "get" [annexedfile] "get"
annexed_present annexedfile annexed_present annexedfile
git_annex "whereis" [annexedfile] "whereis on present file" git_annex "whereis" [annexedfile] "whereis on present file"
readonly_query $
git_annex "whereis" [annexedfile] "readonly whereis on present file"
test_hook_remote :: Assertion test_hook_remote :: Assertion
test_hook_remote = intmpclonerepo $ do test_hook_remote = intmpclonerepo $ do

View file

@ -1,6 +1,6 @@
{- git-annex test suite framework {- git-annex test suite framework
- -
- Copyright 2010-2020 Joey Hess <id@joeyh.name> - Copyright 2010-2021 Joey Hess <id@joeyh.name>
- -
- Licensed under the GNU AGPL version 3 or higher. - Licensed under the GNU AGPL version 3 or higher.
-} -}
@ -640,3 +640,24 @@ pair r1 r2 = forM_ [r1, r2] $ \r -> indir r $ do
when (r /= r2) $ when (r /= r2) $
git "remote" ["add", "r2", "../../" ++ r2] "remote add" git "remote" ["add", "r2", "../../" ++ r2] "remote add"
{- Runs a query in the current repository, but first makes the repository
- read-only. The write bit is added back at the end, so when possible,
- include multiple tests within a single call for efficiency. -}
readonly_query :: Assertion -> Assertion
readonly_query = bracket_ (make_readonly ".") (make_writeable ".")
{- Not guaranteed to do anything:
- chmod may fail, or not be available, or the filesystem not support
- permissions. -}
make_readonly :: FilePath -> IO ()
make_readonly d = void $
Utility.Process.Transcript.processTranscript
"chmod" ["-R", "-w", d] Nothing
{- The write bit is added back for the current user, but not for other
- users, even though make_readonly removes any other user's write bits. -}
make_writeable :: FilePath -> IO ()
make_writeable d = void $
Utility.Process.Transcript.processTranscript
"chmod" ["-R", "u+w", d] Nothing