summaryrefslogtreecommitdiff
path: root/hadrian/src/Rules/Selftest.hs
diff options
context:
space:
mode:
authorBen Gamari <ben@smart-cactus.org>2017-12-08 12:42:35 -0500
committerBen Gamari <ben@smart-cactus.org>2017-12-08 13:22:41 -0500
commit7733e44dd4ba7e7a0a9f3456e6ddc32decbcf5a3 (patch)
tree79c5e7151d760e6c7617d8450fb9ec2a10560989 /hadrian/src/Rules/Selftest.hs
parent5695f462f604fc63cbb45a7f3073bc114f9b475f (diff)
downloadhaskell-7733e44dd4ba7e7a0a9f3456e6ddc32decbcf5a3.tar.gz
Rip out hadrian subtree
Sadly subtrees haven't worked quite as well as we would have liked for developers. See Hadrian #440.
Diffstat (limited to 'hadrian/src/Rules/Selftest.hs')
-rw-r--r--hadrian/src/Rules/Selftest.hs92
1 files changed, 0 insertions, 92 deletions
diff --git a/hadrian/src/Rules/Selftest.hs b/hadrian/src/Rules/Selftest.hs
deleted file mode 100644
index d1ffaac1c3..0000000000
--- a/hadrian/src/Rules/Selftest.hs
+++ /dev/null
@@ -1,92 +0,0 @@
-{-# OPTIONS_GHC -fno-warn-orphans #-}
-module Rules.Selftest (selftestRules) where
-
-import Test.QuickCheck
-
-import Base
-import GHC
-import Oracles.ModuleFiles
-import Oracles.Setting
-import Settings
-import Target
-
-instance Arbitrary Way where
- arbitrary = wayFromUnits <$> arbitrary
-
-instance Arbitrary WayUnit where
- arbitrary = arbitraryBoundedEnum
-
-test :: Testable a => a -> Action ()
-test = liftIO . quickCheck
-
-selftestRules :: Rules ()
-selftestRules =
- "selftest" ~> do
- testBuilder
- testChunksOfSize
- testLookupAll
- testModuleName
- testPackages
- testWay
-
-testBuilder :: Action ()
-testBuilder = do
- putBuild "==== trackArgument"
- let make = target undefined (Make undefined) undefined undefined
- test $ forAll (elements ["-j", "MAKEFLAGS=-j", "THREADS="])
- $ \prefix (NonNegative n) ->
- not (trackArgument make prefix) &&
- not (trackArgument make ("-j" ++ show (n :: Int)))
-
-testChunksOfSize :: Action ()
-testChunksOfSize = do
- putBuild "==== chunksOfSize"
- test $ chunksOfSize 3 [ "a", "b", "c" , "defg" , "hi" , "jk" ]
- == [ ["a", "b", "c"], ["defg"], ["hi"], ["jk"] ]
- test $ \n xs ->
- let res = chunksOfSize n xs
- in concat res == xs && all (\r -> length r == 1 || length (concat r) <= n) res
-
-testLookupAll :: Action ()
-testLookupAll = do
- putBuild "==== lookupAll"
- test $ lookupAll ["b" , "c" ] [("a", 1), ("c", 3), ("d", 4)]
- == [Nothing, Just (3 :: Int)]
- test $ forAll dicts $ \dict -> forAll extras $ \extra ->
- let items = sort $ map fst dict ++ extra
- in lookupAll items (sort dict) == map (`lookup` dict) items
- where
- dicts :: Gen [(Int, Int)]
- dicts = nubBy (\x y -> fst x == fst y) <$> vector 20
- extras :: Gen [Int]
- extras = vector 20
-
-testModuleName :: Action ()
-testModuleName = do
- putBuild "==== Encode/decode module name"
- test $ encodeModule "Data/Functor" "Identity.hs" == "Data.Functor.Identity"
- test $ encodeModule "" "Prelude" == "Prelude"
-
- test $ decodeModule "Data.Functor.Identity" == ("Data/Functor", "Identity")
- test $ decodeModule "Prelude" == ("", "Prelude")
-
- test $ forAll names $ \n -> uncurry encodeModule (decodeModule n) == n
- where
- names = intercalate "." <$> listOf1 (listOf1 $ elements "abcABC123_'")
-
-testPackages :: Action ()
-testPackages = do
- putBuild "==== Check system configuration"
- win <- windowsHost -- This depends on the @boot@ and @configure@ scripts.
- putBuild "==== Packages, interpretInContext, configuration flags"
- forM_ [Stage0 ..] $ \stage -> do
- pkgs <- stagePackages stage
- when (win32 `elem` pkgs) . test $ win
- when (unix `elem` pkgs) . test $ not win
- test $ pkgs == nubOrd pkgs
-
-testWay :: Action ()
-testWay = do
- putBuild "==== Read Way, Show Way"
- test $ \(x :: Way) -> read (show x) == x
-