Skip to content

Commit

Permalink
Merge 20e12a5 into 8c00412
Browse files Browse the repository at this point in the history
  • Loading branch information
xquery committed Jul 14, 2018
2 parents 8c00412 + 20e12a5 commit 39b52fb
Show file tree
Hide file tree
Showing 6 changed files with 123 additions and 7 deletions.
7 changes: 2 additions & 5 deletions lib/url.h
Expand Up @@ -34,7 +34,7 @@
CURLcode Curl_init_do(struct Curl_easy *data, struct connectdata *conn);
CURLcode Curl_open(struct Curl_easy **curl);
CURLcode Curl_init_userdefined(struct Curl_easy *data);
CURLcode Curl_dupset(struct Curl_easy * dst, struct Curl_easy * src);

void Curl_freeset(struct Curl_easy * data);
CURLcode Curl_close(struct Curl_easy *data); /* opposite of curl_open() */
CURLcode Curl_connect(struct Curl_easy *, struct connectdata **,
Expand All @@ -57,17 +57,14 @@ int Curl_doing_getsock(struct connectdata *conn,
CURLcode Curl_parse_login_details(const char *login, const size_t len,
char **userptr, char **passwdptr,
char **optionsptr);
bool Curl_isPipeliningEnabled(const struct Curl_easy *handle);
CURLcode Curl_addHandleToPipeline(struct Curl_easy *handle,
struct curl_llist *pipeline);

int Curl_removeHandleFromPipeline(struct Curl_easy *handle,
struct curl_llist *pipeline);
/* remove the specified connection from all (possible) pipelines and related
queues */
void Curl_getoff_all_pipelines(struct Curl_easy *data,
struct connectdata *conn);

void Curl_close_connections(struct Curl_easy *data);

#define CURL_DEFAULT_PROXY_PORT 1080 /* default proxy port unless specified */
#define CURL_DEFAULT_HTTPS_PROXY_PORT 443 /* default https proxy port unless
Expand Down
2 changes: 1 addition & 1 deletion tests/data/Makefile.inc
Expand Up @@ -179,7 +179,7 @@ test1550 test1551 test1552 test1553 test1554 test1555 test1556 test1557 \
\
test1590 \
test1600 test1601 test1602 test1603 test1604 test1605 test1606 test1607 \
test1608 test1609 \
test1608 test1609 test1620 \
\
test1700 test1701 test1702 \
\
Expand Down
26 changes: 26 additions & 0 deletions tests/data/test1620
@@ -0,0 +1,26 @@
<testcase>
<info>
<keywords>
unittest
URL
</keywords>
</info>

#
# Client-side
<client>
<server>
none
</server>
<features>
unittest
</features>
<name>
unit tests for url.c
</name>
<tool>
unit1620
</tool>
</client>

</testcase>
1 change: 1 addition & 0 deletions tests/unit/CMakeLists.txt
Expand Up @@ -21,6 +21,7 @@ set(UT_SRC
unit1603.c
# Broken link on Linux
# unit1604.c
unit1620.c
)

set(UT_COMMON_FILES ../libtest/first.c ../libtest/test.h curlcheck.h)
Expand Down
5 changes: 4 additions & 1 deletion tests/unit/Makefile.inc
Expand Up @@ -10,7 +10,7 @@ UNITPROGS = unit1300 unit1301 unit1302 unit1303 unit1304 unit1305 unit1307 \
unit1330 unit1394 unit1395 unit1396 unit1397 unit1398 \
unit1399 \
unit1600 unit1601 unit1602 unit1603 unit1604 unit1605 unit1606 unit1607 \
unit1608 unit1609
unit1608 unit1609 unit1620

unit1300_SOURCES = unit1300.c $(UNITFILES)
unit1300_CPPFLAGS = $(AM_CPPFLAGS)
Expand Down Expand Up @@ -95,3 +95,6 @@ unit1608_CPPFLAGS = $(AM_CPPFLAGS)

unit1609_SOURCES = unit1609.c $(UNITFILES)
unit1609_CPPFLAGS = $(AM_CPPFLAGS)

unit1620_SOURCES = unit1620.c $(UNITFILES)
unit1620_CPPFLAGS = $(AM_CPPFLAGS)
89 changes: 89 additions & 0 deletions tests/unit/unit1620.c
@@ -0,0 +1,89 @@
/***************************************************************************
* _ _ ____ _
* Project ___| | | | _ \| |
* / __| | | | |_) | |
* | (__| |_| | _ <| |___
* \___|\___/|_| \_\_____|
*
* Copyright (C) 1998 - 2018, 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 "curlcheck.h"

#include "urldata.h"
#include "url.h"

#include "memdebug.h" /* LAST include file */

static CURLcode unit_setup(void)
{
return CURLE_OK;
}

static void unit_stop(void)
{
}

UNITTEST_START
{
int rc;
struct Curl_easy *empty;
const char *hostname = "hostname";
enum dupstring i;

bool async = FALSE;
bool protocol_connect = FALSE;

rc = Curl_open(&empty);
fail_unless(rc == CURLE_OK, "Curl_open() failed");

rc = Curl_connect(empty, &empty->easy_conn, &async, &protocol_connect);
fail_unless(rc == CURLE_URL_MALFORMAT,
"Curl_connect() failed to return CURLE_URL_MALFORMAT");

fail_unless(empty->magic == CURLEASY_MAGIC_NUMBER,
"empty->magic should be equal to CURLEASY_MAGIC_NUMBER");

rc = Curl_connect(empty, &empty->easy_conn, &async, &protocol_connect);
fail_unless(rc == CURLE_URL_MALFORMAT,
"Curl_connect() failed to return CURLE_URL_MALFORMAT");

rc = Curl_init_userdefined(empty);
fail_unless(rc == CURLE_OK, "Curl_userdefined() failed");

rc = Curl_init_do(empty, empty->easy_conn);
fail_unless(rc == CURLE_OK, "Curl_init_do() failed");

rc = Curl_parse_login_details(
hostname, strlen(hostname), NULL, NULL, NULL);
fail_unless(rc == CURLE_OK,
"Curl_parse_login_details() failed");

rc = Curl_disconnect(empty, empty->easy_conn, FALSE);
fail_unless(rc == CURLE_OK,
"Curl_disconnect() with dead_connection set FALSE failed");

Curl_freeset(empty);
for(i = (enum dupstring)0; i < STRING_LAST; i++) {
fail_unless(empty->set.str[i] == NULL,
"Curl_free() did not set to NULL");
}

Curl_free_request_state(empty);

rc = Curl_close(empty);
fail_unless(rc == CURLE_OK, "Curl_close() failed");

}
UNITTEST_STOP

0 comments on commit 39b52fb

Please sign in to comment.