aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/CompileTest.hs64
-rw-r--r--tests/cabal-versions57
2 files changed, 72 insertions, 49 deletions
diff --git a/tests/CompileTest.hs b/tests/CompileTest.hs
index ea5202e..2df6c2d 100644
--- a/tests/CompileTest.hs
+++ b/tests/CompileTest.hs
@@ -1,4 +1,4 @@
-{-# LANGUAGE ScopedTypeVariables, GADTs, ImplicitParams #-}
+{-# LANGUAGE ScopedTypeVariables, GADTs, ImplicitParams, OverloadedStrings #-}
{-| This test tries to compile the Helper against every supported version of the
Cabal library. Since we compile the Helper at runtime, on the user's machine,
@@ -69,16 +69,16 @@ main = do
args <- getArgs
case args of
"list-versions":[] -> do
- mapM_ print =<< (allCabalVersions <$> ghcVersion)
+ mapM_ print =<< relevantCabalVersions =<< ghcVersion
"list-versions":ghc_ver_str:[] ->
- mapM_ print $ allCabalVersions (GhcVersion (parseVer ghc_ver_str))
+ mapM_ print =<< relevantCabalVersions (GhcVersion (parseVer ghc_ver_str))
_ ->
test args
test :: Env => [String] -> IO ()
test args = do
let action
- | null args = testAllCabalVersions
+ | null args = testRelevantCabalVersions
| otherwise = testCabalVersions $ map parseVer' args
setupHOME
@@ -89,47 +89,14 @@ parseVer' :: String -> CabalVersion
parseVer' "HEAD" = CabalHEAD ()
parseVer' v = CabalVersion $ parseVer v
-allCabalVersions :: GhcVersion -> [Version]
-allCabalVersions (GhcVersion ghc_ver) = let
- cabal_versions :: [Version]
- cabal_versions = map parseVer
- -- , "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" -- deprecated
- , "1.24.2.0"
- , "2.0.0.2"
- , "2.0.1.0"
- , "2.0.1.1"
- , "2.2.0.0"
- , "2.2.0.1"
- , "2.4.0.0"
- , "2.4.0.1"
- , "2.4.1.0"
- ]
+relevantCabalVersions :: GhcVersion -> IO [Version]
+relevantCabalVersions g = map snd . filter fst <$> allCabalVersions g
+allCabalVersions :: GhcVersion -> IO [(Bool,Version)]
+allCabalVersions (GhcVersion ghc_ver) = do
+ cabal_versions
+ <- map parseVer . lines <$> readFile "tests/cabal-versions"
+ let
constraint :: VersionRange
Just constraint =
fmap snd $
@@ -147,14 +114,13 @@ allCabalVersions (GhcVersion ghc_ver) = let
, ("8.4", ">= 2.0.0.2 ")
, ("8.6", ">= 2.0.0.2 ")
]
- in
- reverse $ filter (flip withinRange'CH constraint) cabal_versions
+ return $ reverse $ map (flip withinRange'CH constraint &&& id) cabal_versions
-testAllCabalVersions :: Env => IO ()
-testAllCabalVersions = do
+testRelevantCabalVersions :: Env => IO ()
+testRelevantCabalVersions = do
ghc_ver <- ghcVersion
- let relevant_cabal_versions = allCabalVersions ghc_ver
+ relevant_cabal_versions <- relevantCabalVersions ghc_ver
testCabalVersions $ map CabalVersion relevant_cabal_versions ++ [CabalHEAD ()]
testCabalVersions :: Env => [CabalVersion] -> IO ()
diff --git a/tests/cabal-versions b/tests/cabal-versions
new file mode 100644
index 0000000..f0da0a4
--- /dev/null
+++ b/tests/cabal-versions
@@ -0,0 +1,57 @@
+1.1.6
+1.2.1
+1.2.2.0
+1.2.3.0
+1.2.4.0
+1.4.0.0
+1.4.0.1
+1.4.0.2
+1.6.0.1
+1.6.0.2
+1.6.0.3
+1.8.0.2
+1.8.0.4
+1.8.0.6
+1.10.0.0
+1.10.1.0
+1.10.2.0
+1.12.0
+1.14.0
+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.2.0
+2.0.0.2
+2.0.1.0
+2.0.1.1
+2.2.0.0
+2.2.0.1
+2.4.0.0
+2.4.0.1
+2.4.1.0