File: Init.hs

package info (click to toggle)
haskell-cabal-install 3.10.3.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,400 kB
  • sloc: haskell: 52,202; sh: 80; makefile: 9
file content (51 lines) | stat: -rw-r--r-- 1,760 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
51
module UnitTests.Distribution.Client.Init
( tests
) where

import Test.Tasty

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

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 }