Skip to content

Commit

Permalink
Add FileCreators.generateCabalFile unit tests.
Browse files Browse the repository at this point in the history
  • Loading branch information
m-renaud committed Apr 10, 2020
1 parent a09afa7 commit 696291b
Show file tree
Hide file tree
Showing 7 changed files with 214 additions and 1 deletion.
3 changes: 3 additions & 0 deletions cabal-install/Distribution/Client/Init/FileCreators.hs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,9 @@ module Distribution.Client.Init.FileCreators (
, createMainHs
, createTestSuiteIfEligible
, writeCabalFile

-- * For testing
, generateCabalFile
) where

import Prelude ()
Expand Down
2 changes: 2 additions & 0 deletions cabal-install/cabal-install.cabal
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,8 @@ Extra-Source-Files:
tests/IntegrationTests2/targets/tests-disabled/q/q.cabal
tests/IntegrationTests2/targets/variety/cabal.project
tests/IntegrationTests2/targets/variety/p.cabal
tests/UnitTests/Distribution/Client/Init/goldens/generateCabalFile/exe-only.cabal
tests/UnitTests/Distribution/Client/Init/goldens/generateCabalFile/lib-exe-and-test.cabal
-- END gen-extra-source-files

-- Additional manual extra-source-files:
Expand Down
4 changes: 4 additions & 0 deletions cabal-install/cabal-install.cabal.pp
Original file line number Diff line number Diff line change
Expand Up @@ -370,6 +370,8 @@
tests/IntegrationTests2/targets/tests-disabled/q/q.cabal
tests/IntegrationTests2/targets/variety/cabal.project
tests/IntegrationTests2/targets/variety/p.cabal
tests/UnitTests/Distribution/Client/Init/goldens/generateCabalFile/exe-only.cabal
tests/UnitTests/Distribution/Client/Init/goldens/generateCabalFile/lib-exe-and-test.cabal
-- END gen-extra-source-files
-- Additional manual extra-source-files:
Expand Down Expand Up @@ -475,6 +477,7 @@
UnitTests.Distribution.Client.GenericInstances
UnitTests.Distribution.Client.Glob
UnitTests.Distribution.Client.GZipUtils
UnitTests.Distribution.Client.Init.FileCreators
UnitTests.Distribution.Client.Sandbox
UnitTests.Distribution.Client.Sandbox.Timestamp
UnitTests.Distribution.Client.Store
Expand Down Expand Up @@ -515,6 +518,7 @@
network-uri < 2.6.2.0,
network,
tasty >= 1.2.3 && <1.3,
tasty-golden >=2.3.1.1 && <2.4,
tasty-hunit >= 0.10,
tasty-quickcheck,
tagged,
Expand Down
4 changes: 3 additions & 1 deletion cabal-install/tests/UnitTests.hs
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import qualified UnitTests.Distribution.Client.Described
import qualified UnitTests.Distribution.Client.FileMonitor
import qualified UnitTests.Distribution.Client.Glob
import qualified UnitTests.Distribution.Client.GZipUtils
import qualified UnitTests.Distribution.Client.Init.FileCreators
import qualified UnitTests.Distribution.Client.Sandbox
import qualified UnitTests.Distribution.Client.Sandbox.Timestamp
import qualified UnitTests.Distribution.Client.Store
Expand Down Expand Up @@ -55,6 +56,8 @@ tests mtimeChangeCalibrated =
UnitTests.Distribution.Client.Glob.tests
, testGroup "Distribution.Client.GZipUtils"
UnitTests.Distribution.Client.GZipUtils.tests
, testGroup "Distribution.Client.Init.FileCreators"
UnitTests.Distribution.Client.Init.FileCreators.tests
, testGroup "Distribution.Client.Sandbox"
UnitTests.Distribution.Client.Sandbox.tests
, testGroup "Distribution.Client.Sandbox.Timestamp"
Expand Down Expand Up @@ -95,4 +98,3 @@ main = do
defaultMainWithIngredients
(includingOptions extraOptions : defaultIngredients)
(tests mtimeChange')

157 changes: 157 additions & 0 deletions cabal-install/tests/UnitTests/Distribution/Client/Init/FileCreators.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
module UnitTests.Distribution.Client.Init.FileCreators (
tests
) where

import Distribution.Client.Init.FileCreators
( generateCabalFile )

import Test.Tasty
import Test.Tasty.Golden (goldenVsString)
import Test.Tasty.HUnit

import System.FilePath
( (</>) )
import qualified Data.ByteString.Lazy as BS
import qualified Data.ByteString.Lazy.Char8 as BS8
import qualified Data.Set as Set

import Distribution.Client.Init.Types
( InitFlags(..), PackageType(..) )
import Distribution.Simple.Setup
( Flag(..) )

import Distribution.CabalSpecVersion
( CabalSpecVersion(CabalSpecV2_4) )
import Distribution.Types.Dependency
( Dependency, mkDependency )
import Distribution.Types.LibraryName
( LibraryName(LMainLibName) )
import Distribution.Types.PackageName
( mkPackageName )
import Distribution.Types.VersionRange
( majorBoundVersion )
import Distribution.Types.Version
( mkVersion )
import qualified Distribution.ModuleName as ModuleName
( fromString )
import qualified Distribution.SPDX as SPDX
import Language.Haskell.Extension ( Language(..) )

tests :: [TestTree]
tests = [ testGroup "cabal init goldens"
[ checkCabalFileGolden exeFlags "exe-only.cabal"
, checkCabalFileGolden libExeAndTestFlags "lib-exe-and-test.cabal"
]
]

checkCabalFileGolden :: InitFlags -> FilePath -> TestTree
checkCabalFileGolden flags goldenFileName =
goldenVsString goldenFileName goldenFilePath generatedCabalFile
where
inGoldensDir :: FilePath -> FilePath
inGoldensDir fn =
"tests" </> "UnitTests" </> "Distribution" </> "Client" </> "Init" </>
"goldens" </> "generateCabalFile" </> fn

goldenFilePath :: FilePath
goldenFilePath = inGoldensDir goldenFileName

generatedCabalFile :: IO BS.ByteString
generatedCabalFile = pure . BS8.pack $ generateCabalFile goldenFileName flags

-- ==================================================
-- Simple exe.

exeFlags :: InitFlags
exeFlags = InitFlags {
packageName = Flag (mkPackageName "foo")
, noComments = Flag False
, minimal = Flag True
, version = Flag (mkVersion [3,2,1])
, synopsis = Flag "The foo package"
, homepage = Flag "https://github.com/foo/foo"
, license = Flag SPDX.NONE
, author = Flag "me"
, email = Flag "me@me.me"
, category = Flag (Left "SomeCat")
, cabalVersion = Flag CabalSpecV2_4
, extraSrc = Just ["CHANGELOG.md"]
, interactive = Flag False
, mainIs = Flag "Main.hs"
, otherModules = Nothing
, otherExts = Nothing
, applicationDirs = Just ["app"]
, language = Flag Haskell2010
, buildTools = Nothing
, packageType = Flag Executable
, initializeTestSuite = Flag False
, exposedModules = Nothing
, sourceDirs = Nothing
, testDirs = Nothing
, dependencies = Just testDependencies
, quiet = Flag True
, packageDir = NoFlag
, simpleProject = Flag False
, initHcPath = NoFlag
, initVerbosity = NoFlag
, overwrite = NoFlag
}


-- ==================================================
-- Lib, exe, and test suite

libExeAndTestFlags :: InitFlags
libExeAndTestFlags = InitFlags {
packageName = Flag (mkPackageName "foo")
, noComments = Flag False
, minimal = Flag True
, version = Flag (mkVersion [3,2,1])
, synopsis = Flag "The foo package"
, homepage = Flag "https://github.com/foo/foo"
, license = Flag SPDX.NONE
, author = Flag "me"
, email = Flag "me@me.me"
, category = Flag (Left "SomeCat")
, cabalVersion = Flag CabalSpecV2_4
, extraSrc = Just ["CHANGELOG.md"]
, interactive = Flag False
, mainIs = Flag "Main.hs"
, otherModules = Nothing
, otherExts = Nothing
, applicationDirs = Just ["app"]
, language = Flag Haskell2010
, buildTools = Nothing
, packageType = Flag LibraryAndExecutable
, initializeTestSuite = Flag True
, exposedModules = Just (map ModuleName.fromString ["A", "B"])
, sourceDirs = Just ["src"]
, testDirs = Just ["tests"]
, dependencies = Just testDependencies
, quiet = Flag True
, packageDir = NoFlag
, simpleProject = Flag False
, initHcPath = NoFlag
, initVerbosity = NoFlag
, overwrite = NoFlag
}


-- ==================================================
-- Test dependency.

testDependencies :: [Dependency]
testDependencies =
[ mkDependency
(mkPackageName "base")
(majorBoundVersion (mkVersion [4,13,0,0]))
(Set.singleton LMainLibName)
, mkDependency
(mkPackageName "containers")
(majorBoundVersion (mkVersion [5,7,0,0]))
(Set.singleton LMainLibName)
, mkDependency
(mkPackageName "unordered-containers")
(majorBoundVersion (mkVersion [2,7,0,0]))
(Set.singleton LMainLibName)
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
cabal-version: 2.4
name: foo
version: 3.2.1
synopsis: The foo package
homepage: https://github.com/foo/foo
license: NONE
author: me
maintainer: me@me.me
category: SomeCat
extra-source-files: CHANGELOG.md

executable foo
main-is: Main.hs
build-depends: base ^>=4.13.0.0, containers ^>=5.7.0.0, unordered-containers ^>=2.7.0.0
hs-source-dirs: app
default-language: Haskell2010
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
cabal-version: 2.4
name: foo
version: 3.2.1
synopsis: The foo package
homepage: https://github.com/foo/foo
license: NONE
author: me
maintainer: me@me.me
category: SomeCat
extra-source-files: CHANGELOG.md

library
exposed-modules: A, B
build-depends: base ^>=4.13.0.0, containers ^>=5.7.0.0, unordered-containers ^>=2.7.0.0
hs-source-dirs: src
default-language: Haskell2010

executable foo
main-is: Main.hs
build-depends: base ^>=4.13.0.0, containers ^>=5.7.0.0, unordered-containers ^>=2.7.0.0
hs-source-dirs: app
default-language: Haskell2010

test-suite foo-test
default-language: Haskell2010
type: exitcode-stdio-1.0
hs-source-dirs: tests
main-is: MyLibTest.hs
build-depends: base ^>=4.13.0.0, containers ^>=5.7.0.0, unordered-containers ^>=2.7.0.0

0 comments on commit 696291b

Please sign in to comment.