]> git.ipfire.org Git - thirdparty/git.git/commitdiff
t5510: replace 'origin' with URL more carefully
authorDerrick Stolee <derrickstolee@github.com>
Mon, 20 Jun 2022 19:52:09 +0000 (15:52 -0400)
committerJunio C Hamano <gitster@pobox.com>
Tue, 21 Jun 2022 17:35:38 +0000 (10:35 -0700)
The many test_configured_prune tests in t5510-fetch.sh test many
combinations of --prune, --prune-tags, and using 'origin' or an explicit
URL. Some machinery was introduced in e1790f9245f (fetch tests: fetch
<url> <spec> as well as fetch [<remote>], 2018-02-09) to replace
'origin' with this explicit URL. This URL is a "file:///" URL for the
root of the $TRASH_DIRECTORY.

However, if the current build tree has an '@' symbol, the
replacement using perl fails. It drops the '@' as well as anything
else in that directory name.  You can observe this locally by
cloning git.git into a "victim@03" directory and running the test
script.

As we are writing in Perl anyway, pass in the shell variables involved
to the script as arguments and perform necessary string transformations
inside it, instead of assuming that it is sufficient to enclose the
$remote_url variable inside a pair of single quotes.

Reported-by: Randall Becker <rsbecker@nexbridge.com>
Original-patch-by: Derrick Stolee <derrickstolee@github.com>
Helped-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
t/t5510-fetch.sh

index 4620f0ca7fa0d30f5b8811bd67ce21987f055650..b45879a760b829270c3460cb3abd32996cad1c9a 100755 (executable)
@@ -853,7 +853,11 @@ test_configured_prune_type () {
                then
                        new_cmdline=$cmdline_setup
                else
-                       new_cmdline=$(printf "%s" "$cmdline" | perl -pe 's[origin(?!/)]["'"$remote_url"'"]g')
+                       new_cmdline=$(perl -e '
+                               my ($cmdline, $url) = @ARGV;
+                               $cmdline =~ s[origin(?!/)][quotemeta($url)]ge;
+                               print $cmdline;
+                       ' -- "$cmdline" "$remote_url")
                fi
 
                if test "$fetch_prune_tags" = 'true' ||