hpath/unix/tests/user001.hs

28 lines
1.2 KiB
Haskell
Raw Permalink Normal View History

2020-04-14 09:27:28 +00:00
-- test that none of System.Posix.User.get* fail
import Control.Exception as Exception
import System.Posix.User
check :: Show a => a -> Bool
check a = show a == show a
p :: Show a => String -> IO a -> IO ()
p s m = (do putStr (s ++ ": ")
c <- fmap check m
putStrLn $ if c then "OK" else "I am the pope!")
`Exception.catch` (\e -> putStrLn ("ERROR: " ++ show (e::SomeException)))
main :: IO ()
main = do p "getRealUserID" $ getRealUserID
p "getRealGroupID" $ getRealGroupID
p "getEffectiveUserID" $ getEffectiveUserID
p "getEffectiveGroupID" $ getEffectiveGroupID
p "getGroups" $ getGroups
--p "getLoginName" $ getLoginName
p "getEffectiveUserName" $ getEffectiveUserName
p "getGroupEntryForID" $ getRealGroupID >>= getGroupEntryForID
p "getGroupEntryForName" $ getRealGroupID >>= getGroupEntryForID >>= getGroupEntryForName . groupName
p "getAllGroupEntries" $ getAllGroupEntries
p "getUserEntryForID" $ getRealUserID >>= getUserEntryForID
--p "getUserEntryForName" $ getLoginName >>= getUserEntryForName
p "getAllUserEntries" $ getAllUserEntries