forked from commercialhaskell/stack
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSolverSpec.hs
More file actions
42 lines (39 loc) · 1.36 KB
/
SolverSpec.hs
File metadata and controls
42 lines (39 loc) · 1.36 KB
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
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE OverloadedStrings #-}
-- | Test suite for "Stack.Solver"
module Stack.SolverSpec where
import Data.Text (unpack)
import Stack.Types
import Test.Hspec
import qualified Data.Map as Map
import Stack.Solver
spec :: Spec
spec =
describe "Stack.Solver" $ do
successfulExample
"text-1.2.1.1 (latest: 1.2.2.0) -integer-simple (via: parsec-3.1.9) (new package)"
$(mkPackageName "text")
$(mkVersion "1.2.1.1")
[ ($(mkFlagName "integer-simple"), False)
]
successfulExample
"hspec-snap-1.0.0.0 *test (via: servant-snap-0.5) (new package)"
$(mkPackageName "hspec-snap")
$(mkVersion "1.0.0.0")
[]
successfulExample
"time-locale-compat-0.1.1.1 -old-locale (via: http-api-data-0.2.2) (new package)"
$(mkPackageName "time-locale-compat")
$(mkVersion "0.1.1.1")
[ ($(mkFlagName "old-locale"), False)
]
successfulExample
"flowdock-rest-0.2.0.0 -aeson-compat *test (via: haxl-fxtra-0.0.0.0) (new package)"
$(mkPackageName "flowdock-rest")
$(mkVersion "0.2.0.0")
[ ($(mkFlagName "aeson-compat"), False)
]
where
successfulExample input pkgName pkgVersion flags =
it ("parses " ++ unpack input) $
parseCabalOutputLine input `shouldBe` Right (pkgName, (pkgVersion, Map.fromList flags))