1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39
|
module Examples.Test.Files(main) where
import Development.Shake
import Examples.Util
import Control.Monad
import Data.List
main = shaken test $ \args obj -> do
let fun = "@" `elem` args
let rest = delete "@" args
want $ map obj $ if null rest then ["even.txt","odd.txt"] else rest
-- Since &?> and &*> are implemented separately we test everything in both modes
let deps &?*> act | fun = (\x -> if x `elem` deps then Just deps else Nothing) &?> act
| otherwise = deps &*> act
map obj ["even.txt","odd.txt"] &?*> \[evens,odds] -> do
src <- readFileLines $ obj "numbers.txt"
let (es,os) = partition even $ map read src
writeFileLines evens $ map show es
writeFileLines odds $ map show os
map obj ["dir1/out.txt","dir2/out.txt"] &?*> \[a,b] -> do
writeFile' a "a"
writeFile' b "b"
test build obj = do
forM_ [[],["@"]] $ \args -> do
let nums = unlines . map show
writeFile (obj "numbers.txt") $ nums [1,2,4,5,2,3,1]
build ("--sleep":args)
assertContents (obj "even.txt") $ nums [2,4,2]
assertContents (obj "odd.txt" ) $ nums [1,5,3,1]
build ["clean"]
build ["--no-build","--report=-"]
build ["dir1/out.txt"]
|