TESTS: restructure files

This commit is contained in:
Julian Ospald 2016-05-03 13:27:10 +02:00
parent e56c345156
commit 1487351f29
No known key found for this signature in database
GPG Key ID: 511B62C09D50CD28
96 changed files with 697 additions and 697 deletions

View File

@ -119,18 +119,18 @@ Test-Suite spec
Hs-Source-Dirs: test Hs-Source-Dirs: test
Main-Is: Spec.hs Main-Is: Spec.hs
other-modules: other-modules:
CopyDirRecursiveSpec FileSystem.FileOperations.CopyDirRecursiveSpec
CopyFileSpec FileSystem.FileOperations.CopyFileSpec
CreateDirSpec FileSystem.FileOperations.CreateDirSpec
CreateRegularFileSpec FileSystem.FileOperations.CreateRegularFileSpec
DeleteDirRecursiveSpec FileSystem.FileOperations.DeleteDirRecursiveSpec
DeleteDirSpec FileSystem.FileOperations.DeleteDirSpec
DeleteFileSpec FileSystem.FileOperations.DeleteFileSpec
GetDirsFilesSpec FileSystem.FileOperations.GetDirsFilesSpec
GetFileTypeSpec FileSystem.FileOperations.GetFileTypeSpec
MoveFileSpec FileSystem.FileOperations.MoveFileSpec
RecreateSymlinkSpec FileSystem.FileOperations.RecreateSymlinkSpec
RenameFileSpec FileSystem.FileOperations.RenameFileSpec
Utils Utils
GHC-Options: -Wall GHC-Options: -Wall
Build-Depends: base Build-Depends: base

View File

@ -1,102 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module CopyDirRecursiveSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import System.Exit
import System.Process
import Utils
copyDirRecursiveSpec :: Spec
copyDirRecursiveSpec =
describe "HSFM.FileSystem.FileOperations.copyDirRecursive" $ do
-- successes --
it "copyDirRecursive, all fine" $ do
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/outputDir"
removeDirIfExists "test/copyDirRecursiveSpec/outputDir"
it "copyDirRecursive, all fine and compare" $ do
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/outputDir"
(system $ "diff -r --no-dereference "
++ "test/copyDirRecursiveSpec/inputDir" ++ " "
++ "test/copyDirRecursiveSpec/outputDir")
`shouldReturn` ExitSuccess
removeDirIfExists "test/copyDirRecursiveSpec/outputDir"
-- posix failures --
it "copyDirRecursive, source directory does not exist" $
copyDirRecursive' "test/copyDirRecursiveSpec/doesNotExist"
"test/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "copyDirRecursive, no write permission on output dir" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/noWritePerm/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, cannot open output dir" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, cannot open source dir" $
copyDirRecursive' "test/copyDirRecursiveSpec/noPerms/inputDir"
"test/copyDirRecursiveSpec/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, destination dir already exists" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, destination already exists and is a file" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, destination and source same directory" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/inputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, wrong input (regular file)" $
copyDirRecursive' "test/copyDirRecursiveSpec/wrongInput"
"test/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "copyDirRecursive, wrong input (symlink to directory)" $
copyDirRecursive' "test/copyDirRecursiveSpec/wrongInputSymL"
"test/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
-- custom failures
it "copyDirRecursive, destination in source" $
copyDirRecursive' "test/copyDirRecursiveSpec/inputDir"
"test/copyDirRecursiveSpec/inputDir/foo"
`shouldThrow`
isDestinationInSource

View File

@ -1,93 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module CopyFileSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import System.Exit
import System.Process
import Utils
copyFileSpec :: Spec
copyFileSpec =
describe "HSFM.FileSystem.FileOperations.copyFile" $ do
-- successes --
it "copyFile, everything clear" $ do
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/outputFile"
removeFileIfExists "test/copyFileSpec/outputFile"
it "copyFile, and compare" $ do
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/outputFile"
(system $ "cmp -s " ++ "test/copyFileSpec/inputFile" ++ " "
++ "test/copyFileSpec/outputFile")
`shouldReturn` ExitSuccess
removeFileIfExists "test/copyFileSpec/outputFile"
-- posix failures --
it "copyFile, input file does not exist" $
copyFile' "test/copyFileSpec/noSuchFile"
"test/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "copyFile, no permission to write to output directory" $
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/outputDirNoWrite/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, cannot open output directory" $
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/noPerms/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, cannot open source directory" $
copyFile' "test/copyFileSpec/noPerms/inputFile"
"test/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, wrong input type (symlink)" $
copyFile' "test/copyFileSpec/inputFileSymL"
"test/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "copyFile, wrong input type (directory)" $
copyFile' "test/copyFileSpec/wrongInput"
"test/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "copyFile, output and input are same file" $
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/inputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyFile, output file already exists" $
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyFile, output file already exists and is a dir" $
copyFile' "test/copyFileSpec/inputFile"
"test/copyFileSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -1,85 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module DeleteDirRecursiveSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import System.Posix.Files.ByteString
(
getSymbolicLinkStatus
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
deleteDirRecursiveSpec :: Spec
deleteDirRecursiveSpec =
describe "HSFM.FileSystem.FileOperations.deleteDirRecursive" $ do
-- successes --
it "deleteDirRecursive, empty directory, all fine" $ do
createDir' "test/deleteDirRecursiveSpec/testDir"
deleteDirRecursive' "test/deleteDirRecursiveSpec/testDir"
getSymbolicLinkStatus "test/deleteDirRecursiveSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDirRecursive, empty directory with null permissions, all fine" $ do
createDir' "test/deleteDirRecursiveSpec/noPerms/testDir"
noPerms "test/deleteDirRecursiveSpec/noPerms/testDir"
deleteDirRecursive' "test/deleteDirRecursiveSpec/noPerms/testDir"
it "deleteDirRecursive, non-empty directory, all fine" $ do
createDir' "test/deleteDirRecursiveSpec/nonEmpty"
createDir' "test/deleteDirRecursiveSpec/nonEmpty/dir1"
createDir' "test/deleteDirRecursiveSpec/nonEmpty/dir2"
createDir' "test/deleteDirRecursiveSpec/nonEmpty/dir2/dir3"
createRegularFile' "test/deleteDirRecursiveSpec/nonEmpty/file1"
createRegularFile' "test/deleteDirRecursiveSpec/nonEmpty/dir1/file2"
deleteDirRecursive' "test/deleteDirRecursiveSpec/nonEmpty"
getSymbolicLinkStatus "test/deleteDirRecursiveSpec/nonEmpty"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
-- posix failures --
it "deleteDirRecursive, can't open parent directory" $ do
createDir' "test/deleteDirRecursiveSpec/noPerms/foo"
noPerms "test/deleteDirRecursiveSpec/noPerms"
(deleteDirRecursive' "test/deleteDirRecursiveSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
>> normalDirPerms "test/deleteDirRecursiveSpec/noPerms"
>> deleteDir' "test/deleteDirRecursiveSpec/noPerms/foo"
it "deleteDirRecursive, can't write to parent directory" $ do
createDir' "test/deleteDirRecursiveSpec/noWritable/foo"
noWritableDirPerms "test/deleteDirRecursiveSpec/noWritable"
(deleteDirRecursive' "test/deleteDirRecursiveSpec/noWritable/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
normalDirPerms "test/deleteDirRecursiveSpec/noWritable"
deleteDir' "test/deleteDirRecursiveSpec/noWritable/foo"
it "deleteDirRecursive, wrong file type (symlink to directory)" $
deleteDirRecursive' "test/deleteDirRecursiveSpec/dirSym"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDirRecursive, wrong file type (regular file)" $
deleteDirRecursive' "test/deleteDirRecursiveSpec/file"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDirRecursive, directory does not exist" $
deleteDirRecursive' "test/deleteDirRecursiveSpec/doesNotExist"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)

View File

@ -1,82 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module DeleteDirSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import System.Posix.Files.ByteString
(
getSymbolicLinkStatus
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
deleteDirSpec :: Spec
deleteDirSpec =
describe "HSFM.FileSystem.FileOperations.deleteDir" $ do
-- successes --
it "deleteDir, empty directory, all fine" $ do
createDir' "test/deleteDirSpec/testDir"
deleteDir' "test/deleteDirSpec/testDir"
getSymbolicLinkStatus "test/deleteDirSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDir, directory with null permissions, all fine" $ do
createDir' "test/deleteDirSpec/noPerms/testDir"
noPerms "test/deleteDirSpec/noPerms/testDir"
deleteDir' "test/deleteDirSpec/noPerms/testDir"
getSymbolicLinkStatus "test/deleteDirSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
-- posix failures --
it "deleteDir, wrong file type (symlink to directory)" $
deleteDir' "test/deleteDirSpec/dirSym"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDir, wrong file type (regular file)" $
deleteDir' "test/deleteDirSpec/file"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDir, directory does not exist" $
deleteDir' "test/deleteDirSpec/doesNotExist"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDir, directory not empty" $
deleteDir' "test/deleteDirSpec/dir"
`shouldThrow`
(\e -> ioeGetErrorType e == UnsatisfiedConstraints)
it "deleteDir, can't open parent directory" $ do
createDir' "test/deleteDirSpec/noPerms/foo"
noPerms "test/deleteDirSpec/noPerms"
(deleteDir' "test/deleteDirSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
>> normalDirPerms "test/deleteDirSpec/noPerms"
>> deleteDir' "test/deleteDirSpec/noPerms/foo"
it "deleteDir, can't write to parent directory, still fine" $ do
createDir' "test/deleteDirSpec/noWritable/foo"
noWritableDirPerms "test/deleteDirSpec/noWritable"
(deleteDir' "test/deleteDirSpec/noWritable/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
normalDirPerms "test/deleteDirSpec/noWritable"
deleteDir' "test/deleteDirSpec/noWritable/foo"

View File

@ -0,0 +1,102 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.CopyDirRecursiveSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import System.Exit
import System.Process
import Utils
copyDirRecursiveSpec :: Spec
copyDirRecursiveSpec =
describe "HSFM.FileSystem.FileOperations.copyDirRecursive" $ do
-- successes --
it "copyDirRecursive, all fine" $ do
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
removeDirIfExists "test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
it "copyDirRecursive, all fine and compare" $ do
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
(system $ "diff -r --no-dereference "
++ "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir" ++ " "
++ "test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir")
`shouldReturn` ExitSuccess
removeDirIfExists "test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
-- posix failures --
it "copyDirRecursive, source directory does not exist" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/doesNotExist"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "copyDirRecursive, no write permission on output dir" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/noWritePerm/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, cannot open output dir" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, cannot open source dir" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/noPerms/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyDirRecursive, destination dir already exists" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, destination already exists and is a file" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, destination and source same directory" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyDirRecursive, wrong input (regular file)" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/wrongInput"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "copyDirRecursive, wrong input (symlink to directory)" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/wrongInputSymL"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/outputDir"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
-- custom failures
it "copyDirRecursive, destination in source" $
copyDirRecursive' "test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir"
"test/FileSystem/FileOperations/copyDirRecursiveSpec/inputDir/foo"
`shouldThrow`
isDestinationInSource

View File

@ -0,0 +1,93 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.CopyFileSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import System.Exit
import System.Process
import Utils
copyFileSpec :: Spec
copyFileSpec =
describe "HSFM.FileSystem.FileOperations.copyFile" $ do
-- successes --
it "copyFile, everything clear" $ do
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
removeFileIfExists "test/FileSystem/FileOperations/copyFileSpec/outputFile"
it "copyFile, and compare" $ do
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
(system $ "cmp -s " ++ "test/FileSystem/FileOperations/copyFileSpec/inputFile" ++ " "
++ "test/FileSystem/FileOperations/copyFileSpec/outputFile")
`shouldReturn` ExitSuccess
removeFileIfExists "test/FileSystem/FileOperations/copyFileSpec/outputFile"
-- posix failures --
it "copyFile, input file does not exist" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/noSuchFile"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "copyFile, no permission to write to output directory" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/outputDirNoWrite/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, cannot open output directory" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/noPerms/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, cannot open source directory" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/noPerms/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "copyFile, wrong input type (symlink)" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFileSymL"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "copyFile, wrong input type (directory)" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/wrongInput"
"test/FileSystem/FileOperations/copyFileSpec/outputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "copyFile, output and input are same file" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/inputFile"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyFile, output file already exists" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "copyFile, output file already exists and is a dir" $
copyFile' "test/FileSystem/FileOperations/copyFileSpec/inputFile"
"test/FileSystem/FileOperations/copyFileSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -1,6 +1,6 @@
{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE OverloadedStrings #-}
module CreateDirSpec where module FileSystem.FileOperations.CreateDirSpec where
import Test.Hspec import Test.Hspec
@ -21,22 +21,22 @@ createDirSpec =
-- successes -- -- successes --
it "createDir, all fine" $ do it "createDir, all fine" $ do
createDir' "test/createDirSpec/newDir" createDir' "test/FileSystem/FileOperations/createDirSpec/newDir"
removeDirIfExists "test/createDirSpec/newDir" removeDirIfExists "test/FileSystem/FileOperations/createDirSpec/newDir"
-- posix failures -- -- posix failures --
it "createDir, can't write to output directory" $ it "createDir, can't write to output directory" $
createDir' "test/createDirSpec/noWritePerms/newDir" createDir' "test/FileSystem/FileOperations/createDirSpec/noWritePerms/newDir"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)
it "createDir, can't open output directory" $ it "createDir, can't open output directory" $
createDir' "test/createDirSpec/noPerms/newDir" createDir' "test/FileSystem/FileOperations/createDirSpec/noPerms/newDir"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)
it "createDir, destination directory already exists" $ it "createDir, destination directory already exists" $
createDir' "test/createDirSpec/alreadyExists" createDir' "test/FileSystem/FileOperations/createDirSpec/alreadyExists"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists) (\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -1,6 +1,6 @@
{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE OverloadedStrings #-}
module CreateRegularFileSpec where module FileSystem.FileOperations.CreateRegularFileSpec where
import Test.Hspec import Test.Hspec
@ -21,22 +21,22 @@ createRegularFileSpec =
-- successes -- -- successes --
it "createRegularFile, all fine" $ do it "createRegularFile, all fine" $ do
createRegularFile' "test/createRegularFileSpec/newDir" createRegularFile' "test/FileSystem/FileOperations/createRegularFileSpec/newDir"
removeFileIfExists "test/createRegularFileSpec/newDir" removeFileIfExists "test/FileSystem/FileOperations/createRegularFileSpec/newDir"
-- posix failures -- -- posix failures --
it "createRegularFile, can't write to destination directory" $ it "createRegularFile, can't write to destination directory" $
createRegularFile' "test/createRegularFileSpec/noWritePerms/newDir" createRegularFile' "test/FileSystem/FileOperations/createRegularFileSpec/noWritePerms/newDir"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)
it "createRegularFile, can't write to destination directory" $ it "createRegularFile, can't write to destination directory" $
createRegularFile' "test/createRegularFileSpec/noPerms/newDir" createRegularFile' "test/FileSystem/FileOperations/createRegularFileSpec/noPerms/newDir"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)
it "createRegularFile, destination file already exists" $ it "createRegularFile, destination file already exists" $
createRegularFile' "test/createRegularFileSpec/alreadyExists" createRegularFile' "test/FileSystem/FileOperations/createRegularFileSpec/alreadyExists"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists) (\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -0,0 +1,86 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.DeleteDirRecursiveSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import System.Posix.Files.ByteString
(
getSymbolicLinkStatus
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
deleteDirRecursiveSpec :: Spec
deleteDirRecursiveSpec =
describe "HSFM.FileSystem.FileOperations.deleteDirRecursive" $ do
-- successes --
it "deleteDirRecursive, empty directory, all fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/testDir"
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/testDir"
getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteDirRecursiveSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDirRecursive, empty directory with null permissions, all fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/testDir"
noPerms "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/testDir"
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/testDir"
it "deleteDirRecursive, non-empty directory, all fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty"
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty/dir1"
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty/dir2"
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty/dir2/dir3"
createRegularFile' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty/file1"
createRegularFile' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty/dir1/file2"
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty"
getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteDirRecursiveSpec/nonEmpty"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
-- posix failures --
it "deleteDirRecursive, can't open parent directory" $ do
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/foo"
noPerms "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms"
(deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
>> normalDirPerms "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms"
>> deleteDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noPerms/foo"
it "deleteDirRecursive, can't write to parent directory" $ do
createDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noWritable/foo"
noWritableDirPerms "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noWritable"
(deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noWritable/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
normalDirPerms "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noWritable"
deleteDir' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/noWritable/foo"
it "deleteDirRecursive, wrong file type (symlink to directory)" $
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/dirSym"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDirRecursive, wrong file type (regular file)" $
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/file"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDirRecursive, directory does not exist" $
deleteDirRecursive' "test/FileSystem/FileOperations/deleteDirRecursiveSpec/doesNotExist"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)

View File

@ -0,0 +1,82 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.DeleteDirSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import System.Posix.Files.ByteString
(
getSymbolicLinkStatus
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
deleteDirSpec :: Spec
deleteDirSpec =
describe "HSFM.FileSystem.FileOperations.deleteDir" $ do
-- successes --
it "deleteDir, empty directory, all fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirSpec/testDir"
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/testDir"
getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteDirSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDir, directory with null permissions, all fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirSpec/noPerms/testDir"
noPerms "test/FileSystem/FileOperations/deleteDirSpec/noPerms/testDir"
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/noPerms/testDir"
getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteDirSpec/testDir"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
-- posix failures --
it "deleteDir, wrong file type (symlink to directory)" $
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/dirSym"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDir, wrong file type (regular file)" $
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/file"
`shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType)
it "deleteDir, directory does not exist" $
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/doesNotExist"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "deleteDir, directory not empty" $
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/dir"
`shouldThrow`
(\e -> ioeGetErrorType e == UnsatisfiedConstraints)
it "deleteDir, can't open parent directory" $ do
createDir' "test/FileSystem/FileOperations/deleteDirSpec/noPerms/foo"
noPerms "test/FileSystem/FileOperations/deleteDirSpec/noPerms"
(deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/noPerms/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
>> normalDirPerms "test/FileSystem/FileOperations/deleteDirSpec/noPerms"
>> deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/noPerms/foo"
it "deleteDir, can't write to parent directory, still fine" $ do
createDir' "test/FileSystem/FileOperations/deleteDirSpec/noWritable/foo"
noWritableDirPerms "test/FileSystem/FileOperations/deleteDirSpec/noWritable"
(deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/noWritable/foo"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied))
normalDirPerms "test/FileSystem/FileOperations/deleteDirSpec/noWritable"
deleteDir' "test/FileSystem/FileOperations/deleteDirSpec/noWritable/foo"

View File

@ -1,6 +1,6 @@
{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE OverloadedStrings #-}
module DeleteFileSpec where module FileSystem.FileOperations.DeleteFileSpec where
import Test.Hspec import Test.Hspec
@ -25,33 +25,33 @@ deleteFileSpec =
-- successes -- -- successes --
it "deleteFile, regular file, all fine" $ do it "deleteFile, regular file, all fine" $ do
createRegularFile' "test/deleteFileSpec/testFile" createRegularFile' "test/FileSystem/FileOperations/deleteFileSpec/testFile"
deleteFile' "test/deleteFileSpec/testFile" deleteFile' "test/FileSystem/FileOperations/deleteFileSpec/testFile"
getSymbolicLinkStatus "test/deleteFileSpec/testFile" getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteFileSpec/testFile"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing) (\e -> ioeGetErrorType e == NoSuchThing)
it "deleteFile, symlink, all fine" $ do it "deleteFile, symlink, all fine" $ do
recreateSymlink' "test/deleteFileSpec/syml" recreateSymlink' "test/FileSystem/FileOperations/deleteFileSpec/syml"
"test/deleteFileSpec/testFile" "test/FileSystem/FileOperations/deleteFileSpec/testFile"
deleteFile' "test/deleteFileSpec/testFile" deleteFile' "test/FileSystem/FileOperations/deleteFileSpec/testFile"
getSymbolicLinkStatus "test/deleteFileSpec/testFile" getSymbolicLinkStatus "test/FileSystem/FileOperations/deleteFileSpec/testFile"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing) (\e -> ioeGetErrorType e == NoSuchThing)
-- posix failures -- -- posix failures --
it "deleteFile, wrong file type (directory)" $ it "deleteFile, wrong file type (directory)" $
deleteFile' "test/deleteFileSpec/dir" deleteFile' "test/FileSystem/FileOperations/deleteFileSpec/dir"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType) (\e -> ioeGetErrorType e == InappropriateType)
it "deleteFile, file does not exist" $ it "deleteFile, file does not exist" $
deleteFile' "test/deleteFileSpec/doesNotExist" deleteFile' "test/FileSystem/FileOperations/deleteFileSpec/doesNotExist"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing) (\e -> ioeGetErrorType e == NoSuchThing)
it "deleteFile, can't read directory" $ it "deleteFile, can't read directory" $
deleteFile' "test/deleteFileSpec/noPerms/blah" deleteFile' "test/FileSystem/FileOperations/deleteFileSpec/noPerms/blah"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)

View File

@ -1,6 +1,6 @@
{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE OverloadedStrings #-}
module GetDirsFilesSpec where module FileSystem.FileOperations.GetDirsFilesSpec where
import Data.List import Data.List
@ -36,39 +36,39 @@ getDirsFilesSpec =
-- successes -- -- successes --
it "getDirsFiles, all fine" $ do it "getDirsFiles, all fine" $ do
pwd <- fromJust <$> getEnv "PWD" >>= P.parseAbs pwd <- fromJust <$> getEnv "PWD" >>= P.parseAbs
expectedFiles <- mapM P.parseRel ["test/getDirsFilesSpec/.hidden" expectedFiles <- mapM P.parseRel ["test/FileSystem/FileOperations/getDirsFilesSpec/.hidden"
,"test/getDirsFilesSpec/Lala" ,"test/FileSystem/FileOperations/getDirsFilesSpec/Lala"
,"test/getDirsFilesSpec/dir" ,"test/FileSystem/FileOperations/getDirsFilesSpec/dir"
,"test/getDirsFilesSpec/dirsym" ,"test/FileSystem/FileOperations/getDirsFilesSpec/dirsym"
,"test/getDirsFilesSpec/file" ,"test/FileSystem/FileOperations/getDirsFilesSpec/file"
,"test/getDirsFilesSpec/noPerms" ,"test/FileSystem/FileOperations/getDirsFilesSpec/noPerms"
,"test/getDirsFilesSpec/syml"] ,"test/FileSystem/FileOperations/getDirsFilesSpec/syml"]
(fmap sort $ getDirsFiles' "test/getDirsFilesSpec") (fmap sort $ getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec")
`shouldReturn` fmap (pwd P.</>) expectedFiles `shouldReturn` fmap (pwd P.</>) expectedFiles
-- posix failures -- -- posix failures --
it "getDirsFiles, nonexistent directory" $ it "getDirsFiles, nonexistent directory" $
getDirsFiles' "test/getDirsFilesSpec/nothingHere" getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec/nothingHere"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing) (\e -> ioeGetErrorType e == NoSuchThing)
it "getDirsFiles, wrong file type (file)" $ it "getDirsFiles, wrong file type (file)" $
getDirsFiles' "test/getDirsFilesSpec/file" getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec/file"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == InappropriateType) (\e -> ioeGetErrorType e == InappropriateType)
it "getDirsFiles, wrong file type (symlink to file)" $ it "getDirsFiles, wrong file type (symlink to file)" $
getDirsFiles' "test/getDirsFilesSpec/syml" getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec/syml"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument) (\e -> ioeGetErrorType e == InvalidArgument)
it "getDirsFiles, wrong file type (symlink to dir)" $ it "getDirsFiles, wrong file type (symlink to dir)" $
getDirsFiles' "test/getDirsFilesSpec/dirsym" getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec/dirsym"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument) (\e -> ioeGetErrorType e == InvalidArgument)
it "getDirsFiles, can't open directory" $ it "getDirsFiles, can't open directory" $
getDirsFiles' "test/getDirsFilesSpec/noPerms" getDirsFiles' "test/FileSystem/FileOperations/getDirsFilesSpec/noPerms"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)

View File

@ -1,6 +1,6 @@
{-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE OverloadedStrings #-}
module GetFileTypeSpec where module FileSystem.FileOperations.GetFileTypeSpec where
import HSFM.FileSystem.FileOperations import HSFM.FileSystem.FileOperations
@ -23,37 +23,37 @@ getFileTypeSpec =
-- successes -- -- successes --
it "getFileType, regular file" $ it "getFileType, regular file" $
getFileType' "test/getFileTypeSpec/regularfile" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/regularfile"
`shouldReturn` RegularFile `shouldReturn` RegularFile
it "getFileType, directory" $ it "getFileType, directory" $
getFileType' "test/getFileTypeSpec/directory" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/directory"
`shouldReturn` Directory `shouldReturn` Directory
it "getFileType, directory with null permissions" $ it "getFileType, directory with null permissions" $
getFileType' "test/getFileTypeSpec/noPerms" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/noPerms"
`shouldReturn` Directory `shouldReturn` Directory
it "getFileType, symlink to file" $ it "getFileType, symlink to file" $
getFileType' "test/getFileTypeSpec/symlink" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/symlink"
`shouldReturn` SymbolicLink `shouldReturn` SymbolicLink
it "getFileType, symlink to directory" $ it "getFileType, symlink to directory" $
getFileType' "test/getFileTypeSpec/symlinkD" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/symlinkD"
`shouldReturn` SymbolicLink `shouldReturn` SymbolicLink
it "getFileType, broken symlink" $ it "getFileType, broken symlink" $
getFileType' "test/getFileTypeSpec/brokenSymlink" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/brokenSymlink"
`shouldReturn` SymbolicLink `shouldReturn` SymbolicLink
-- posix failures -- -- posix failures --
it "getFileType, file does not exist" $ it "getFileType, file does not exist" $
getFileType' "test/getFileTypeSpec/nothingHere" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/nothingHere"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing) (\e -> ioeGetErrorType e == NoSuchThing)
it "getFileType, can't open directory" $ it "getFileType, can't open directory" $
getFileType' "test/getFileTypeSpec/noPerms/forz" getFileType' "test/FileSystem/FileOperations/getFileTypeSpec/noPerms/forz"
`shouldThrow` `shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied) (\e -> ioeGetErrorType e == PermissionDenied)

View File

@ -0,0 +1,83 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.MoveFileSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
moveFileSpec :: Spec
moveFileSpec =
describe "HSFM.FileSystem.FileOperations.moveFile" $ do
-- successes --
it "moveFile, all fine" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/movedFile"
it "moveFile, all fine" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/dir/movedFile"
it "moveFile, all fine on symlink" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFileL"
"test/FileSystem/FileOperations/moveFileSpec/movedFile"
it "moveFile, all fine on directory" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/dir"
"test/FileSystem/FileOperations/moveFileSpec/movedFile"
-- posix failures --
it "moveFile, source file does not exist" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/fileDoesNotExist"
"test/FileSystem/FileOperations/moveFileSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "moveFile, can't write to destination directory" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/noWritePerm/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "moveFile, can't open destination directory" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/noPerms/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "moveFile, can't open source directory" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/noPerms/myFile"
"test/FileSystem/FileOperations/moveFileSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
-- custom failures --
it "moveFile, destination file already exists" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/alreadyExists"
`shouldThrow`
isFileDoesExist
it "moveFile, move from file to dir" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/alreadyExistsD"
`shouldThrow`
isDirDoesExist
it "moveFile, source and dest are same file" $
moveFile' "test/FileSystem/FileOperations/moveFileSpec/myFile"
"test/FileSystem/FileOperations/moveFileSpec/myFile"
`shouldThrow`
isSameFile

View File

@ -0,0 +1,81 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.RecreateSymlinkSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
recreateSymlinkSpec :: Spec
recreateSymlinkSpec =
describe "HSFM.FileSystem.FileOperations.recreateSymlink" $ do
-- successes --
it "recreateSymLink, all fine" $ do
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/movedFile"
removeFileIfExists "test/FileSystem/FileOperations/recreateSymlinkSpec/movedFile"
it "recreateSymLink, all fine" $ do
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/dir/movedFile"
removeFileIfExists "test/FileSystem/FileOperations/recreateSymlinkSpec/dir/movedFile"
-- posix failures --
it "recreateSymLink, wrong input type (file)" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFile"
"test/FileSystem/FileOperations/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "recreateSymLink, wrong input type (directory)" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/dir"
"test/FileSystem/FileOperations/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "recreateSymLink, can't write to destination directory" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/noWritePerm/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, can't open destination directory" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/noPerms/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, can't open source directory" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/noPerms/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, destination file already exists" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "recreateSymLink, destination already exists and is a dir" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "recreateSymLink, source and destination are the same file" $
recreateSymlink' "test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
"test/FileSystem/FileOperations/recreateSymlinkSpec/myFileL"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -0,0 +1,83 @@
{-# LANGUAGE OverloadedStrings #-}
module FileSystem.FileOperations.RenameFileSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
renameFileSpec :: Spec
renameFileSpec =
describe "HSFM.FileSystem.FileOperations.renameFile" $ do
-- successes --
it "renameFile, all fine" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/renamedFile"
it "renameFile, all fine" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/dir/renamedFile"
it "renameFile, all fine on symlink" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFileL"
"test/FileSystem/FileOperations/renameFileSpec/renamedFile"
it "renameFile, all fine on directory" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/dir"
"test/FileSystem/FileOperations/renameFileSpec/renamedFile"
-- posix failures --
it "renameFile, source file does not exist" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/fileDoesNotExist"
"test/FileSystem/FileOperations/renameFileSpec/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "renameFile, can't write to output directory" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/noWritePerm/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "renameFile, can't open output directory" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/noPerms/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "renameFile, can't open source directory" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/noPerms/myFile"
"test/FileSystem/FileOperations/renameFileSpec/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
-- custom failures --
it "renameFile, destination file already exists" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/alreadyExists"
`shouldThrow`
isFileDoesExist
it "renameFile, move from file to dir" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/alreadyExistsD"
`shouldThrow`
isDirDoesExist
it "renameFile, source and dest are same file" $
renameFile' "test/FileSystem/FileOperations/renameFileSpec/myFile"
"test/FileSystem/FileOperations/renameFileSpec/myFile"
`shouldThrow`
isSameFile

View File

@ -1,83 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module MoveFileSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
moveFileSpec :: Spec
moveFileSpec =
describe "HSFM.FileSystem.FileOperations.moveFile" $ do
-- successes --
it "moveFile, all fine" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/movedFile"
it "moveFile, all fine" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/dir/movedFile"
it "moveFile, all fine on symlink" $
moveFile' "test/moveFileSpec/myFileL"
"test/moveFileSpec/movedFile"
it "moveFile, all fine on directory" $
moveFile' "test/moveFileSpec/dir"
"test/moveFileSpec/movedFile"
-- posix failures --
it "moveFile, source file does not exist" $
moveFile' "test/moveFileSpec/fileDoesNotExist"
"test/moveFileSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "moveFile, can't write to destination directory" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/noWritePerm/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "moveFile, can't open destination directory" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/noPerms/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "moveFile, can't open source directory" $
moveFile' "test/moveFileSpec/noPerms/myFile"
"test/moveFileSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
-- custom failures --
it "moveFile, destination file already exists" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/alreadyExists"
`shouldThrow`
isFileDoesExist
it "moveFile, move from file to dir" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/alreadyExistsD"
`shouldThrow`
isDirDoesExist
it "moveFile, source and dest are same file" $
moveFile' "test/moveFileSpec/myFile"
"test/moveFileSpec/myFile"
`shouldThrow`
isSameFile

View File

@ -1,81 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module RecreateSymlinkSpec where
import Test.Hspec
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
recreateSymlinkSpec :: Spec
recreateSymlinkSpec =
describe "HSFM.FileSystem.FileOperations.recreateSymlink" $ do
-- successes --
it "recreateSymLink, all fine" $ do
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/movedFile"
removeFileIfExists "test/recreateSymlinkSpec/movedFile"
it "recreateSymLink, all fine" $ do
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/dir/movedFile"
removeFileIfExists "test/recreateSymlinkSpec/dir/movedFile"
-- posix failures --
it "recreateSymLink, wrong input type (file)" $
recreateSymlink' "test/recreateSymlinkSpec/myFile"
"test/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "recreateSymLink, wrong input type (directory)" $
recreateSymlink' "test/recreateSymlinkSpec/dir"
"test/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == InvalidArgument)
it "recreateSymLink, can't write to destination directory" $
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/noWritePerm/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, can't open destination directory" $
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/noPerms/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, can't open source directory" $
recreateSymlink' "test/recreateSymlinkSpec/noPerms/myFileL"
"test/recreateSymlinkSpec/movedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "recreateSymLink, destination file already exists" $
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/alreadyExists"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "recreateSymLink, destination already exists and is a dir" $
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/alreadyExistsD"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)
it "recreateSymLink, source and destination are the same file" $
recreateSymlink' "test/recreateSymlinkSpec/myFileL"
"test/recreateSymlinkSpec/myFileL"
`shouldThrow`
(\e -> ioeGetErrorType e == AlreadyExists)

View File

@ -1,83 +0,0 @@
{-# LANGUAGE OverloadedStrings #-}
module RenameFileSpec where
import Test.Hspec
import HSFM.FileSystem.Errors
import System.IO.Error
(
ioeGetErrorType
)
import GHC.IO.Exception
(
IOErrorType(..)
)
import Utils
renameFileSpec :: Spec
renameFileSpec =
describe "HSFM.FileSystem.FileOperations.renameFile" $ do
-- successes --
it "renameFile, all fine" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/renamedFile"
it "renameFile, all fine" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/dir/renamedFile"
it "renameFile, all fine on symlink" $
renameFile' "test/renameFileSpec/myFileL"
"test/renameFileSpec/renamedFile"
it "renameFile, all fine on directory" $
renameFile' "test/renameFileSpec/dir"
"test/renameFileSpec/renamedFile"
-- posix failures --
it "renameFile, source file does not exist" $
renameFile' "test/renameFileSpec/fileDoesNotExist"
"test/renameFileSpec/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == NoSuchThing)
it "renameFile, can't write to output directory" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/noWritePerm/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "renameFile, can't open output directory" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/noPerms/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
it "renameFile, can't open source directory" $
renameFile' "test/renameFileSpec/noPerms/myFile"
"test/renameFileSpec/renamedFile"
`shouldThrow`
(\e -> ioeGetErrorType e == PermissionDenied)
-- custom failures --
it "renameFile, destination file already exists" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/alreadyExists"
`shouldThrow`
isFileDoesExist
it "renameFile, move from file to dir" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/alreadyExistsD"
`shouldThrow`
isDirDoesExist
it "renameFile, source and dest are same file" $
renameFile' "test/renameFileSpec/myFile"
"test/renameFileSpec/myFile"
`shouldThrow`
isSameFile

View File

@ -2,22 +2,21 @@
import Test.Hspec import Test.Hspec
import CopyDirRecursiveSpec import FileSystem.FileOperations.CopyDirRecursiveSpec
import CopyFileSpec import FileSystem.FileOperations.CopyFileSpec
import CreateDirSpec import FileSystem.FileOperations.CreateDirSpec
import CreateRegularFileSpec import FileSystem.FileOperations.CreateRegularFileSpec
import DeleteDirRecursiveSpec import FileSystem.FileOperations.DeleteDirRecursiveSpec
import DeleteDirSpec import FileSystem.FileOperations.DeleteDirSpec
import DeleteFileSpec import FileSystem.FileOperations.DeleteFileSpec
import GetDirsFilesSpec import FileSystem.FileOperations.GetDirsFilesSpec
import GetFileTypeSpec import FileSystem.FileOperations.GetFileTypeSpec
import MoveFileSpec import FileSystem.FileOperations.MoveFileSpec
import RecreateSymlinkSpec import FileSystem.FileOperations.RecreateSymlinkSpec
import RenameFileSpec import FileSystem.FileOperations.RenameFileSpec
import Utils import Utils
-- TODO: chardev, blockdev, namedpipe, socket -- TODO: chardev, blockdev, namedpipe, socket
@ -44,24 +43,24 @@ main = hspec $ before_ fixPermissions $ after_ revertPermissions $ do
getDirsFilesSpec getDirsFilesSpec
where where
noWriteDirs = ["test/copyFileSpec/outputDirNoWrite" noWriteDirs = ["test/FileSystem/FileOperations/copyFileSpec/outputDirNoWrite"
,"test/copyDirRecursiveSpec/noWritePerm" ,"test/FileSystem/FileOperations/copyDirRecursiveSpec/noWritePerm"
,"test/createDirSpec/noWritePerms" ,"test/FileSystem/FileOperations/createDirSpec/noWritePerms"
,"test/createRegularFileSpec/noWritePerms" ,"test/FileSystem/FileOperations/createRegularFileSpec/noWritePerms"
,"test/renameFileSpec/noWritePerm" ,"test/FileSystem/FileOperations/renameFileSpec/noWritePerm"
,"test/moveFileSpec/noWritePerm" ,"test/FileSystem/FileOperations/moveFileSpec/noWritePerm"
,"test/recreateSymlinkSpec/noWritePerm" ,"test/FileSystem/FileOperations/recreateSymlinkSpec/noWritePerm"
] ]
noPermsDirs = ["test/copyFileSpec/noPerms" noPermsDirs = ["test/FileSystem/FileOperations/copyFileSpec/noPerms"
,"test/copyDirRecursiveSpec/noPerms" ,"test/FileSystem/FileOperations/copyDirRecursiveSpec/noPerms"
,"test/createDirSpec/noPerms" ,"test/FileSystem/FileOperations/createDirSpec/noPerms"
,"test/createRegularFileSpec/noPerms" ,"test/FileSystem/FileOperations/createRegularFileSpec/noPerms"
,"test/renameFileSpec/noPerms" ,"test/FileSystem/FileOperations/renameFileSpec/noPerms"
,"test/moveFileSpec/noPerms" ,"test/FileSystem/FileOperations/moveFileSpec/noPerms"
,"test/recreateSymlinkSpec/noPerms" ,"test/FileSystem/FileOperations/recreateSymlinkSpec/noPerms"
,"test/getFileTypeSpec/noPerms" ,"test/FileSystem/FileOperations/getFileTypeSpec/noPerms"
,"test/getDirsFilesSpec/noPerms" ,"test/FileSystem/FileOperations/getDirsFilesSpec/noPerms"
,"test/deleteFileSpec/noPerms" ,"test/FileSystem/FileOperations/deleteFileSpec/noPerms"
] ]
fixPermissions = do fixPermissions = do
sequence_ $ fmap noWritableDirPerms noWriteDirs sequence_ $ fmap noWritableDirPerms noWriteDirs