summaryrefslogtreecommitdiff
path: root/testsuite/tests/ghc-regress/cabal/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'testsuite/tests/ghc-regress/cabal/Makefile')
-rw-r--r--testsuite/tests/ghc-regress/cabal/Makefile184
1 files changed, 0 insertions, 184 deletions
diff --git a/testsuite/tests/ghc-regress/cabal/Makefile b/testsuite/tests/ghc-regress/cabal/Makefile
deleted file mode 100644
index a820fb3714..0000000000
--- a/testsuite/tests/ghc-regress/cabal/Makefile
+++ /dev/null
@@ -1,184 +0,0 @@
-TOP=../../..
-include $(TOP)/mk/boilerplate.mk
-include $(TOP)/mk/test.mk
-
-PKGCONF01=local01.package.conf
-LOCAL_GHC_PKG01 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF01)
-
-STRIP_PKGROOT=sed 's/^pkgroot: .*$$/pkgroot: /'
-
-# a bunch of tests for ghc-pkg
-ghcpkg01 :
- @rm -rf $(PKGCONF01)
- $(LOCAL_GHC_PKG01) init $(PKGCONF01)
- $(LOCAL_GHC_PKG01) list
- $(LOCAL_GHC_PKG01) register --force test.pkg 2>/dev/null
- $(LOCAL_GHC_PKG01) describe testpkg | $(STRIP_PKGROOT)
- $(LOCAL_GHC_PKG01) describe testpkg-1.2.3.4 | $(STRIP_PKGROOT)
- $(LOCAL_GHC_PKG01) field testpkg-1.2.3.4 import-dirs
-
- @: # test2.pkg is a later version of testpkg-1.2.3.4
- $(LOCAL_GHC_PKG01) register --force test2.pkg 2>/dev/null
- $(LOCAL_GHC_PKG01) list
- $(LOCAL_GHC_PKG01) describe testpkg-2.0 | $(STRIP_PKGROOT)
- $(LOCAL_GHC_PKG01) describe testpkg-* | $(STRIP_PKGROOT)
- $(LOCAL_GHC_PKG01) field testpkg-* version
-
- @: # test hiding/exposing
- $(LOCAL_GHC_PKG01) hide testpkg-1.2.3.4
- $(LOCAL_GHC_PKG01) field testpkg-1.2.3.4 exposed | grep False
- $(LOCAL_GHC_PKG01) expose testpkg-2.0
- $(LOCAL_GHC_PKG01) field testpkg-2.0 exposed | grep True
- $(LOCAL_GHC_PKG01) hide testpkg-*
- $(LOCAL_GHC_PKG01) field testpkg-* exposed
-
- @: # test3.pkg depends on testpkg-2.0
- $(LOCAL_GHC_PKG01) register test3.pkg
-
- @: # unregistering testpkg-2.0 should fail now, testpkg-3.0 depends on it
- if $(LOCAL_GHC_PKG01) unregister testpkg-2.0; then false; else true; fi
-
- $(LOCAL_GHC_PKG01) unregister testpkg-3.0
-
- $(LOCAL_GHC_PKG01) unregister testpkg-2.0
- $(LOCAL_GHC_PKG01) describe testpkg | $(STRIP_PKGROOT)
- $(LOCAL_GHC_PKG01) unregister testpkg-*
- $(LOCAL_GHC_PKG01) list
-
- @: # registering test3.pkg should fail now, its dependency has gone
- if $(LOCAL_GHC_PKG01) register test3.pkg; then false; else true; fi
-
-PKGCONF03=local03.package.conf
-LOCAL_GHC_PKG03 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF03)
-
-ghcpkg03 :
- @rm -rf $(PKGCONF03)
- $(LOCAL_GHC_PKG03) init $(PKGCONF03)
- @: # update should hide conflicting packages
- $(LOCAL_GHC_PKG03) register --force test.pkg
- $(LOCAL_GHC_PKG03) register --force test2.pkg
-
- @: # test4.pkg depends on testpkg-2.0, which conflicts with testpkg-1.2.3.4,
- @: # ghc-pkg will happily register it now (it didn't in GHC 6.4)
- $(LOCAL_GHC_PKG03) register test4.pkg
- $(LOCAL_GHC_PKG03) update test4.pkg
-
- @: # and another update of test.pkg will now hide dep-2.0
- $(LOCAL_GHC_PKG03) update --force test.pkg
-
-PKGCONF04=local04.package.conf
-LOCAL_GHC_PKG04 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF04)
-
-# Test that importing a module exposed by two packages reports a conflict
-ghcpkg04 :
- rm -rf $(PKGCONF04)
- $(LOCAL_GHC_PKG04) init $(PKGCONF04)
- $(LOCAL_GHC_PKG04) register --force test.pkg >/dev/null 2>&1
- $(LOCAL_GHC_PKG04) update --force test5.pkg >/dev/null 2>&1
- $(LOCAL_GHC_PKG04) expose testpkg-1.2.3.4 >/dev/null 2>&1
- @: # testpkg-1.2.3.4 and newtestpkg-2.0 are both exposed now
- '$(TEST_HC)' $(TEST_HC_OPTS) -package-conf $(PKGCONF04) -c ghcpkg04.hs || true
-
-# Test stacking of package.confs (also #2441)
-PKGCONF05a=local05a.package.conf
-PKGCONF05b=local05b.package.conf
-LOCAL_GHC_PKG05a = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF05a)
-LOCAL_GHC_PKG05b = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF05a) -f $(PKGCONF05b)
-
-ghcpkg05 :
- rm -rf $(PKGCONF05a) $(PKGCONF05b)
- $(LOCAL_GHC_PKG05a) init $(PKGCONF05a)
- $(LOCAL_GHC_PKG05b) init $(PKGCONF05b)
- $(LOCAL_GHC_PKG05a) register --force test2.pkg >/dev/null 2>&1
- $(LOCAL_GHC_PKG05b) register --force test3.pkg >/dev/null 2>&1
- $(LOCAL_GHC_PKG05b) check || true
- $(LOCAL_GHC_PKG05b) list
- $(LOCAL_GHC_PKG05b) expose testpkg-2.0
- $(LOCAL_GHC_PKG05b) hide testpkg-2.0
- if $(LOCAL_GHC_PKG05b) unregister testpkg-2.0; then false; else true; fi
- $(LOCAL_GHC_PKG05b) unregister testpkg-3.0
- $(LOCAL_GHC_PKG05b) unregister testpkg-2.0
-
-# Test for #2330: reject duplicate dependencies
-PKGCONF06=local06.package.conf
-LOCAL_GHC_PKG06 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF06)
-
-ghcpkg06 :
- rm -rf $(PKGCONF06)
- $(LOCAL_GHC_PKG06) init $(PKGCONF06)
- $(LOCAL_GHC_PKG06) register --force test.pkg >/dev/null 2>&1
- if $(LOCAL_GHC_PKG06) register testdup.pkg; then false else true; fi
- $(LOCAL_GHC_PKG06) register --force testdup.pkg
-
-PKGCONF1750=local1750.package.conf
-LOCAL_GHC_PKG1750 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONF1750)
-
-1750:
- rm -rf $(PKGCONF1750) 1750.hs 1750.o 1750.hi 1750.out
- $(LOCAL_GHC_PKG1750) init $(PKGCONF1750)
- $(LOCAL_GHC_PKG1750) register --force 1750A.pkg >1750.out 2>&1
- $(LOCAL_GHC_PKG1750) register --force 1750B.pkg >1750.out 2>&1
- GHC_PACKAGE_PATH=$(PKGCONF1750) '$(GHC_PKG)' --no-user-package-conf list
-# GHC_PACKAGE_PATH trick is to make this work with 6.8.2 which doesn't have
-# the patch "Change the command-line semantics for query commands" to
-# ghc-pkg
- echo "main = return ()" >1750.hs
- '$(TEST_HC)' $(TEST_HC_OPTS) -package-conf $(PKGCONF1750) -package 1750A 1750.hs || true
-
-PKGCONFSHADOW1=localshadow1.package.conf
-PKGCONFSHADOW2=localshadow2.package.conf
-LOCAL_GHC_PKGSHADOW1 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONFSHADOW1)
-LOCAL_GHC_PKGSHADOW2 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONFSHADOW2)
-LOCAL_GHC_PKGSHADOW3 = '$(GHC_PKG)' --no-user-package-conf -f $(PKGCONFSHADOW1) -f $(PKGCONFSHADOW2)
-
-# Test package shadowing behaviour.
-#
-# localshadow1.package.conf: shadowdep-1-XXX <- shadow-1-XXX
-# localshadow2.package.conf: shadow-1-YYY
-#
-# shadow-1-XXX will be shadowed by shadow-1-YYY, thus invalidating
-# shadowdep-1-XXX.
-shadow:
- rm -rf $(PKGCONFSHADOW1) $(PKGCONFSHADOW2) shadow.hs shadow.o shadow.hi shadow.out shadow.hs shadow.hi
- $(LOCAL_GHC_PKGSHADOW1) init $(PKGCONFSHADOW1)
- $(LOCAL_GHC_PKGSHADOW2) init $(PKGCONFSHADOW2)
- $(LOCAL_GHC_PKGSHADOW1) register --force shadow1.pkg >shadow1.out 2>&1
- $(LOCAL_GHC_PKGSHADOW1) register --force shadow2.pkg >shadow2.out 2>&1
- $(LOCAL_GHC_PKGSHADOW2) register --force shadow3.pkg >shadow3.out 2>&1
- $(LOCAL_GHC_PKGSHADOW3) list
- echo "main = return ()" >shadow.hs
-#
-# In this test, shadow-1-XXX is shadowed by shadow-1-YYY, which causes
-# shadowdep-1-XXX to be unavailable:
-#
- @echo "should FAIL:"
- '$(TEST_HC)' $(TEST_HC_OPTS) -package-conf $(PKGCONFSHADOW1) -package-conf $(PKGCONFSHADOW2) -package shadowdep -c shadow.hs -fno-code || true
-#
-# Reversing the order of the package.conf files should fix the problem:
-#
- @echo "should SUCCEED:"
- '$(TEST_HC)' $(TEST_HC_OPTS) -package-conf $(PKGCONFSHADOW2) -package-conf $(PKGCONFSHADOW1) -package shadowdep -c shadow.hs -fno-code || true
-#
-# We can also fix the problem by using an explicit -package-id flag to
-# specify a package we really want to use:
-#
- @echo "should SUCCEED:"
- '$(TEST_HC)' $(TEST_HC_OPTS) -package-conf $(PKGCONFSHADOW1) -package-conf $(PKGCONFSHADOW2) -package-id shadowdep-1-XXX -c shadow.hs -fno-code
-
-
-# -----------------------------------------------------------------------------
-# Try piping the output of "ghc-pkg describe" into "ghc-pkg update" for
-# every package we know about. This is for testing the pretty printing/parsing
-# of InstalledPackageInfo.
-
-PACKAGE_CONF_ghcpkg02 = package.conf.ghcpkg02
-GHC_PKG_ghcpkg02 = '$(GHC_PKG)' --no-user-package-conf --global-conf=$(PACKAGE_CONF_ghcpkg02)
-
-ghcpkg02:
- rm -rf $(PACKAGE_CONF_ghcpkg02)
- $(GHC_PKG_ghcpkg02) init $(PACKAGE_CONF_ghcpkg02)
- set -e; \
- for i in `$(GHC_PKG) list --global --simple-output -v0`; do \
- echo Updating $$i; \
- $(GHC_PKG) describe --global $$i | $(GHC_PKG_ghcpkg02) update --global --force -; \
- done