mirror of
https://github.com/ostreedev/ostree.git
synced 2024-12-22 17:35:55 +03:00
tests: Add a test for ostree pull --url
Closes: #271 Approved by: cgwalters
This commit is contained in:
parent
a6ce162231
commit
c2931583d3
@ -51,6 +51,7 @@ test_scripts = \
|
||||
tests/test-pull-summary-sigs.sh \
|
||||
tests/test-pull-resume.sh \
|
||||
tests/test-pull-untrusted.sh \
|
||||
tests/test-pull-override-url.sh \
|
||||
tests/test-local-pull.sh \
|
||||
tests/test-local-pull-depth.sh \
|
||||
tests/test-gpg-signed-commit.sh \
|
||||
|
80
tests/test-pull-override-url.sh
Executable file
80
tests/test-pull-override-url.sh
Executable file
@ -0,0 +1,80 @@
|
||||
#!/bin/bash
|
||||
#
|
||||
# Copyright (C) 2016 Endless Mobile, Inc.
|
||||
#
|
||||
# This library is free software; you can redistribute it and/or
|
||||
# modify it under the terms of the GNU Lesser General Public
|
||||
# License as published by the Free Software Foundation; either
|
||||
# version 2 of the License, or (at your option) any later version.
|
||||
#
|
||||
# This library is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
# Lesser General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU Lesser General Public
|
||||
# License along with this library; if not, write to the
|
||||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
||||
# Boston, MA 02111-1307, USA.
|
||||
|
||||
set -euo pipefail
|
||||
|
||||
. $(dirname $0)/libtest.sh
|
||||
|
||||
setup_fake_remote_repo1 "archive-z2"
|
||||
|
||||
echo '1..1'
|
||||
|
||||
cd ${test_tmpdir}
|
||||
# get a list of XX/XXXXXXX...XX.commit
|
||||
find ostree-srv/gnomerepo/objects -name '*.commit' | cut -d/ -f4- | sort >${test_tmpdir}/original_commits
|
||||
|
||||
|
||||
gnomerepo_url="$(cat httpd-address)/ostree/gnomerepo"
|
||||
mkdir mirror-srv
|
||||
cd mirror-srv
|
||||
mkdir gnomerepo
|
||||
${CMD_PREFIX} ostree --repo=gnomerepo init --mode "archive-z2"
|
||||
${CMD_PREFIX} ostree --repo=gnomerepo remote add --set=gpg-verify=false origin ${gnomerepo_url}
|
||||
${CMD_PREFIX} ostree --repo=gnomerepo pull --mirror --depth=-1 origin main
|
||||
|
||||
find gnomerepo/objects -name '*.commit' | cut -d/ -f3- | sort >${test_tmpdir}/mirror_commits
|
||||
|
||||
if ! cmp --quiet ${test_tmpdir}/original_commits ${test_tmpdir}/mirror_commits
|
||||
then
|
||||
assert_not_reached 'original repository and its mirror should have the same commits'
|
||||
fi
|
||||
|
||||
cd ${test_tmpdir}
|
||||
mkdir mirror-httpd
|
||||
cd mirror-httpd
|
||||
ln -s ${test_tmpdir}/mirror-srv ostree
|
||||
mirror_log="${test_tmpdir}/mirror_log"
|
||||
${CMD_PREFIX} ostree trivial-httpd --log-file=${mirror_log} --autoexit --daemonize -p ${test_tmpdir}/mirror-httpd-port
|
||||
port=$(cat ${test_tmpdir}/mirror-httpd-port)
|
||||
echo "http://127.0.0.1:${port}" > ${test_tmpdir}/mirror-httpd-address
|
||||
|
||||
cd ${test_tmpdir}
|
||||
mirrorrepo_url="$(cat mirror-httpd-address)/ostree/gnomerepo"
|
||||
mkdir repo
|
||||
${CMD_PREFIX} ostree --repo=repo init
|
||||
${CMD_PREFIX} ostree --repo=repo remote add --set=gpg-verify=false origin ${gnomerepo_url}
|
||||
rm -rf ${test_tmpdir}/ostree-srv/gnomerepo
|
||||
if ${CMD_PREFIX} ostree --repo=repo pull --depth=-1 origin main
|
||||
then
|
||||
assert_not_reached 'pulling from removed remote should have failed'
|
||||
fi
|
||||
|
||||
if ! ${CMD_PREFIX} ostree --repo=repo pull --depth=-1 --url=${mirrorrepo_url} origin main
|
||||
then
|
||||
cat ${mirror_log}
|
||||
assert_not_reached 'fetching from the overridden URL should succeed'
|
||||
fi
|
||||
find repo/objects -name '*.commit' | cut -d/ -f3- | sort >${test_tmpdir}/repo_commits
|
||||
|
||||
if ! cmp --quiet ${test_tmpdir}/original_commits ${test_tmpdir}/repo_commits
|
||||
then
|
||||
assert_not_reached 'original repository and its mirror should have the same commits'
|
||||
fi
|
||||
|
||||
echo "ok pull url override"
|
Loading…
Reference in New Issue
Block a user