]> git.saurik.com Git - apt.git/blobdiff - test/test-indexes.sh
move sha512,256 into apt-pkg/sha2.{cc,h}, move gifford implementation to sha2_interna...
[apt.git] / test / test-indexes.sh
index ce2c36481d8e6c8a4317d83ddf982c3ca1a6886e..50d54f691545f98a6290bbb11a2e0214207fef1d 100755 (executable)
@@ -21,6 +21,7 @@ DEBUG=""
 #DEBUG="-o Debug::pkgAcquire=true"
 APT_GET="$BUILDDIR/bin/apt-get $OPTS $DEBUG"
 APT_CACHE="$BUILDDIR/bin/apt-cache $OPTS $DEBUG"
 #DEBUG="-o Debug::pkgAcquire=true"
 APT_GET="$BUILDDIR/bin/apt-get $OPTS $DEBUG"
 APT_CACHE="$BUILDDIR/bin/apt-cache $OPTS $DEBUG"
+APT_FTPARCHIVE="$BUILDDIR/bin/apt-ftparchive"
 
 [ -x "$BUILDDIR/bin/apt-get" ] || {
     echo "please build the tree first" >&2
 
 [ -x "$BUILDDIR/bin/apt-get" ] || {
     echo "please build the tree first" >&2
@@ -79,9 +80,9 @@ check_cache() {
     # again (with cache)
     $APT_CACHE show $TEST_PKG | grep -q ^Version:
     rm var/cache/apt/*.bin
     # again (with cache)
     $APT_CACHE show $TEST_PKG | grep -q ^Version:
     rm var/cache/apt/*.bin
-    $APT_CACHE policy $TEST_PKG | grep -q '500 http://'
+    $APT_CACHE policy $TEST_PKG | egrep -q '500 (http://|file:/)'
     # again (with cache)
     # again (with cache)
-    $APT_CACHE policy $TEST_PKG | grep -q '500 http://'
+    $APT_CACHE policy $TEST_PKG | egrep -q '500 (http://|file:/)'
 
     TEST_SRC=`$APT_CACHE show $TEST_PKG | grep ^Source: | awk '{print $2}'`
     rm var/cache/apt/*.bin
 
     TEST_SRC=`$APT_CACHE show $TEST_PKG | grep ^Source: | awk '{print $2}'`
     rm var/cache/apt/*.bin
@@ -103,7 +104,8 @@ check_install() {
 # test apt-get source
 check_get_source() {
     echo "--- apt-get source"
 # test apt-get source
 check_get_source() {
     echo "--- apt-get source"
-    $APT_GET source $TEST_PKG
+    # quiesce: it'll complain about not being able to verify the signature
+    $APT_GET source $TEST_PKG >/dev/null 2>&1
     test -f $TEST_SRC_*.dsc
     test -d $TEST_SRC-*
     rm -r $TEST_SRC*
     test -f $TEST_SRC_*.dsc
     test -d $TEST_SRC-*
     rm -r $TEST_SRC*
@@ -130,10 +132,19 @@ echo "deb-src $TEST_SOURCE" >> etc/apt/sources.list
 # specifying -o RootDir at the command line does not work for
 # etc/apt/apt.conf.d/ since it is parsed after pkgInitConfig(); $APT_CONFIG is
 # checked first, so this works
 # specifying -o RootDir at the command line does not work for
 # etc/apt/apt.conf.d/ since it is parsed after pkgInitConfig(); $APT_CONFIG is
 # checked first, so this works
-echo 'RootDir ".";' > apt_config
+echo "RootDir \"$WORKDIR\";" > apt_config
 export APT_CONFIG=`pwd`/apt_config
 
 export APT_CONFIG=`pwd`/apt_config
 
+echo "==== no indexes ===="
+echo '--- apt-get check works without indexes'
+[ -z `$APT_GET check` ]
+echo '--- apt-cache policy works without indexes'
+$APT_CACHE policy bash >/dev/null
+echo '--- apt-cache show works without indexes'
+! LC_MESSAGES=C $APT_CACHE show bash 2>&1| grep -q 'E: No packages found'
+
 echo "===== uncompressed indexes ====="
 echo "===== uncompressed indexes ====="
+echo 'Acquire::GzipIndexes "false";' > etc/apt/apt.conf.d/02compress-indexes
 check_update
 check_indexes
 check_cache
 check_update
 check_indexes
 check_cache
@@ -189,4 +200,36 @@ $APT_GET -o Acquire::PDiffs=true update
 check_indexes compressed
 check_cache
 
 check_indexes compressed
 check_cache
 
+rm etc/apt/apt.conf.d/02compress-indexes
+
+echo "==== apt-ftparchive ===="
+mkdir arch
+$APT_GET install -d $TEST_PKG 
+cp var/cache/apt/archives/$TEST_PKG*.deb arch/
+cd arch
+$APT_GET source -d $TEST_PKG >/dev/null 2>&1
+$APT_FTPARCHIVE packages . | gzip -9 > Packages.gz
+$APT_FTPARCHIVE sources . | gzip -9 > Sources.gz
+cd ..
+
+echo "deb file://$WORKDIR/arch /
+deb-src file://$WORKDIR/arch /" > etc/apt/sources.list
+$APT_GET clean
+
+echo "==== uncompressed indexes from local file:// archive ===="
+echo "--- apt-get update"
+$APT_GET update
+check_indexes
+check_cache
+check_get_source
+
+echo "==== compressed indexes from local file:// archive ===="
+echo "--- apt-get update"
+$APT_GET -o Acquire::GzipIndexes=true update
+# EXFAIL: file:/ URIs currently decompress even with above option
+#check_indexes compressed
+check_indexes
+check_cache
+check_get_source
+
 echo "===== ALL TESTS PASSED ====="
 echo "===== ALL TESTS PASSED ====="