1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- {-# LANGUAGE QuasiQuotes #-}
- module Day8Spec (spec) where
-
- import Test.Hspec
- import Text.Heredoc
- import Control.Arrow ((>>>))
-
- import qualified Data.Matrix as M
- import qualified Data.Vector as V
- import Day8
-
- testInput :: String
- testInput = [str|30373
- |25512
- |65332
- |33549
- |35390
- |]
-
- testVisibility :: Visibillity
- testVisibility = M.fromList 5 5
- [x,x,x,x,x,
- x,x,x,o,x,
- x,x,o,x,x,
- x,o,x,o,x,
- x,x,x,x,x
- ]
- where
- x = True
- o = False
-
- smallForest :: String
- smallForest = [str|1234
- |5678
- |9012
- |]
-
- parsedSmallForest :: Forest
- parsedSmallForest = M.fromList 3 4 $ [1..9] ++ [0,1,2]
-
- spec :: Spec
- spec =
- describe "Day8" $ do
- describe "Part1" $ do
- it "parses a forest" $ do
- parseForest smallForest `shouldBe` parsedSmallForest
- it "checks visibility" $ do
- let forest = parseForest testInput
- checkVisibility forest `shouldBe` testVisibility
- it "counts visible things" $ do
- let v = parseForest >>>
- checkVisibility >>>
- countVisible $ testInput
- v `shouldBe` 21
- describe "Part2" $ do
- it "calculates viewing distance from height" $ do
- viewingDistance 5 (V.fromList [3]) `shouldBe` 1
- viewingDistance 5 (V.fromList [5,2]) `shouldBe` 1
- viewingDistance 5 (V.fromList [1,2]) `shouldBe` 2
- viewingDistance 5 (V.fromList [3,5,3]) `shouldBe` 2
- it "calculates the scenic score" $ do
- let s = parseForest >>>
- findMaxScenicScore $ testInput
- s `shouldBe` 8
|