urlapi: fix redirect handling if CURLU_NO_GUESS_SCHEME is set

Verified by test 1967

Reported-by: Joshua Rogers
Closes #21721
This commit is contained in:
Daniel Stenberg 2026-05-21 23:00:55 +02:00
parent 8e549fbdd3
commit 7e350dd147
No known key found for this signature in database
GPG key ID: 5CC908FDB71E12C2
5 changed files with 77 additions and 4 deletions

View file

@ -1731,8 +1731,9 @@ static CURLUcode set_url(CURLU *u, const char *url, size_t part_size,
return parseurl_and_replace(url, u, flags);
/* if the old URL is incomplete (we cannot get an absolute URL in
'oldurl'), replace the existing with the new */
uc = curl_url_get(u, CURLUPART_URL, &oldurl, flags);
'oldurl'), replace the existing with the new.
Always include "scheme://" to make the URL "complete" */
uc = curl_url_get(u, CURLUPART_URL, &oldurl, flags& ~CURLU_NO_GUESS_SCHEME);
if(uc == CURLUE_OUT_OF_MEMORY)
return uc;
else if(uc)

View file

@ -239,7 +239,7 @@ test1916 test1917 test1918 test1919 test1920 test1921 \
test1933 test1934 test1935 test1936 test1937 test1938 test1939 test1940 \
test1941 test1942 test1943 test1944 test1945 test1946 test1947 test1948 \
test1955 test1956 test1957 test1958 test1959 test1960 test1964 test1965 \
test1966 \
test1966 test1967 \
\
test1970 test1971 test1972 test1973 test1974 test1975 test1976 test1977 \
test1978 test1979 test1980 test1981 test1982 test1983 test1984 \

30
tests/data/test1967 Normal file
View file

@ -0,0 +1,30 @@
<?xml version="1.0" encoding="US-ASCII"?>
<testcase>
<info>
<keywords>
HTTP
urlapi
</keywords>
</info>
<client>
<name>
curl_url_set() a URL without guessing a scheme
</name>
<tool>
lib%TESTNUMBER
</tool>
<command>
http://%HOSTIP:%NOLISTENPORT/not-there/%TESTNUMBER
</command>
</client>
# Verify data after the test has been "shot"
<verify>
<stdout mode="text">
URL http://a.b/x
</stdout>
</verify>
</testcase>

View file

@ -108,7 +108,7 @@ TESTS_C = \
lib1940.c lib1945.c \
lib1947.c lib1948.c \
lib1955.c lib1956.c lib1957.c lib1958.c lib1959.c lib1960.c \
lib1964.c lib1965.c lib1970.c \
lib1964.c lib1965.c lib1967.c lib1970.c \
lib1971.c lib1972.c lib1973.c lib1974.c lib1975.c lib1977.c lib1978.c \
lib2023.c lib2032.c lib2082.c \
lib2301.c lib2302.c lib2304.c lib2306.c lib2308.c lib2309.c \

42
tests/libtest/lib1967.c Normal file
View file

@ -0,0 +1,42 @@
/***************************************************************************
* _ _ ____ _
* Project ___| | | | _ \| |
* / __| | | | |_) | |
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
* Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
*
* This software is licensed as described in the file COPYING, which
* you should have received as part of this distribution. The terms
* are also available at https://curl.se/docs/copyright.html.
*
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
* copies of the Software, and permit persons to whom the Software is
* furnished to do so, under the terms of the COPYING file.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
* SPDX-License-Identifier: curl
*
***************************************************************************/
#include "first.h"
static CURLcode test_lib1967(const char *URL)
{
CURLU *u = curl_url();
(void)URL;
if(u) {
char *url;
curl_url_set(u, CURLUPART_URL, "a.b", CURLU_GUESS_SCHEME);
curl_url_set(u, CURLUPART_URL, "/x", CURLU_NO_GUESS_SCHEME);
if(!curl_url_get(u, CURLUPART_URL, &url, 0)) {
curl_mprintf("URL %s\n", url);
curl_free(url);
}
curl_url_cleanup(u);
}
return CURLE_OK;
}