File: File.hs

package info (click to toggle)
ghc 9.0.2-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 177,780 kB
  • sloc: haskell: 494,441; ansic: 70,262; javascript: 9,423; sh: 8,537; python: 2,646; asm: 1,725; makefile: 1,333; xml: 196; cpp: 167; perl: 143; ruby: 84; lisp: 7
file content (43 lines) | stat: -rw-r--r-- 1,132 bytes parent folder | download | duplicates (7)
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
40
41
42
43
{-# LANGUAGE CPP #-}
module Main where

#if ! MIN_VERSION_base(4,8,0)
import           Control.Applicative
#endif

import           System.Directory          (getTemporaryDirectory)
import           System.FilePath           ((</>))
import           Test.HUnit

import           Distribution.Simple.Utils (withTempDirectory)
import           Distribution.Verbosity    (silent)

import           Data.Binary

data Foo = Bar !Word32 !Word32 !Word32 deriving (Eq, Show)

instance Binary Foo where
  get = Bar <$> get <*> get <*> get
  put (Bar a b c) = put (a,b,c)

exampleData :: [Foo]
exampleData = make bytes
  where
    make (a:b:c:xs) = Bar a b c : make xs
    make _ = []
    bytes = take (256*1024) (cycle [minBound..maxBound])

readWriteTest :: Test
readWriteTest = TestCase $ do
  tmpDir <- getTemporaryDirectory
  withTempDirectory silent tmpDir "foo-dir" $ \dir -> do
    let fn = dir </> "foo.bin"
    encodeFile fn exampleData
    content <- decodeFile fn
    -- It'd be nice to use lsof to verify that 'fn' isn't still open.
    exampleData @=? content

main :: IO ()
main = do 
  _ <- runTestTT readWriteTest
  return ()