aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tests/Selective.hs (renamed from tests/test_Selective.hs)2
-rw-r--r--tests/SwapWorkspaces.hs (renamed from tests/test_SwapWorkspaces.hs)3
-rw-r--r--tests/XPrompt.hs (renamed from tests/test_XPrompt.hs)7
-rw-r--r--tests/genMain.hs52
4 files changed, 62 insertions, 2 deletions
diff --git a/tests/test_Selective.hs b/tests/Selective.hs
index 186f904..db00563 100644
--- a/tests/test_Selective.hs
+++ b/tests/Selective.hs
@@ -1,4 +1,6 @@
+{-# LANGUAGE NoMonomorphismRestriction #-}
{-# LANGUAGE ScopedTypeVariables, FlexibleInstances #-}
+module Selective where
-- Tests for limitSelect-related code in L.LimitWindows.
-- To run these tests, export (select,update,Selection(..),updateAndSelect) from
diff --git a/tests/test_SwapWorkspaces.hs b/tests/SwapWorkspaces.hs
index 148ab97..1cd33a0 100644
--- a/tests/test_SwapWorkspaces.hs
+++ b/tests/SwapWorkspaces.hs
@@ -1,4 +1,5 @@
-{-# OPTIONS -fglasgow-exts #-}
+{-# LANGUAGE ScopedTypeVariables #-}
+module SwapWorkspaces where
import Data.List(find,union)
import Data.Maybe(fromJust)
diff --git a/tests/test_XPrompt.hs b/tests/XPrompt.hs
index a4c6236..9c8ca8c 100644
--- a/tests/test_XPrompt.hs
+++ b/tests/XPrompt.hs
@@ -1,9 +1,10 @@
-{-# OPTIONS -fglasgow-exts #-}
+{-# LANGUAGE ScopedTypeVariables #-}
-------------------------------------
--
-- Tests for XPrompt and ShellPrompt
--
-------------------------------------
+module XPrompt where
import Data.Char
import Test.QuickCheck
@@ -12,11 +13,14 @@ import Data.List
import XMonad.Prompt
import qualified XMonad.Prompt.Shell as S
+import Properties
+{-
instance Arbitrary Char where
arbitrary = choose ('\32', '\255')
coarbitrary c = variant (ord c `rem` 4)
+-}
doubleCheck p = check (defaultConfig { configMaxTest = 1000}) p
deepCheck p = check (defaultConfig { configMaxTest = 10000}) p
@@ -40,6 +44,7 @@ prop_spliInSubListsAt (x :: Int) (str :: [Char]) =
prop_skipGetLastWord (str :: [Char]) =
skipLastWord str ++ getLastWord str == str || skipLastWord str == getLastWord str
+
-- newIndex and newCommand get only non empy lists
elemGen :: Gen ([String],String)
elemGen = do
diff --git a/tests/genMain.hs b/tests/genMain.hs
new file mode 100644
index 0000000..90d8224
--- /dev/null
+++ b/tests/genMain.hs
@@ -0,0 +1,52 @@
+{-# LANGUAGE ViewPatterns #-}
+{- | generate another Main from all modules in the current directory,
+extracting all functions with @prop_@.
+
+Usage (your QuickCheck-1 version may vary):
+
+> ln -s ../../xmonad/tests/Properties.hs .
+> runghc genMain.hs > Main.hs
+> ghc -DTESTING -i.. -i. -package QuickCheck-1.2.0.0 Main.hs -e main
+
+-}
+module Main where
+
+import Control.Monad.List
+import Data.Char
+import Data.IORef
+import Data.List
+import qualified Data.Set as S
+import System.Directory
+import System.FilePath
+import Text.PrettyPrint.HughesPJ
+
+main = do
+ imports <- newIORef S.empty
+ props <- runListT $ do
+ f @ ((isUpper -> True) : (takeExtension -> ".hs"))
+ <- ListT (getDirectoryContents ".")
+ guard $ f `notElem` ["Main.hs", "Common.hs", "Properties.hs"]
+ let b = takeBaseName f
+ nesting <- io $ newIORef 0
+ decl : _ <- ListT $ (map words . lines) `fmap` readFile f
+ case decl of
+ "{-" -> io $ modifyIORef nesting succ
+ "-}" -> io $ modifyIORef nesting pred
+ _ -> return ()
+ 0 <- io $ readIORef nesting
+ guard $ "prop_" `isPrefixOf` decl
+ io $ modifyIORef imports (S.insert b)
+ return (b ++ "." ++ decl)
+ imports <- S.toList `fmap` readIORef imports
+ print $ genModule imports props
+
+genModule :: [String] -> [String] -> Doc
+genModule imports props = vcat [header,imports', main ]
+ where
+ header = text "module Main where"
+ imports' = text "import Test.QuickCheck"
+ $$ vcat [ text "import qualified" <+> text im | im <- imports ]
+ props' = vcat [ text "quickCheck" <+> text p | p <- props ]
+ main = hang (text "main = do") 4 props'
+
+io x = liftIO x