mirror of
https://github.com/ostreedev/ostree.git
synced 2025-01-10 05:18:30 +03:00
361aa449fb
For rpm-ostree, we already link to libcurl indirectly via librepo, and only having one HTTP library in process makes sense. Further, libcurl is (I think) more popular in the embedded space. It also supports HTTP/2.0 today, which is a *very* nice to have for OSTree. This seems to be working fairly well for me in my local testing, but it's obviously brand new nontrivial code, so it's going to need some soak time. The ugliest part of this is having to vendor in the soup-url code. With Oxidation we could follow the path of Firefox and use the [Servo URL parser](https://github.com/servo/rust-url). Having to redo cookie parsing also sucked, and that would also be a good oxidation target. But that's for the future. Closes: #641 Approved by: jlebon
72 lines
2.5 KiB
Bash
Executable File
72 lines
2.5 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# Copyright (C) 2013 Jeremy Whiting <jeremy.whiting@collabora.com>
|
|
# Copyright (C) 2016 Sjoerd Simons <sjoerd@luon.net>
|
|
#
|
|
# 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
|
|
|
|
echo '1..4'
|
|
|
|
. $(dirname $0)/libtest.sh
|
|
|
|
setup_fake_remote_repo1 "archive-z2" "" \
|
|
"--expected-cookies foo=bar --expected-cookies baz=badger"
|
|
|
|
assert_fail (){
|
|
if $@; then
|
|
(echo 1>&2 "$@ did not fail"; exit 1)
|
|
fi
|
|
}
|
|
|
|
cd ${test_tmpdir}
|
|
rm repo -rf
|
|
mkdir repo
|
|
${CMD_PREFIX} ostree --repo=repo init
|
|
${CMD_PREFIX} ostree --repo=repo remote add --set=gpg-verify=false origin $(cat httpd-address)/ostree/gnomerepo
|
|
|
|
# Sanity check the setup, without cookies the pull should fail
|
|
assert_fail ${CMD_PREFIX} ostree --repo=repo pull origin main
|
|
|
|
echo "ok, setup done"
|
|
|
|
# Add 2 cookies, pull should succeed now
|
|
${CMD_PREFIX} ostree --repo=repo remote add-cookie origin 127.0.0.1 / foo bar
|
|
${CMD_PREFIX} ostree --repo=repo remote add-cookie origin 127.0.0.1 / baz badger
|
|
assert_file_has_content repo/origin.cookies.txt foo.*bar
|
|
assert_file_has_content repo/origin.cookies.txt baz.*badger
|
|
${CMD_PREFIX} ostree --repo=repo pull origin main
|
|
|
|
echo "ok, initial cookie pull succeeded"
|
|
|
|
# Delete one cookie, if successful pulls will fail again
|
|
${CMD_PREFIX} ostree --repo=repo remote delete-cookie origin 127.0.0.1 / baz badger
|
|
assert_file_has_content repo/origin.cookies.txt foo.*bar
|
|
assert_not_file_has_content repo/origin.cookies.txt baz.*badger
|
|
assert_fail ${CMD_PREFIX} ostree --repo=repo pull origin main
|
|
|
|
echo "ok, delete succeeded"
|
|
|
|
# Re-add the removed cooking and things succeed again, verified the removal
|
|
# removed exactly one cookie
|
|
${CMD_PREFIX} ostree --repo=repo remote add-cookie origin 127.0.0.1 / baz badger
|
|
assert_file_has_content repo/origin.cookies.txt foo.*bar
|
|
assert_file_has_content repo/origin.cookies.txt baz.*badger
|
|
${CMD_PREFIX} ostree --repo=repo pull origin main
|
|
|
|
echo "ok, second cookie pull succeeded"
|