TESTS: add getFileTypeSpec

This commit is contained in:
Julian Ospald 2016-05-02 22:13:19 +02:00
parent ac41b053e3
commit 5670b160d8
No known key found for this signature in database
GPG Key ID: 511B62C09D50CD28
8 changed files with 65 additions and 3 deletions

View File

@ -184,7 +184,7 @@ data FileType = Directory
| CharacterDevice | CharacterDevice
| NamedPipe | NamedPipe
| Socket | Socket
deriving (Show) deriving (Eq, Show)
@ -614,6 +614,13 @@ getDirsFiles p =
--------------------------- ---------------------------
-- |Get the file type of the file located at the given path. Does
-- not follow symbolic links.
--
-- Throws:
--
-- - `NoSuchThing` if the file does not exist
-- - `PermissionDenied` if any part of the path is not accessible
getFileType :: Path Abs -> IO FileType getFileType :: Path Abs -> IO FileType
getFileType p = do getFileType p = do
fs <- PF.getSymbolicLinkStatus (P.fromAbs p) fs <- PF.getSymbolicLinkStatus (P.fromAbs p)

View File

@ -42,6 +42,7 @@ import System.Posix.Files.ByteString
-- TODO: chardev, blockdev, namedpipe, socket -- TODO: chardev, blockdev, namedpipe, socket
@ -54,9 +55,10 @@ main = hspec $ before_ fixPermissions $ after_ revertPermissions $ do
, renameFileSpec , renameFileSpec
, moveFileSpec , moveFileSpec
, recreateSymlinkSpec , recreateSymlinkSpec
, getFileTypeSpec
] ]
-- run all tests twice to catch missing cleanups or state skew -- run all stateful tests twice to catch missing cleanups or state skew
sequence_ tests sequence_ tests
sequence_ tests sequence_ tests
@ -77,6 +79,7 @@ main = hspec $ before_ fixPermissions $ after_ revertPermissions $ do
,"test/renameFile/noPerms" ,"test/renameFile/noPerms"
,"test/moveFile/noPerms" ,"test/moveFile/noPerms"
,"test/recreateSymlinkSpec/noPerms" ,"test/recreateSymlinkSpec/noPerms"
,"test/getFileTypeSpec/noPerms"
] ]
fixPermissions = do fixPermissions = do
sequence_ $ fmap noWritableDirPerms noWriteDirs sequence_ $ fmap noWritableDirPerms noWriteDirs
@ -489,6 +492,49 @@ recreateSymlinkSpec =
(\e -> ioeGetErrorType e == AlreadyExists) (\e -> ioeGetErrorType e == AlreadyExists)
getFileTypeSpec :: Spec
getFileTypeSpec =
describe "HSFM.FileSystem.FileOperations.getFileType" $ do
-- successes --
it "getFileType, regular file" $
getFileType' "test/getFileTypeSpec/regularfile"
`shouldReturn` RegularFile
it "getFileType, directory" $
getFileType' "test/getFileTypeSpec/directory"
`shouldReturn` Directory
it "getFileType, directory with null permissions" $
getFileType' "test/getFileTypeSpec/noPerms"
`shouldReturn` Directory
it "getFileType, symlink to file" $
getFileType' "test/getFileTypeSpec/symlink"
`shouldReturn` SymbolicLink
it "getFileType, symlink to directory" $
getFileType' "test/getFileTypeSpec/symlinkD"
`shouldReturn` SymbolicLink
it "getFileType, broken symlink" $
getFileType' "test/getFileTypeSpec/brokenSymlink"
`shouldReturn` SymbolicLink
-- posix failures --
it "getFileType, file does not exist" $
getFileType' "test/getFileTypeSpec/nothingHere"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "getFileType, can't open directory" $
getFileType' "test/getFileTypeSpec/noPerms/forz"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
----------------- -----------------
--[ Utilities ]-- --[ Utilities ]--
@ -597,3 +643,9 @@ normalDirPerms path = do
file <- (pwd P.</>) <$> P.parseRel path file <- (pwd P.</>) <$> P.parseRel path
setFileMode (P.fromAbs file) newDirPerms setFileMode (P.fromAbs file) newDirPerms
getFileType' :: ByteString -> IO FileType
getFileType' path = do
pwd <- fromJust <$> getEnv "PWD" >>= P.parseAbs
file <- (pwd P.</>) <$> P.parseRel path
getFileType file

View File

@ -0,0 +1 @@
broken

View File

View File

View File

View File

@ -0,0 +1 @@
regularfile

View File

@ -0,0 +1 @@
directory