123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- {-# LANGUAGE QuasiQuotes #-}
- module Day7Spec (spec) where
-
- import Test.Hspec
- import Text.Heredoc
-
- import Day7
- import Day7.Parser
- import qualified Data.Map as Map
-
- inputPart1 :: String
- inputPart1 = [str|$ cd /
- |$ ls
- |dir a
- |14848514 b.txt
- |8504156 c.dat
- |dir d
- |$ cd a
- |$ ls
- |dir e
- |29116 f
- |2557 g
- |62596 h.lst
- |$ cd e
- |$ ls
- |584 i
- |$ cd ..
- |$ cd ..
- |$ cd d
- |$ ls
- |4060174 j
- |8033020 d.log
- |5626152 d.ext
- |7214296 k
- |]
-
- cdTerm :: [TerminalCommand]
- cdTerm = forceRight $ parseTerminalLines
- [str|$ cd foo
- |$ ls
- |23 f
- |34 f2
- |dir d
- |$ cd ..
- |]
-
- cdOutTerm :: [TerminalCommand]
- cdOutTerm = forceRight $ parseTerminalLines
- [str|$ cd foo
- |$ ls
- |42 f
- |$ cd ..
- |$ cd bar
- |$ ls
- |100 baba
- |$ cd x
- |$ cd /
- |$ ls
- |23 f
- |dir foo
- |dir bar
- |]
- cdOutParsed :: [TerminalCommand]
- cdOutParsed = [
- In "foo",
- Listing [FileListing "f" 42],
- Out,
- In "bar",
- Listing [FileListing "baba" 100],
- In "x",
- Root,
- Listing [FileListing "f" 23, DirListing "foo", DirListing "bar"]
- ]
-
- forceRight :: Either a b -> b
- forceRight (Left _) = error "forced Right but got Left"
- forceRight (Right b) = b
-
- spec :: Spec
- spec =
- describe "Day7" $ do
- describe "Part1" $ do
- describe "parser" $ do
- it "parses an ls command" $ do
- parseTerminalLines "$ ls\n" `shouldBe` Right [Listing []]
- it "parses a cd up command" $ do
- parseTerminalLines "$ cd ..\n" `shouldBe` Right [Out]
- it "parses a cd root command" $ do
- parseTerminalLines "$ cd /\n" `shouldBe` Right [Root]
- it "parses a cd in command" $ do
- parseTerminalLines "$ cd dirname\n" `shouldBe` Right [In "dirname"]
- it "parses a file listing line" $ do
- parseTerminalLines "$ ls\n1234 f\n$ cd foo\n" `shouldBe` Right [Listing [FileListing "f" 1234], In "foo"]
- it "parses a larger shell log" $ do
- cdOutTerm `shouldBe` cdOutParsed
- describe "tree" $ do
- it "reads a listing" $ do
- buildTree [Listing [FileListing "f" 123]] `shouldBe`
- mkdir { files = Map.singleton "f" 123, isRoot = True }
- it "changes dir" $ do
- buildTree cdTerm `shouldBe`
- mkdir {
- sub = Map.fromList [
- ("foo", mkdir { files = Map.fromList [("f", 23), ("f2", 34)] })
- ],
- files = Map.empty,
- isRoot = True
- }
- it "changes dir outwards" $ do
- buildTree cdOutTerm `shouldBe`
- mkdir {
- sub = Map.fromList [
- ("foo", mkdir { files = Map.fromList [("f", 42)] } ),
- ("bar", mkdir {
- sub = Map.fromList [("x", mkdir)],
- files = Map.fromList [("baba", 100)]
- } )
- ],
- files = Map.fromList [("f", 23)],
- isRoot = True
- }
- it "calculates size of directories" $ do
- calculateSize mkdir { files = Map.fromList [("f", 23), ("f2", 34)] }
- `shouldBe` 23 + 34
- calculateSize mkdir {
- sub = Map.fromList [ ("d", mkdir { files = Map.fromList [("f", 23), ("f2", 34)] })] }
- `shouldBe` 23 + 34
- it "sums stuff up" $ do
- let parsed = forceRight $ parseTerminalLines inputPart1
- let tree = buildTree parsed
- let filtered = filterDirectories (<= 100000) tree
- let summed = sumUp filtered
- summed `shouldBe` 95437
|