/*************************************************************************** * _ _ ____ _ * Project ___| | | | _ \| | * / __| | | | |_) | | * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * * Copyright (C) Daniel Stenberg, , 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 "test.h" #ifdef HAVE_LOCALE_H # include /* for setlocale() */ #endif #ifdef HAVE_IO_H # include /* for setmode() */ #endif #ifdef HAVE_FCNTL_H # include /* for setmode() */ #endif #ifdef CURLDEBUG # define MEMDEBUG_NODEFINES # include "memdebug.h" #endif #include "timediff.h" int select_wrapper(int nfds, fd_set *rd, fd_set *wr, fd_set *exc, struct timeval *tv) { if(nfds < 0) { SET_SOCKERRNO(EINVAL); return -1; } #ifdef USE_WINSOCK /* * Winsock select() requires that at least one of the three fd_set * pointers is not NULL and points to a non-empty fdset. IOW Winsock * select() can not be used to sleep without a single fd_set. */ if(!nfds) { Sleep((DWORD)curlx_tvtoms(tv)); return 0; } #endif return select(nfds, rd, wr, exc, tv); } void wait_ms(int ms) { if(ms < 0) return; #ifdef USE_WINSOCK Sleep((DWORD)ms); #else { struct timeval t; curlx_mstotv(&t, ms); select_wrapper(0, NULL, NULL, NULL, &t); } #endif } char *libtest_arg2 = NULL; char *libtest_arg3 = NULL; int test_argc; char **test_argv; struct timeval tv_test_start; /* for test timing */ int unitfail; /* for unittests */ #ifdef CURLDEBUG static void memory_tracking_init(void) { char *env; /* if CURL_MEMDEBUG is set, this starts memory tracking message logging */ env = curl_getenv("CURL_MEMDEBUG"); if(env) { /* use the value as file name */ char fname[CURL_MT_LOGFNAME_BUFSIZE]; if(strlen(env) >= CURL_MT_LOGFNAME_BUFSIZE) env[CURL_MT_LOGFNAME_BUFSIZE-1] = '\0'; strcpy(fname, env); curl_free(env); curl_dbg_memdebug(fname); /* this weird stuff here is to make curl_free() get called before curl_dbg_memdebug() as otherwise memory tracking will log a free() without an alloc! */ } /* if CURL_MEMLIMIT is set, this enables fail-on-alloc-number-N feature */ env = curl_getenv("CURL_MEMLIMIT"); if(env) { char *endptr; long num = strtol(env, &endptr, 10); if((endptr != env) && (endptr == env + strlen(env)) && (num > 0)) curl_dbg_memlimit(num); curl_free(env); } } #else # define memory_tracking_init() Curl_nop_stmt #endif /* returns a hexdump in a static memory area */ char *hexdump(const unsigned char *buffer, size_t len) { static char dump[200 * 3 + 1]; char *p = dump; size_t i; if(len > 200) return NULL; for(i = 0; i2) libtest_arg2 = argv[2]; if(argc>3) libtest_arg3 = argv[3]; URL = argv[1]; /* provide this to the rest */ fprintf(stderr, "URL: %s\n", URL); result = test(URL); fprintf(stderr, "Test ended with result %d\n", result); #ifdef _WIN32 /* flush buffers of all streams regardless of mode */ _flushall(); #endif /* Regular program status codes are limited to 0..127 and 126 and 127 have * special meanings by the shell, so limit a normal return code to 125 */ return (int)result <= 125 ? (int)result : 125; }