This project is mirrored from https://github.com/haskell/Cabal.
Pull mirroring updated .
- Feb 08, 2024
-
-
This reverts commit 3f4c81fd.
-
- Feb 07, 2024
-
-
mergify[bot] authored
Bump a number of dependencies
-
f-a authored
-
- Feb 03, 2024
-
-
mergify[bot] authored
Add instruction for CI patches
-
f-a authored
-
mergify[bot] authored
Add static pre-release job
-
Teo Camarasu authored
Co-authored-by:
Artem Pelenitsyn <a.pelenitsyn@gmail.com>
-
Teo Camarasu authored
Add a job that builds a statically linked cabal-install executable, and make it available for pre-releases. Resolves #9631.
-
- Feb 01, 2024
-
-
mergify[bot] authored
Add tests for project imports and constraint version conflicts
-
mergify[bot] authored
Don't inherit package database to tests
-
Matthew Pickering authored
We were attempting to register a package into the global package database, which then triggered some other check to do with relocatable packages to fail. The fix is to initialise and use a local package database, so the package would be built and installed into the local package database.
-
Matthew Pickering authored
I can't think of a reason why it would be desirable to expose the user's cabal store or local dist-newstyle to the test runner. In fact, this can break test output in certain situations depending on what is in your store. Tests should run in as hemertic environment as possible and not depend on anything to do with external system configuration. I have introduced a Note [Testsuite package environments] which explains what the environments are for the three different components of the testsuite. {- Note [Testsuite package environments] There are three different package environments which are used when running the testsuite. 1. Environment used to compile `cabal-tests` executable 2. Environment used to run test scripts "setup.test.hs" 3. Environment made available to tests themselves via `./Setup configure` These are all distinct from each other and should be specified separately. Where are these environments specified: 1. The build-depends on `cabal-tests` executable in `cabal-testsuite.cabal` 2. The build-depends of `test-runtime-deps` executable in `cabal-testsuite.cabal` These dependencies are injected in a special module (`Test.Cabal.ScriptEnv0`) which then is consulted in `Test.Cabal.Monad` in order to pass the right environmnet. This is mechanism by which the `./Setup` tests have access to the in-tree `Cabal` and `Cabal-syntax` libraries. 3. No specification, only the `GlobalPackageDb` is available (see `testPackageDBStack`) unless the test itself augments the environment with `withPackageDb`. At the moment, `cabal-install` tests always use the bootstrap cabal, which is a bit confusing but `cabal-install` is not flexible enough to be given additional package databases (yet). -}
-
Phil de Joux authored
- Allow for bad behaviour of master branch - Add cyclical checks with same file names and hops - Add cyclical import tests with 1 and 2 hops in cycle - Expected output has project with full project path - Add newlines at EOF
-
- Jan 31, 2024
-
-
Phil de Joux authored
-
Phil de Joux authored
-
mergify[bot] authored
Cabal: Allow Win32-2.14
-
Ben Gamari authored
-
mergify[bot] authored
testsuite: Fix hardcoded /bin/bash in custom-cc wrapper
-
Not all operating systems have `/bin/bash` available, it is more portable to use `/usr/bin/env bash` For example: https://stackoverflow.com/questions/21612980/why-is-usr-bin-env-bash-superior-to-bin-bash
-
andreas.abel authored
* Fixup #9614: make config file extraction from help text more robust The previous test (PR #9614) did not work when the config file was absent, because then the help text would add one more line at the end (see issue #535). The new test looks for the exact line printed before the line with the config file. We test both scenarios, with config file present or absent. * Trim lines before searching the marker to work around CRLF issues. --------- Co-authored-by:
mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
-
- Jan 30, 2024
-
-
dependabot[bot] authored
Bumps [haskell-actions/run-fourmolu](https://github.com/haskell-actions/run-fourmolu) from 9 to 10. - [Release notes](https://github.com/haskell-actions/run-fourmolu/releases) - [Changelog](https://github.com/haskell-actions/run-fourmolu/blob/master/CHANGELOG.md) - [Commits](https://github.com/haskell-actions/run-fourmolu/compare/v9...v10 ) --- updated-dependencies: - dependency-name: haskell-actions/run-fourmolu dependency-type: direct:production update-type: version-update:semver-major ... Signed-off-by:
dependabot[bot] <support@github.com> Co-authored-by:
dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
-
- Jan 29, 2024
-
-
mergify[bot] authored
Add further tests of cyclical project imports
-
mergify[bot] authored
Refactor the core component building logic: gbuild vs buildOrReplLib
-
Rodrigo Mesquita authored
1. Refactors the duplicated `buildExtraSources` function from `gbuild` and `buildOrReplLib` into a standalone monadic computation in the context of building a component. This refactor allows us to share the code for building an extra source amongst the two functions. 2. Creates a new module Distribution.Simple.GHC.Build.Modules which, in the same spirit as ...GHC.Build.ExtraModules, defines an action which builds all the Haskell modules of the component being built. This function clarifies and re-implements the logic of building Haskell modules in the different possible ways, while accounting for Template Haskell special "way requirements", which was previously duplicated in a non-obvious manner in gbuild and buildOrReplLib. The Note [Building Haskell modules accounting for TH] in that module explains the big picture, and the implementation is re-done in light of it. 3. Re-work the linker invocations, focusing on preserving existing behaviour before simplifying or fixing bugs any further. Fixes #9389.
-
Rodrigo Mesquita authored
-
Phil de Joux authored
- Assert on exact cyclical import failure message - Add logging and assertOutputContains to cyclical tests - Use a different naming convention for cyclical import tests - Use "self" in naming - Show import tree
-
Phil de Joux authored
-
mergify[bot] authored
Don't build unnecessary targets of legacy-fallback deps.
-
Rodrigo Mesquita authored
The refactor in f70fc980 solved an inconsistency in `buildAndInstallUnpackedPackage`. Namely, before the refactor, we didn't pass `hsSetupBuildArgs` to the build invocations, and afterwards we did. The result is that build targets of (legacy) package `B`, that a package `A` depends on, are now passed to the ./Setup build invocation of package `B` (e.g. `./Setup build lib:openapi3` rather than just `./Setup build`). This means we no longer /build always all targets of a legacy-package/ (for example, the lib, the testsuites and the executables). Instead only the required target (just the lib) will be built. However, despite now passing the build args to `./Setup build`, we weren't passing the same arguments to the `./Setup copy` invocation. Therefore, `./Setup copy` would also try to copy targets of the package that weren't built, resulting in a failure. This fixes that failure by correctly passing the build targets to the `./Setup copy` invocation, just like we do for the `./Setup build` one. Fixes #9640
-
Andrea Bedini authored
This change removes support for building sub-component targets in cabal-install, since no versions of Cabal support this feature. The test RunMainBad is also dropped because without the concept of a file target, RunMainBad is the same test as ScriptBad.
-
mergify[bot] authored
Cabal-syntax: Drop dependencies on unix and Win32
-
Ben Gamari authored
Neither of these dependencies appear to be needed.
-
- Jan 26, 2024
-
-
mergify[bot] authored
Add solver Hackage benchmarks to GitHub Actions (fixes #9495)
-
kristenk authored
-
- Jan 25, 2024
-
-
mergify[bot] authored
Ignore `IntegrationTests2/config/default-config`
-
Tom Smeding authored
* Ignore invalid Unicode in pkg-config descriptions Previously, if any of the pkg-config packages on the system had invalid Unicode in their description fields (like the Intel vpl package has at the time of writing, 2024-01-11, see #9608), cabal would crash because it tried to interpret the entire `pkg-config --list-all` output as Unicode. This change, as suggested by gbaz in https://github.com/haskell/cabal/issues/9608#issuecomment-1886120831 switches to using a lazy ByteString for reading in the output, splitting on the first space in byte land, and then parsing only the package _name_ to a String. For further future-proofing, package names that don't parse as valid Unicode don't crash Cabal, but are instead ignored. * Add changelog entry * cabal-install-solver: Add bounds on 'text' * No literal ASCII values, use 'ord' * Address review comments re invalid unicode from pkg-config * Add test for invalid unicode from pkg-config * Compatibility with text-1.2.5.0 * Align imports * Handle different exception type * Use only POSIX shell syntax * Add invalid-input handler in pkg-config shim This is to appease shellcheck * Actually implement all required stuff in the pkg-config shim * Less exception dance * Fix shebang lines MacOS doesn't have /usr/bin/sh, and /bin/sh is the standard (for a POSIX shell) anyway * Don't expect a particular representation of invalid characters --------- Co-authored-by:
mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
-
- Jan 23, 2024
-
-
Ben Gamari authored
Relax `containers` upper bound in `Cabal-syntax`
-
- Jan 22, 2024
-
-
Phil de Joux authored
-
mergify[bot] authored
Add test cases that reproduce sdist --project-file.
-
f-a authored
-