This commit is contained in:
Joey Hess 2011-04-08 00:12:00 -04:00
parent dfc1bfcc76
commit a77c34d2b4
2 changed files with 20 additions and 18 deletions

View file

@ -72,26 +72,28 @@ testCmd k cmdline = do
{- Ensures that one of a set of commands is available by running each in {- Ensures that one of a set of commands is available by running each in
- turn. The Config is set to the first one found. -} - turn. The Config is set to the first one found. -}
selectCmd :: Bool -> ConfigKey -> [String] -> String -> Test selectCmd :: ConfigKey -> [String] -> String -> Test
selectCmd required k cmds param = search cmds selectCmd k = searchCmd
(\match -> return $ Config k $ StringConfig match)
(\cmds -> do
testEnd $ Config k $ BoolConfig False
error $ "* need one of these commands, but none are available: " ++ show cmds
)
maybeSelectCmd :: ConfigKey -> [String] -> String -> Test
maybeSelectCmd k = searchCmd
(\match -> return $ Config k $ MaybeStringConfig $ Just match)
(\_ -> return $ Config k $ MaybeStringConfig Nothing)
searchCmd :: (String -> Test) -> ([String] -> Test) -> [String] -> String -> Test
searchCmd success failure cmds param = search cmds
where where
search [] = failure search [] = failure cmds
search (c:cs) = do search (c:cs) = do
ret <- system $ quiet c ++ " " ++ param ret <- system $ quiet c ++ " " ++ param
if (ret == ExitSuccess) if (ret == ExitSuccess)
then success c then success c
else search cs else search cs
success c
| required == True = return $ Config k (StringConfig c)
| otherwise = return $ Config k (MaybeStringConfig $ Just c)
failure
| required == True = do
testEnd $ Config k (BoolConfig False)
error $ "* need one of these commands, but none are available: " ++ show cmds
| otherwise = do
let r = Config k (MaybeStringConfig Nothing)
testEnd r
return r
quiet :: String -> String quiet :: String -> String
quiet s = s ++ " >/dev/null 2>&1" quiet s = s ++ " >/dev/null 2>&1"

View file

@ -6,12 +6,12 @@ import Data.List
import TestConfig import TestConfig
tests :: [TestCase] tests :: [TestCase]
tests = [ tests =
TestCase "version" $ getVersion [ TestCase "version" $ getVersion
, testCp "cp_a" "-a" , testCp "cp_a" "-a"
, testCp "cp_p" "-p" , testCp "cp_p" "-p"
, testCp "cp_reflink_auto" "--reflink=auto" , testCp "cp_reflink_auto" "--reflink=auto"
, TestCase "uuid generator" $ selectCmd True "uuid" ["uuid", "uuidgen"] "" , TestCase "uuid generator" $ selectCmd "uuid" ["uuid", "uuidgen"] ""
, TestCase "xargs -0" $ requireCmd "xargs_0" "xargs -0 </dev/null" , TestCase "xargs -0" $ requireCmd "xargs_0" "xargs -0 </dev/null"
, TestCase "rsync" $ requireCmd "rsync" "rsync --version >/dev/null" , TestCase "rsync" $ requireCmd "rsync" "rsync --version >/dev/null"
, TestCase "curl" $ testCmd "curl" "curl --version >/dev/null" , TestCase "curl" $ testCmd "curl" "curl --version >/dev/null"
@ -24,7 +24,7 @@ shaTestCases l = map make l
let let
cmds = map (\x -> "sha" ++ show n ++ x) ["", "sum"] cmds = map (\x -> "sha" ++ show n ++ x) ["", "sum"]
key = "sha" ++ show n key = "sha" ++ show n
in TestCase key $ selectCmd False key cmds "</dev/null" in TestCase key $ maybeSelectCmd key cmds "</dev/null"
tmpDir :: String tmpDir :: String
tmpDir = "tmp" tmpDir = "tmp"