File: Init.hs

package info (click to toggle)
haskell-cabal-install 3.12.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 3,552 kB
  • sloc: haskell: 65,985; sh: 80; makefile: 5
file content (50 lines) | stat: -rw-r--r-- 1,689 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
module UnitTests.Distribution.Client.Init
  ( tests
  ) where

import Test.Tasty

import qualified UnitTests.Distribution.Client.Init.FileCreators as FileCreators
import qualified UnitTests.Distribution.Client.Init.Golden as Golden
import qualified UnitTests.Distribution.Client.Init.Interactive as Interactive
import qualified UnitTests.Distribution.Client.Init.NonInteractive as NonInteractive
import qualified UnitTests.Distribution.Client.Init.Simple as Simple

import UnitTests.Distribution.Client.Init.Utils

import Distribution.Client.Config
import Distribution.Client.IndexUtils
import Distribution.Client.Init.Types
import Distribution.Client.Sandbox
import Distribution.Client.Setup
import Distribution.Verbosity

tests :: IO [TestTree]
tests = do
  confFlags <- loadConfigOrSandboxConfig v defaultGlobalFlags

  let confFlags' = savedConfigureFlags confFlags `mappend` compFlags
      initFlags' = savedInitFlags confFlags `mappend` emptyFlags
      globalFlags' = savedGlobalFlags confFlags `mappend` defaultGlobalFlags

  (comp, _, progdb) <- configCompilerAux' confFlags'

  withRepoContext v globalFlags' $ \repoCtx -> do
    let pkgDb = configPackageDB' confFlags'

    pkgIx <- getInstalledPackages v comp pkgDb progdb
    srcDb <- getSourcePackages v repoCtx

    return
      [ Interactive.tests v initFlags' pkgIx srcDb
      , NonInteractive.tests v initFlags' comp pkgIx srcDb
      , Golden.tests v initFlags' pkgIx srcDb
      , Simple.tests v initFlags' pkgIx srcDb
      , FileCreators.tests v initFlags' comp pkgIx srcDb
      ]
  where
    v :: Verbosity
    v = normal

    compFlags :: ConfigFlags
    compFlags = mempty{configHcPath = initHcPath emptyFlags}