diff options
| author | Kazu Yamamoto <kazu@iij.ad.jp> | 2013-02-01 11:59:24 +0900 | 
|---|---|---|
| committer | Kazu Yamamoto <kazu@iij.ad.jp> | 2013-02-01 11:59:24 +0900 | 
| commit | 8d4c94ca5a969a5ebbb791939fb0195dc672429e (patch) | |
| tree | 560a944a7105cd715f9acba46790bd7e1a77f82f /tests/html-tests/runtests.hs | |
| parent | 266a20afd2d27f28bbb62839ebc3f70bd83bfcce (diff) | |
| parent | 3d25ea2929a9a9bd0768339b8ac5fd1b7c4670ad (diff) | |
Merge branch 'ghc-7.6' into ghc-7.6-merge-2
Conflicts:
	haddock.cabal
	src/Haddock/Interface/AttachInstances.hs
	src/Haddock/Interface/Create.hs
	src/Haddock/Interface/LexParseRn.hs
	src/Haddock/InterfaceFile.hs
	src/Haddock/Types.hs
Only GHC HEAD can compile this. GHC 7.6.x cannot compile this.
Some test fail.
Diffstat (limited to 'tests/html-tests/runtests.hs')
| -rw-r--r-- | tests/html-tests/runtests.hs | 132 | 
1 files changed, 0 insertions, 132 deletions
| diff --git a/tests/html-tests/runtests.hs b/tests/html-tests/runtests.hs deleted file mode 100644 index 25e53d1a..00000000 --- a/tests/html-tests/runtests.hs +++ /dev/null @@ -1,132 +0,0 @@ -import Control.Monad -import Data.List -import Data.Maybe -import Distribution.InstalledPackageInfo -import Distribution.Package -import Distribution.Simple.Compiler -import Distribution.Simple.GHC -import Distribution.Simple.PackageIndex -import Distribution.Simple.Program -import Distribution.Simple.Utils -import Distribution.Verbosity -import System.Cmd -import System.Directory -import System.Environment -import System.Exit -import System.FilePath -import System.Process -import Text.Printf - - -packageRoot   = "." -haddockPath   = packageRoot </> "dist" </> "build" </> "haddock" </> "haddock" -testSuiteRoot = packageRoot </> "tests" </> "html-tests" -testDir       = testSuiteRoot </> "tests" -outDir        = testSuiteRoot </> "output" - - -main = do -  test -  putStrLn "All tests passed!" - - -test = do -  x <- doesFileExist haddockPath -  unless x $ die "you need to run 'cabal build' successfully first" - -  contents <- getDirectoryContents testDir -  args <- getArgs -  let (opts, spec) = span ("-" `isPrefixOf`) args -  let mods = -        case spec of -          x:_ | x /= "all" -> [x ++ ".hs"] -          _ -> filter ((==) ".hs" . takeExtension) contents - -  let mods' = map (testDir </>) mods -  putStrLn "" -  putStrLn "Haddock version: " -  h1 <- runProcess haddockPath ["--version"] Nothing -                   (Just [("haddock_datadir", packageRoot)]) Nothing Nothing Nothing -  waitForProcess h1 -  putStrLn "" -  putStrLn "GHC version: " -  h2 <- runProcess haddockPath ["--ghc-version"] Nothing -                   (Just [("haddock_datadir", packageRoot)]) Nothing Nothing Nothing -  waitForProcess h2 -  putStrLn "" - -  -- TODO: maybe do something more clever here using haddock.cabal -  ghcPath <- fmap init $ rawSystemStdout normal haddockPath ["--print-ghc-path"] -  (_, conf) <- configure normal (Just ghcPath) Nothing defaultProgramConfiguration -  pkgIndex <- getInstalledPackages normal [GlobalPackageDB] conf -  let safeHead xs = case xs of x : _ -> Just x; [] -> Nothing -  let mkDep pkgName = -        maybe (error "Couldn't find test dependencies") id $ do -          let pkgs = lookupPackageName pkgIndex (PackageName pkgName) -          (_, pkgs') <- safeHead pkgs -          pkg <- safeHead pkgs' -          ifacePath <- safeHead (haddockInterfaces pkg) -          htmlPath <- safeHead (haddockHTMLs pkg) -          return ("-i " ++ htmlPath ++ "," ++ ifacePath) - -  let base    = mkDep "base" -      process = mkDep "process" -      ghcprim = mkDep "ghc-prim" - -  putStrLn "Running tests..." -  handle <- runProcess haddockPath -                       (["-w", "-o", outDir, "-h", "--pretty-html", "--optghc=-fglasgow-exts" -                        , "--optghc=-w", base, process, ghcprim] ++ opts ++ mods') -                       Nothing (Just [("haddock_datadir", packageRoot)]) Nothing -                       Nothing Nothing - -  code <- waitForProcess handle -  when (code /= ExitSuccess) $ error "Haddock run failed! Exiting." -  check mods (if not (null args) && args !! 0 == "all" then False else True) - - -check modules strict = do -  forM_ modules $ \mod -> do -    let outfile = outDir  </> dropExtension mod ++ ".html" -    let reffile = testDir </> dropExtension mod ++ ".html.ref" -    b <- doesFileExist reffile -    if b -      then do -        copyFile reffile (outDir </> takeFileName reffile) -        out <- readFile outfile -        ref <- readFile reffile -        if not $ haddockEq out ref -          then do -            putStrLn $ "Output for " ++ mod ++ " has changed! Exiting with diff:" -            let ref' = stripLinks ref -                out' = stripLinks out -            let reffile' = outDir </> takeFileName reffile ++ ".nolinks" -                outfile' = outDir </> takeFileName outfile ++ ".nolinks" -            writeFile reffile' ref' -            writeFile outfile' out' -            b <- programOnPath "colordiff" -            if b -              then system $ "colordiff " ++ reffile' ++ " " ++ outfile' -              else system $ "diff " ++ reffile' ++ " " ++ outfile' -            if strict then exitFailure else return () -          else do -            putStrLn $ "Pass: " ++ mod -      else do -        putStrLn $ "Pass: " ++ mod ++ " (no .ref file)" - - -haddockEq file1 file2 = stripLinks file1 == stripLinks file2 - -stripLinks str = -  let prefix = "<a href=\"" in -  case stripPrefix prefix str of -    Just str' -> prefix ++ stripLinks (dropWhile (/= '"') str') -    Nothing -> -      case str of -        [] -> [] -        x : xs -> x : stripLinks xs - -programOnPath p = do -  result <- findProgramLocation silent p -  return (isJust result) - | 
