summaryrefslogtreecommitdiffstats
path: root/test/pacman
diff options
context:
space:
mode:
Diffstat (limited to 'test/pacman')
-rw-r--r--test/pacman/meson.build2
-rw-r--r--test/pacman/tests/upgrade-download-with-xfercommand.py26
2 files changed, 28 insertions, 0 deletions
diff --git a/test/pacman/meson.build b/test/pacman/meson.build
index 6c28bd7d..0e75b3ee 100644
--- a/test/pacman/meson.build
+++ b/test/pacman/meson.build
@@ -333,6 +333,7 @@ pacman_tests = [
'tests/upgrade-download-404.py',
'tests/upgrade-download-pkg-and-sig-with-filename.py',
'tests/upgrade-download-pkg-and-sig-without-filename.py',
+ 'tests/upgrade-download-with-xfercommand.py',
]
xfail_tests = {
@@ -344,6 +345,7 @@ xfail_tests = {
'tests/sync403.py': true,
'tests/sync406.py': true,
'tests/upgrade078.py': true,
+ 'tests/upgrade-download-with-xfercommand.py': true,
}
foreach input : pacman_tests
diff --git a/test/pacman/tests/upgrade-download-with-xfercommand.py b/test/pacman/tests/upgrade-download-with-xfercommand.py
new file mode 100644
index 00000000..03ce4819
--- /dev/null
+++ b/test/pacman/tests/upgrade-download-with-xfercommand.py
@@ -0,0 +1,26 @@
+self.description = "--upgrade remote packages with XferCommand"
+
+self.option['XferCommand'] = ['/usr/bin/curl %u -o %o']
+
+p1 = pmpkg('pkg1', '1.0-1')
+self.addpkg(p1)
+
+p2 = pmpkg('pkg2', '2.0-2')
+self.addpkg(p2)
+
+url = self.add_simple_http_server({
+ '/{}'.format(p1.filename()): p1.makepkg_bytes(),
+ '/{}'.format(p2.filename()): p2.makepkg_bytes(),
+})
+
+self.args = '-U {url}/{} {url}/{}'.format(p1.filename(), p2.filename(), url=url)
+
+self.addrule("PACMAN_RETCODE=0")
+self.addrule("PKG_EXIST=pkg1")
+self.addrule("PKG_EXIST=pkg2")
+self.addrule("CACHE_EXISTS=pkg1|1.0-1")
+self.addrule("CACHE_EXISTS=pkg2|2.0-2")
+
+# --upgrade fails hard with XferCommand because the fetch callback has no way
+# to return the file path to alpm
+self.expectfailure = True