module Test.HspecSpec (main, spec) where import Helper import Mock import Data.List (isPrefixOf) import Test.Hspec.Core (SpecTree(..), Result(..), runSpecM) import qualified Test.Hspec as H import qualified Test.Hspec.Runner as H (hspecResult) main :: IO () main = hspec spec spec :: Spec spec = do describe "pending" $ do it "specifies a pending example" $ do r <- runSpec $ do H.it "foo" H.pending r `shouldSatisfy` any (== " # PENDING: No reason given") describe "pendingWith" $ do it "specifies a pending example with a reason for why it's pending" $ do r <- runSpec $ do H.it "foo" $ do H.pendingWith "for some reason" r `shouldSatisfy` any (== " # PENDING: for some reason") describe "describe" $ do let testSpec = do H.describe "some subject" $ do H.it "foo" True H.it "bar" True H.it "baz" True it "takes a description of what the behavior is for" $ do r <- runSpec testSpec r `shouldSatisfy` any (== "some subject") it "groups behaviors for what's being described" $ do r <- filter (isPrefixOf " - ") `fmap` runSpec testSpec length r `shouldBe` 3 it "can be nested" $ do let [SpecGroup foo [SpecGroup bar [SpecItem _ baz _]]] = runSpecM $ do H.describe "foo" $ do H.describe "bar" $ do H.it "baz" True (foo, bar, baz) `shouldBe` ("foo", "bar", "baz") context "when no description is given" $ do it "uses a default description" $ do let [SpecGroup d _] = runSpecM (H.describe "" (pure ())) d `shouldBe` "(no description given)" describe "it" $ do it "takes a description of a desired behavior" $ do let [SpecItem _ d _] = runSpecM (H.it "whatever" True) d `shouldBe` "whatever" it "takes an example of that behavior" $ do let [SpecItem _ _ e] = runSpecM (H.it "whatever" True) e defaultParams `shouldReturn` Success context "when no description is given" $ do it "uses a default description" $ do let [SpecItem _ d _] = runSpecM (H.it "" True) d `shouldBe` "(unspecified behavior)" describe "example" $ do it "fixes the type of an expectation" $ do r <- runSpec $ do H.it "foo" $ H.example $ do pure () r `shouldSatisfy` any (== "1 example, 0 failures") describe "parallel" $ do it "marks examples for parallel execution" $ do let [SpecItem isParallelizable _ _] = runSpecM . H.parallel $ H.it "whatever" True isParallelizable `shouldBe` True it "is applied recursively" $ do let [SpecGroup _ [SpecGroup _ [SpecItem isParallelizable _ _]]] = runSpecM . H.parallel $ do H.describe "foo" $ do H.describe "bar" $ do H.it "baz" True isParallelizable `shouldBe` True describe "before" $ do it "runs an action before each spec item" $ do mock <- newMock silence $ H.hspec $ H.before (mockAction mock) $ do H.it "foo" $ do mockCounter mock `shouldReturn` 1 H.it "bar" $ do mockCounter mock `shouldReturn` 2 where runSpec :: H.Spec -> IO [String] runSpec = captureLines . H.hspecResult