mirror of
https://github.com/curl/curl.git
synced 2025-01-18 14:04:30 +08:00
4564636781
- Call Curl_initinfo on init and duphandle. Prior to this change the statistical and informational variables were simply zeroed by calloc on easy init and duphandle. While zero is the correct default value for almost all info variables, there is one where it isn't (filetime initializes to -1). Bug: https://github.com/curl/curl/issues/1103 Reported-by: Neal Poole
130 lines
3.9 KiB
C
130 lines
3.9 KiB
C
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 1998 - 2016, 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.haxx.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.
|
|
*
|
|
***************************************************************************/
|
|
#include "test.h"
|
|
|
|
#include "memdebug.h"
|
|
|
|
/* Test CURLINFO_FILETIME */
|
|
|
|
int test(char *URL)
|
|
{
|
|
CURL *curl, *dupe = NULL;
|
|
long filetime;
|
|
int res = CURLE_OK;
|
|
|
|
global_init(CURL_GLOBAL_ALL);
|
|
|
|
easy_init(curl);
|
|
|
|
/* Test that a filetime is properly initialized on curl_easy_init.
|
|
*/
|
|
|
|
res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime);
|
|
if(res) {
|
|
fprintf(stderr, "%s:%d curl_easy_getinfo() failed with code %d (%s)\n",
|
|
__FILE__, __LINE__, res, curl_easy_strerror(res));
|
|
goto test_cleanup;
|
|
}
|
|
if(filetime != -1) {
|
|
fprintf(stderr, "%s:%d filetime init failed; expected -1 but is %ld\n",
|
|
__FILE__, __LINE__, filetime);
|
|
res = CURLE_FAILED_INIT;
|
|
goto test_cleanup;
|
|
}
|
|
|
|
easy_setopt(curl, CURLOPT_URL, URL);
|
|
easy_setopt(curl, CURLOPT_FILETIME, 1L);
|
|
|
|
res = curl_easy_perform(curl);
|
|
if(res) {
|
|
fprintf(stderr, "%s:%d curl_easy_perform() failed with code %d (%s)\n",
|
|
__FILE__, __LINE__, res, curl_easy_strerror(res));
|
|
goto test_cleanup;
|
|
}
|
|
|
|
/* Test that a filetime is properly set after receiving an HTTP resource.
|
|
*/
|
|
|
|
res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime);
|
|
if(res) {
|
|
fprintf(stderr, "%s:%d curl_easy_getinfo() failed with code %d (%s)\n",
|
|
__FILE__, __LINE__, res, curl_easy_strerror(res));
|
|
goto test_cleanup;
|
|
}
|
|
if(filetime != 30) {
|
|
fprintf(stderr, "%s:%d filetime of http resource is incorrect; "
|
|
"expected 30 but is %ld\n",
|
|
__FILE__, __LINE__, filetime);
|
|
res = CURLE_HTTP_RETURNED_ERROR;
|
|
goto test_cleanup;
|
|
}
|
|
|
|
/* Test that a filetime is properly initialized on curl_easy_duphandle.
|
|
*/
|
|
|
|
dupe = curl_easy_duphandle(curl);
|
|
if(!dupe) {
|
|
fprintf(stderr, "%s:%d curl_easy_duphandle() failed\n",
|
|
__FILE__, __LINE__);
|
|
res = CURLE_FAILED_INIT;
|
|
goto test_cleanup;
|
|
}
|
|
|
|
res = curl_easy_getinfo(dupe, CURLINFO_FILETIME, &filetime);
|
|
if(res) {
|
|
fprintf(stderr, "%s:%d curl_easy_getinfo() failed with code %d (%s)\n",
|
|
__FILE__, __LINE__, res, curl_easy_strerror(res));
|
|
goto test_cleanup;
|
|
}
|
|
if(filetime != -1) {
|
|
fprintf(stderr, "%s:%d filetime init failed; expected -1 but is %ld\n",
|
|
__FILE__, __LINE__, filetime);
|
|
res = CURLE_FAILED_INIT;
|
|
goto test_cleanup;
|
|
}
|
|
|
|
|
|
/* Test that a filetime is properly initialized on curl_easy_reset.
|
|
*/
|
|
|
|
curl_easy_reset(curl);
|
|
|
|
res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime);
|
|
if(res) {
|
|
fprintf(stderr, "%s:%d curl_easy_getinfo() failed with code %d (%s)\n",
|
|
__FILE__, __LINE__, res, curl_easy_strerror(res));
|
|
goto test_cleanup;
|
|
}
|
|
if(filetime != -1) {
|
|
fprintf(stderr, "%s:%d filetime init failed; expected -1 but is %ld\n",
|
|
__FILE__, __LINE__, filetime);
|
|
res = CURLE_FAILED_INIT;
|
|
goto test_cleanup;
|
|
}
|
|
|
|
test_cleanup:
|
|
curl_easy_cleanup(curl);
|
|
curl_easy_cleanup(dupe);
|
|
curl_global_cleanup();
|
|
return res;
|
|
}
|