aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Gröber <dxld@darkboxed.org>2017-07-09 00:48:38 +0200
committerDaniel Gröber <dxld@darkboxed.org>2017-07-09 00:48:38 +0200
commitc17a519c3c3f07d483708d0ef9e1ed63d93033ea (patch)
tree55a207d90a7e5fa9d6acec16d27a71e3812b3675
parentd03b93e993c7e9493226e7e8fe3b9ff833d06222 (diff)
spec: Introduce upper bounds for cabal version
-rw-r--r--tests/Spec.hs138
1 files changed, 77 insertions, 61 deletions
diff --git a/tests/Spec.hs b/tests/Spec.hs
index 4fe9293..48be9b7 100644
--- a/tests/Spec.hs
+++ b/tests/Spec.hs
@@ -3,9 +3,15 @@ import System.Environment.Extra (lookupEnv)
import System.Posix.Env (setEnv)
import System.Process
import System.Exit
+import System.IO
+import Data.List
import Data.Maybe
import Data.Version
import Data.Functor
+import Data.Function
+import qualified Distribution.Compat.ReadP as Dist
+import Distribution.Version hiding (Version)
+import Distribution.Text
import Control.Exception as E
import Control.Arrow
import Control.Monad
@@ -13,8 +19,19 @@ import Prelude
import CabalHelper.Common
import CabalHelper.Compile
+import CabalHelper.Compat.Version
import CabalHelper.Types
+runReadP'Dist :: Dist.ReadP t t -> String -> t
+runReadP'Dist p i = case filter ((=="") . snd) $ Dist.readP_to_S p i of
+ (a,""):[] -> a
+ _ -> error $ "Error parsing: " ++ show i
+
+withinRange'CH :: Either HEAD Version -> VersionRange -> Bool
+withinRange'CH v r =
+ withinRange (fromDataVersion v') r
+ where
+ v' = either (const $ parseVer "1000000000") id v
main :: IO ()
main = do
@@ -24,66 +41,65 @@ main = do
writeAutogenFiles' $ defaultQueryEnv "." "./dist"
let parseVer' "HEAD" = Left HEAD
- parseVer' v = Right $ parseVer v
-
- let vers :: [(Version, [Either HEAD Version])]
- vers = map (parseVer *** map parseVer') [
- ("7.4", [ -- "1.14.0" -- not supported at runtime
- ]),
-
- ("7.6", [ "1.16.0"
- , "1.16.0.1"
- , "1.16.0.2"
- , "1.16.0.3"
- ]),
-
- ("7.8", [
- "1.18.0"
- , "1.18.1"
- , "1.18.1.1"
- , "1.18.1.2"
- , "1.18.1.3"
- , "1.18.1.4"
- , "1.18.1.5"
- , "1.18.1.6"
- , "1.18.1.7"
-
- , "1.20.0.0"
- , "1.20.0.1"
- , "1.20.0.2"
- , "1.20.0.3"
- , "1.20.0.4"
- , "1.22.0.0"
- , "1.22.1.0"
- , "1.22.1.1"
- ]),
-
- ("7.10", [
- "1.22.2.0"
- , "1.22.3.0"
- , "1.22.4.0"
- , "1.22.5.0"
- , "1.22.6.0"
- , "1.22.7.0"
- , "1.22.8.0"
- ]),
- ("8.0.1", [
- "1.24.0.0"
- , "1.24.1.0"
- ]),
- ("8.0.2", [
- "1.24.2.0"
- , "HEAD"
- ])
- ]
-
- ghcVer <- ghcVersion defaultOptions
-
- let cabalVers = reverse $ concat $ map snd $ dropWhile ((<ghcVer) . fst) vers
-
- rvs <- forM cabalVers $ \ver -> do
+ parseVer' v = Right $ parseVer v
+
+ let cabal_versions :: [Either HEAD Version]
+ cabal_versions = map parseVer'
+ -- "1.14.0" -- not supported at runtime
+ [ "1.16.0"
+ , "1.16.0.1"
+ , "1.16.0.2"
+ , "1.16.0.3"
+ , "1.18.0"
+ , "1.18.1"
+ , "1.18.1.1"
+ , "1.18.1.2"
+ , "1.18.1.3"
+ , "1.18.1.4"
+ , "1.18.1.5"
+ , "1.18.1.6"
+ , "1.18.1.7"
+ , "1.20.0.0"
+ , "1.20.0.1"
+ , "1.20.0.2"
+ , "1.20.0.3"
+ , "1.20.0.4"
+ , "1.22.0.0"
+ , "1.22.1.0"
+ , "1.22.1.1"
+ , "1.22.2.0"
+ , "1.22.3.0"
+ , "1.22.4.0"
+ , "1.22.5.0"
+ , "1.22.6.0"
+ , "1.22.7.0"
+ , "1.22.8.0"
+ , "1.24.0.0"
+ , "1.24.1.0"
+ , "1.24.2.0"
+ , "HEAD"
+ ]
+
+ ghc_ver <- ghcVersion defaultOptions
+
+ let constraint :: VersionRange
+ Just (_, constraint) =
+ find (and . (zipWith (==) `on` versionBranch) ghc_ver . fst) $
+ map (parseVer *** runReadP'Dist parse) $
+ [ ("7.4" , ">= 1.14 && < 2")
+ , ("7.6" , ">= 1.16 && < 2")
+ , ("7.8" , ">= 1.18 && < 2")
+ , ("7.10" , ">= 1.22.2 && < 2")
+ , ("8.0.1", ">= 1.24 ")
+ , ("8.0.2", ">= 1.24.2 ")
+ ]
+
+ relevant_cabal_versions =
+ reverse $ filter (flip withinRange'CH constraint) cabal_versions
+
+ rvs <- forM relevant_cabal_versions $ \ver -> do
let sver = either show showVersion ver
- putStrLn $ "\n\n\n\n\n\n====== Compiling with Cabal-" ++ sver
+ hPutStrLn stderr $ "\n\n\n\n\n\n====== Compiling with Cabal-" ++ sver
compilePrivatePkgDb ver
let printStatus (cv, rv) = putStrLn $ "- Cabal "++show cv++" "++status
@@ -93,9 +109,9 @@ main = do
Left rvc ->
"failed (exit code "++show rvc++")"
- let drvs = cabalVers `zip` rvs
+ let drvs = relevant_cabal_versions `zip` rvs
- mapM_ printStatus (cabalVers `zip` rvs)
+ mapM_ printStatus (relevant_cabal_versions `zip` rvs)
if any isLeft' $ map snd $ filter ((/=Left HEAD) . fst) drvs
then exitFailure
else exitSuccess