1 -- | Tests for Metainfo module
4 - Copyright (C) 2015-2016 Ramakrishnan Muthukrishnan <ram@rkrishnan.org>
6 - This file is part of FuncTorrent.
8 - FuncTorrent is free software; you can redistribute it and/or modify
9 - it under the terms of the GNU General Public License as published by
10 - the Free Software Foundation; either version 3 of the License, or
11 - (at your option) any later version.
13 - FuncTorrent is distributed in the hope that it will be useful,
14 - but WITHOUT ANY WARRANTY; without even the implied warranty of
15 - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 - GNU General Public License for more details.
18 - You should have received a copy of the GNU General Public License
19 - along with FuncTorrent; if not, see <http://www.gnu.org/licenses/>
22 module MetainfoTests where
24 import Prelude hiding (readFile)
26 import FuncTorrent.Metainfo
28 import Control.Monad (liftM)
30 import Data.ByteString (readFile)
34 fc <- readFile "data/debian-7.8.0-amd64-CD-1.iso.torrent"
35 let minfo = torrentToMetainfo fc
37 describe "read and interpret a torrent file 1" $ do
38 it "valid torrent file" $ do
39 (torrentToMetainfo fc) `shouldNotBe` (Left "parse error")
40 it "valid announce list" $ do
41 case torrentToMetainfo fc of
44 announceList metainfo `shouldSatisfy` (not . null)
45 it "valid piece length" $ do
46 case torrentToMetainfo fc of
49 let (Just info') = info metainfo
50 pieceLength info' `shouldBe` (524288 :: Integer)
51 it "Not a multifile torrent" $ do
52 case torrentToMetainfo fc of
55 let (Just i) = info metainfo
56 (length (filemeta i)) `shouldSatisfy` (== 1)
58 describe "read and interpret a multifile torrent file" $ do
59 it "valid multifile torrent file" $ do
60 fc <- readFile "data/multifile.torrent"
61 (torrentToMetainfo fc) `shouldNotBe` (Left "parse error")
62 it "valid multifile torrent with multiple files" $ do
63 fc <- readFile "data/multifile.torrent"
64 case torrentToMetainfo fc of
67 let (Just i) = info metainfo
68 (length (filemeta i)) `shouldSatisfy` (> 1)