summaryrefslogtreecommitdiff
path: root/testsuite/tests/cabal/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'testsuite/tests/cabal/Makefile')
-rw-r--r--testsuite/tests/cabal/Makefile184
1 files changed, 184 insertions, 0 deletions
diff --git a/testsuite/tests/cabal/Makefile b/testsuite/tests/cabal/Makefile
new file mode 100644
index 0000000000..a036d820dd
--- /dev/null
+++ b/testsuite/tests/cabal/Makefile
@@ -0,0 +1,184 @@
+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