diff options
author | Brad King <brad.king@kitware.com> | 2014-10-08 19:08:40 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2014-10-29 20:41:14 (GMT) |
commit | 661fa7c917f64231200c8ae90b59fe9146dfa958 (patch) | |
tree | 4882bbf8a82677c74ae6ff24b50cb4b44266a4bd /Utilities/cmcurl/curltest.c | |
parent | 9cf069f88ba43931c46b245f567b0f8371a6067c (diff) | |
download | CMake-661fa7c917f64231200c8ae90b59fe9146dfa958.zip CMake-661fa7c917f64231200c8ae90b59fe9146dfa958.tar.gz CMake-661fa7c917f64231200c8ae90b59fe9146dfa958.tar.bz2 |
curl: Drop unused testing code
Remove our "Testing/" directory renames of the upstream examples.
Diffstat (limited to 'Utilities/cmcurl/curltest.c')
-rw-r--r-- | Utilities/cmcurl/curltest.c | 159 |
1 files changed, 159 insertions, 0 deletions
diff --git a/Utilities/cmcurl/curltest.c b/Utilities/cmcurl/curltest.c new file mode 100644 index 0000000..210868e --- /dev/null +++ b/Utilities/cmcurl/curltest.c @@ -0,0 +1,159 @@ +/* Prevent warnings on Visual Studio */ +struct _RPC_ASYNC_STATE; + +#include "curl/curl.h" +#include <stdlib.h> +#include <string.h> + +int GetFtpFile(void) +{ + int retVal = 0; + CURL *curl; + CURLcode res; + curl = curl_easy_init(); + if(curl) + { + /* Get curl 7.9.2 from sunet.se's FTP site: */ + curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); + curl_easy_setopt(curl, CURLOPT_HEADER, 1); + curl_easy_setopt(curl, CURLOPT_URL, + "ftp://public.kitware.com/pub/cmake/cygwin/setup.hint"); + res = curl_easy_perform(curl); + if ( res != 0 ) + { + printf("Error fetching: ftp://public.kitware.com/pub/cmake/cygwin/setup.hint\n"); + retVal = 1; + } + + /* always cleanup */ + curl_easy_cleanup(curl); + } + else + { + printf("Cannot create curl object\n"); + retVal = 1; + } + return retVal; +} + +int GetWebFiles(char *url1, char *url2) +{ + int retVal = 0; + CURL *curl; + CURLcode res; + + char proxy[1024]; + int proxy_type = 0; + + if ( getenv("HTTP_PROXY") ) + { + proxy_type = 1; + if (getenv("HTTP_PROXY_PORT") ) + { + sprintf(proxy, "%s:%s", getenv("HTTP_PROXY"), getenv("HTTP_PROXY_PORT")); + } + else + { + sprintf(proxy, "%s", getenv("HTTP_PROXY")); + } + if ( getenv("HTTP_PROXY_TYPE") ) + { + /* HTTP/SOCKS4/SOCKS5 */ + if ( strcmp(getenv("HTTP_PROXY_TYPE"), "HTTP") == 0 ) + { + proxy_type = 1; + } + else if ( strcmp(getenv("HTTP_PROXY_TYPE"), "SOCKS4") == 0 ) + { + proxy_type = 2; + } + else if ( strcmp(getenv("HTTP_PROXY_TYPE"), "SOCKS5") == 0 ) + { + proxy_type = 3; + } + } + } + + curl = curl_easy_init(); + if(curl) + { + curl_easy_setopt(curl, CURLOPT_VERBOSE, 1); + curl_easy_setopt(curl, CURLOPT_HEADER, 1); + + /* Using proxy */ + if ( proxy_type > 0 ) + { + curl_easy_setopt(curl, CURLOPT_PROXY, proxy); + switch (proxy_type) + { + case 2: + curl_easy_setopt(curl, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS4); + break; + case 3: + curl_easy_setopt(curl, CURLOPT_PROXYTYPE, CURLPROXY_SOCKS5); + break; + default: + curl_easy_setopt(curl, CURLOPT_PROXYTYPE, CURLPROXY_HTTP); + } + } + + /* get the first document */ + curl_easy_setopt(curl, CURLOPT_URL, url1); + res = curl_easy_perform(curl); + if ( res != 0 ) + { + printf("Error fetching: %s\n", url1); + retVal = 1; + } + + /* get another document from the same server using the same + connection */ + /* avoid warnings about url2 since below block is commented out: */ + (void) url2; + /* + curl_easy_setopt(curl, CURLOPT_URL, url2); + res = curl_easy_perform(curl); + if ( res != 0 ) + { + printf("Error fetching: %s\n", url2); + retVal = 1; + } + */ + + /* always cleanup */ + curl_easy_cleanup(curl); + } + else + { + printf("Cannot create curl object\n"); + retVal = 1; + } + + return retVal; +} + + +int main(int argc, char **argv) +{ + int retVal = 0; + + curl_global_init(CURL_GLOBAL_DEFAULT); + + if(argc>1) + { + retVal += GetWebFiles(argv[1], 0); + } + else + { + printf("error: first argument should be a url to download\n"); + retVal = 1; + } + + /* Do not check the output of FTP socks5 cannot handle FTP yet */ + /* GetFtpFile(); */ + /* do not test ftp right now because we don't enable that port */ + + curl_global_cleanup(); + + return retVal; +} |