summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/cmake/CMakeLists.txt63
-rwxr-xr-xtests/cmake/test.sh6
-rw-r--r--tests/data/Makefile.am2
-rw-r--r--tests/data/test303440
-rw-r--r--tests/data/test961
-rw-r--r--tests/libtest/Makefile.inc2
-rw-r--r--tests/libtest/lib3034.c77
7 files changed, 165 insertions, 26 deletions
diff --git a/tests/cmake/CMakeLists.txt b/tests/cmake/CMakeLists.txt
index d40a6b25d..2c3d0daeb 100644
--- a/tests/cmake/CMakeLists.txt
+++ b/tests/cmake/CMakeLists.txt
@@ -31,20 +31,7 @@ option(TEST_INTEGRATION_MODE "Integration mode" "find_package")
message(STATUS "TEST_INTEGRATION_MODE: ${TEST_INTEGRATION_MODE}")
-if(TEST_INTEGRATION_MODE STREQUAL "FetchContent" AND CMAKE_VERSION VERSION_LESS 3.14)
- message(FATAL_ERROR "This test requires CMake 3.14 or upper")
-endif()
-
-if(TEST_INTEGRATION_MODE STREQUAL "ExternalProject") # Broken
- include(ExternalProject)
- ExternalProject_Add(libssh2
- URL "${FROM_ARCHIVE}" URL_HASH "SHA256=${FROM_HASH}"
- INSTALL_COMMAND ""
- DOWNLOAD_EXTRACT_TIMESTAMP ON)
-endif()
-
-if(TEST_INTEGRATION_MODE STREQUAL "find_package" OR
- TEST_INTEGRATION_MODE STREQUAL "ExternalProject")
+if(TEST_INTEGRATION_MODE STREQUAL "find_package")
find_package(CURL REQUIRED CONFIG)
find_package(CURL REQUIRED CONFIG) # Double-inclusion test
foreach(_result_var IN ITEMS
@@ -75,6 +62,9 @@ elseif(TEST_INTEGRATION_MODE STREQUAL "add_subdirectory")
set(BUILD_STATIC_LIBS ON CACHE BOOL "")
add_subdirectory(curl)
elseif(TEST_INTEGRATION_MODE STREQUAL "FetchContent")
+ if(CMAKE_VERSION VERSION_LESS 3.14)
+ message(FATAL_ERROR "This test requires CMake 3.14 or upper")
+ endif()
include(FetchContent)
option(FROM_GIT_REPO "Git URL" "https://github.com/curl/curl.git")
option(FROM_GIT_TAG "Git tag" "master")
@@ -85,17 +75,48 @@ elseif(TEST_INTEGRATION_MODE STREQUAL "FetchContent")
set(BUILD_SHARED_LIBS ON CACHE BOOL "")
set(BUILD_STATIC_LIBS ON CACHE BOOL "")
FetchContent_MakeAvailable(curl) # Requires CMake 3.14
+elseif(TEST_INTEGRATION_MODE STREQUAL "ExternalProject")
+ include(ExternalProject)
+ set(_curl_install_dir "${CMAKE_BINARY_DIR}/curl-external-install")
+ set(_curl_static_lib "${_curl_install_dir}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}curl${CMAKE_STATIC_LIBRARY_SUFFIX}")
+ string(REPLACE " " ";" CURL_TEST_OPTS "${CURL_TEST_OPTS}")
+ if(CMAKE_VERSION VERSION_GREATER_EQUAL 3.24)
+ set(_download_extract_timestamp "DOWNLOAD_EXTRACT_TIMESTAMP" "ON")
+ endif()
+ ExternalProject_Add(curl-external
+ URL "${FROM_ARCHIVE}" URL_HASH "SHA256=${FROM_HASH}"
+ ${_download_extract_timestamp}
+ PREFIX "${CMAKE_BINARY_DIR}/curl-external"
+ CMAKE_ARGS "-DCMAKE_INSTALL_PREFIX=${_curl_install_dir}" -DBUILD_SHARED_LIBS=OFF -DCURL_USE_LIBPSL=OFF -DCURL_USE_PKGCONFIG=OFF
+ -DCURL_ENABLE_SSL=OFF -DCURL_ENABLE_SSL=OFF -DCURL_DISABLE_LDAP=ON -DCURL_USE_LIBSSH2=OFF -DUSE_NGHTTP2=OFF
+ -DCURL_BROTLI=OFF -DCURL_ZLIB=OFF -DCURL_ZSTD=OFF -DUSE_LIBIDN2=OFF -DENABLE_IPV6=OFF
+ ${CURL_TEST_OPTS}
+ BUILD_BYPRODUCTS "${_curl_static_lib}")
+
+ add_executable(test-consumer-static-fetch "test.c")
+ add_dependencies(test-consumer-static-fetch curl-external)
+ if(WIN32)
+ target_compile_definitions(test-consumer-static-fetch PRIVATE "CURL_STATICLIB")
+ list(APPEND _curl_static_lib "ws2_32" "bcrypt")
+ endif()
+ target_include_directories(test-consumer-static-fetch PRIVATE "${_curl_install_dir}/include")
+ target_link_libraries(test-consumer-static-fetch PRIVATE "${_curl_static_lib}")
endif()
-add_executable(test-consumer-static-ns "test.c")
-target_link_libraries(test-consumer-static-ns PRIVATE "CURL::libcurl_static")
+if(TEST_INTEGRATION_MODE STREQUAL "find_package" OR
+ TEST_INTEGRATION_MODE STREQUAL "add_subdirectory" OR
+ TEST_INTEGRATION_MODE STREQUAL "FetchContent")
+
+ add_executable(test-consumer-static-ns "test.c")
+ target_link_libraries(test-consumer-static-ns PRIVATE "CURL::libcurl_static")
-add_executable(test-consumer-shared-ns "test.c")
-target_link_libraries(test-consumer-shared-ns PRIVATE "CURL::libcurl_shared")
+ add_executable(test-consumer-shared-ns "test.c")
+ target_link_libraries(test-consumer-shared-ns PRIVATE "CURL::libcurl_shared")
-# Alias for either shared or static library
-add_executable(test-consumer-selected-ns "test.c")
-target_link_libraries(test-consumer-selected-ns PRIVATE "CURL::libcurl")
+ # Alias for either shared or static library
+ add_executable(test-consumer-selected-ns "test.c")
+ target_link_libraries(test-consumer-selected-ns PRIVATE "CURL::libcurl")
+endif()
if(TEST_INTEGRATION_MODE STREQUAL "add_subdirectory" OR
TEST_INTEGRATION_MODE STREQUAL "FetchContent")
diff --git a/tests/cmake/test.sh b/tests/cmake/test.sh
index a1d11e8ad..451235484 100755
--- a/tests/cmake/test.sh
+++ b/tests/cmake/test.sh
@@ -41,20 +41,20 @@ runresults() {
set -x
}
-if [ "${mode}" = 'ExternalProject' ]; then # Broken
+if [ "${mode}" = 'all' ] || [ "${mode}" = 'ExternalProject' ]; then
(cd "${src}"; git archive --format=tar HEAD) | gzip > source.tar.gz
src="${PWD}/source.tar.gz"
sha="$(openssl dgst -sha256 "${src}" | grep -a -i -o -E '[0-9a-f]{64}$')"
bldc='bld-externalproject'
rm -rf "${bldc}"
if [ -n "${cmake_consumer_modern:-}" ]; then # 3.15+
- "${cmake_consumer}" -B "${bldc}" -G "${gen}" ${cmake_opts} -DCMAKE_UNITY_BUILD=ON ${TEST_CMAKE_FLAGS:-} "$@" \
+ "${cmake_consumer}" -B "${bldc}" -G "${gen}" ${TEST_CMAKE_FLAGS:-} -DCURL_TEST_OPTS="${cmake_opts} -DCMAKE_UNITY_BUILD=ON $*" \
-DTEST_INTEGRATION_MODE=ExternalProject \
-DFROM_ARCHIVE="${src}" -DFROM_HASH="${sha}"
"${cmake_consumer}" --build "${bldc}" --verbose
else
mkdir "${bldc}"; cd "${bldc}"
- "${cmake_consumer}" .. -G "${gen}" ${cmake_opts} ${TEST_CMAKE_FLAGS:-} "$@" \
+ "${cmake_consumer}" .. -G "${gen}" ${TEST_CMAKE_FLAGS:-} -DCURL_TEST_OPTS="${cmake_opts} $*" \
-DTEST_INTEGRATION_MODE=ExternalProject \
-DFROM_ARCHIVE="${src}" -DFROM_HASH="${sha}"
VERBOSE=1 "${cmake_consumer}" --build .
diff --git a/tests/data/Makefile.am b/tests/data/Makefile.am
index c01d93eb8..1c0258e17 100644
--- a/tests/data/Makefile.am
+++ b/tests/data/Makefile.am
@@ -273,7 +273,7 @@ test3000 test3001 test3002 test3003 test3004 test3005 test3006 test3007 \
test3008 test3009 test3010 test3011 test3012 test3013 test3014 test3015 \
test3016 test3017 test3018 test3019 test3020 test3021 test3022 test3023 \
test3024 test3025 test3026 test3027 test3028 test3029 test3030 test3031 \
-test3032 test3033 \
+test3032 test3033 test3034 \
\
test3100 test3101 test3102 test3103 test3104 test3105 \
\
diff --git a/tests/data/test3034 b/tests/data/test3034
new file mode 100644
index 000000000..5b1ace225
--- /dev/null
+++ b/tests/data/test3034
@@ -0,0 +1,40 @@
+<testcase>
+<info>
+<keywords>
+CURLOPT_READFUNCTION
+curl_easy_reset
+rewind
+</keywords>
+</info>
+
+# Server side
+<reply>
+<data nocheck="yes">
+HTTP/1.1 307 Temporary Redirect OK swsclose
+Content-Length: 0
+Location: /%TESTNUMBER
+</data>
+</reply>
+
+# Client side
+<client>
+<server>
+http
+</server>
+<tool>
+lib%TESTNUMBER
+</tool>
+<name>
+Test reset resolves rewind failure
+</name>
+<command>
+http://%HOSTIP:%HTTPPORT/%TESTNUMBER
+</command>
+</client>
+
+<verify>
+<errorcode>
+0
+</errorcode>
+</verify>
+</testcase>
diff --git a/tests/data/test96 b/tests/data/test96
index 426715a2c..4efc3491a 100644
--- a/tests/data/test96
+++ b/tests/data/test96
@@ -36,6 +36,7 @@ MEM tool_paramhlp.c
MEM tool_cfgable.c
MEM tool_cfgable.c
MEM tool_cfgable.c
+MEM tool_cfgable.c
</file>
<stripfile>
$_ = '' if((($_ !~ /tool_paramhlp/) && ($_ !~ /tool_cfgable/)) || ($_ =~ /free\(\(nil\)\)/))
diff --git a/tests/libtest/Makefile.inc b/tests/libtest/Makefile.inc
index 770184f71..5e1462108 100644
--- a/tests/libtest/Makefile.inc
+++ b/tests/libtest/Makefile.inc
@@ -104,6 +104,6 @@ TESTS_C = \
lib2402.c lib2404.c lib2405.c \
lib2502.c \
lib2700.c \
- lib3010.c lib3025.c lib3026.c lib3027.c lib3033.c \
+ lib3010.c lib3025.c lib3026.c lib3027.c lib3033.c lib3034.c \
lib3100.c lib3101.c lib3102.c lib3103.c lib3104.c lib3105.c \
lib3207.c lib3208.c
diff --git a/tests/libtest/lib3034.c b/tests/libtest/lib3034.c
new file mode 100644
index 000000000..b21c68d15
--- /dev/null
+++ b/tests/libtest/lib3034.c
@@ -0,0 +1,77 @@
+/***************************************************************************
+ * _ _ ____ _
+ * 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 const char data_3034[] = "hello";
+
+static size_t t3034_read_cb(char *ptr, size_t size, size_t nmemb, void *userp)
+{
+ size_t len = size * nmemb;
+ size_t tocopy = sizeof(data_3034) < len ? sizeof(data_3034) : len;
+ (void)userp;
+ memcpy(ptr, data_3034, tocopy);
+ return tocopy;
+}
+
+static CURLcode test_lib3034(const char *URL)
+{
+ CURL *curl;
+ CURLcode res = CURLE_OK;
+
+ global_init(CURL_GLOBAL_ALL);
+ easy_init(curl);
+
+ /* This first request will receive a redirect response; deliberately only
+ * set the CURLOPT_READFUNCTION but not the CURLOPT_SEEKFUNCTION to force a
+ * rewind failure (CURLE_SEND_FAIL_REWIND).
+ */
+ test_setopt(curl, CURLOPT_VERBOSE, 1L);
+ test_setopt(curl, CURLOPT_URL, URL);
+ test_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
+ test_setopt(curl, CURLOPT_UPLOAD, 1L);
+ test_setopt(curl, CURLOPT_INFILESIZE, 5L);
+ test_setopt(curl, CURLOPT_READFUNCTION, t3034_read_cb);
+
+ res = curl_easy_perform(curl);
+ if(res != CURLE_SEND_FAIL_REWIND) {
+ curl_mfprintf(stderr,
+ "%s:%d curl_easy_perform() failed with code %d (%s)\n",
+ __FILE__, __LINE__, res, curl_easy_strerror(res));
+ goto test_cleanup;
+ }
+
+ /* Reset the easy handle, which should clear the rewind failure. */
+ curl_easy_reset(curl);
+
+ /* Perform a second request, which should succeed. */
+ test_setopt(curl, CURLOPT_VERBOSE, 1L);
+ test_setopt(curl, CURLOPT_URL, URL);
+
+ res = curl_easy_perform(curl);
+
+test_cleanup:
+ curl_easy_cleanup(curl);
+ curl_global_cleanup();
+ return res;
+}