Files
ghc-mod/test/InfoSpec.hs

60 lines
2.3 KiB
Haskell
Raw Normal View History

{-# LANGUAGE CPP #-}
2013-02-13 16:22:07 +09:00
module InfoSpec where
import Control.Applicative ((<$>))
import Data.List (isPrefixOf)
2013-05-20 11:29:44 +09:00
import Language.Haskell.GhcMod
2013-10-07 16:39:54 +09:00
#if __GLASGOW_HASKELL__ < 706
import System.Environment.Executable (getExecutablePath)
#else
import System.Environment (getExecutablePath)
#endif
2013-03-31 17:55:37 +04:00
import System.Exit
import System.FilePath
2013-05-20 11:29:44 +09:00
import System.Process
import Test.Hspec
import TestUtils
2013-09-03 11:49:35 +09:00
import Dir
2013-02-13 16:22:07 +09:00
spec :: Spec
spec = do
describe "types" $ do
2013-02-13 16:22:07 +09:00
it "shows types of the expression and its outers" $ do
2013-03-05 10:22:33 +09:00
withDirectory_ "test/data/ghc-mod-check" $ do
res <- runD $ types "Data/Foo.hs" 9 5
2013-02-13 16:22:07 +09:00
res `shouldBe` "9 5 11 40 \"Int -> a -> a -> a\"\n7 1 11 40 \"Int -> Integer\"\n"
it "works with a module using TemplateHaskell" $ do
withDirectory_ "test/data" $ do
res <- runD $ types "Bar.hs" 5 1
res `shouldBe` unlines ["5 1 5 20 \"[Char]\""]
it "works with a module that imports another module using TemplateHaskell" $ do
withDirectory_ "test/data" $ do
res <- runD $ types "Main.hs" 3 8
res `shouldBe` unlines ["3 8 3 16 \"String -> IO ()\"", "3 8 3 20 \"IO ()\"", "3 1 3 20 \"IO ()\""]
describe "info" $ do
2013-03-30 21:24:57 +09:00
it "works for non-export functions" $ do
withDirectory_ "test/data" $ do
res <- runD $ info "Info.hs" "fib"
2013-03-30 21:24:57 +09:00
res `shouldSatisfy` ("fib :: Int -> Int" `isPrefixOf`)
2013-04-01 14:19:15 +09:00
it "works with a module using TemplateHaskell" $ do
withDirectory_ "test/data" $ do
res <- runD $ info "Bar.hs" "foo"
res `shouldSatisfy` ("foo :: ExpQ" `isPrefixOf`)
it "works with a module that imports another module using TemplateHaskell" $ do
withDirectory_ "test/data" $ do
res <- runD $ info "Main.hs" "bar"
res `shouldSatisfy` ("bar :: [Char]" `isPrefixOf`)
2013-03-31 17:55:37 +04:00
it "doesn't fail on unicode output" $ do
dir <- getDistDir
code <- rawSystem (dir </> "build/ghc-mod/ghc-mod") ["info", "test/data/Unicode.hs", "Unicode", "unicode"]
2013-03-31 17:55:37 +04:00
code `shouldSatisfy` (== ExitSuccess)
getDistDir :: IO FilePath
getDistDir = takeDirectory . takeDirectory . takeDirectory <$> getExecutablePath