unit1394.c: plug the curl tool unit test in
This commit is contained in:
parent
b045d079f8
commit
bcf1b9dec1
@ -290,9 +290,12 @@ static const struct feat feats[] = {
|
|||||||
* We allow ':' and '\' to be escaped by '\' so that we can use certificate
|
* We allow ':' and '\' to be escaped by '\' so that we can use certificate
|
||||||
* nicknames containing ':'. See <https://sourceforge.net/p/curl/bugs/1196/>
|
* nicknames containing ':'. See <https://sourceforge.net/p/curl/bugs/1196/>
|
||||||
* for details. */
|
* for details. */
|
||||||
static void parse_cert_parameter(const char *cert_parameter,
|
#ifndef UNITTESTS
|
||||||
char **certname,
|
static
|
||||||
char **passphrase)
|
#endif
|
||||||
|
void parse_cert_parameter(const char *cert_parameter,
|
||||||
|
char **certname,
|
||||||
|
char **passphrase)
|
||||||
{
|
{
|
||||||
size_t param_length = strlen(cert_parameter);
|
size_t param_length = strlen(cert_parameter);
|
||||||
size_t span;
|
size_t span;
|
||||||
|
@ -45,5 +45,11 @@ ParameterError getparameter(char *flag,
|
|||||||
bool *usedarg,
|
bool *usedarg,
|
||||||
struct Configurable *config);
|
struct Configurable *config);
|
||||||
|
|
||||||
|
#ifdef UNITTESTS
|
||||||
|
void parse_cert_parameter(const char *cert_parameter,
|
||||||
|
char **certname,
|
||||||
|
char **passphrase);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* HEADER_CURL_TOOL_GETPARAM_H */
|
#endif /* HEADER_CURL_TOOL_GETPARAM_H */
|
||||||
|
|
||||||
|
30
tests/data/test1394
Normal file
30
tests/data/test1394
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
<testcase>
|
||||||
|
<info>
|
||||||
|
<keywords>
|
||||||
|
unittest
|
||||||
|
</keywords>
|
||||||
|
</info>
|
||||||
|
|
||||||
|
#
|
||||||
|
# Client-side
|
||||||
|
<client>
|
||||||
|
<server>
|
||||||
|
none
|
||||||
|
</server>
|
||||||
|
<features>
|
||||||
|
unittest
|
||||||
|
</features>
|
||||||
|
<name>
|
||||||
|
unit test for parse_cert_parameter()
|
||||||
|
</name>
|
||||||
|
<tool>
|
||||||
|
unit1394
|
||||||
|
</tool>
|
||||||
|
</client>
|
||||||
|
|
||||||
|
<verify>
|
||||||
|
<stdout mode="text">
|
||||||
|
</stdout>
|
||||||
|
</verify>
|
||||||
|
|
||||||
|
</testcase>
|
@ -6,7 +6,7 @@ UNITFILES = curlcheck.h \
|
|||||||
|
|
||||||
# These are all unit test programs
|
# These are all unit test programs
|
||||||
UNITPROGS = unit1300 unit1301 unit1302 unit1303 unit1304 unit1305 unit1307 \
|
UNITPROGS = unit1300 unit1301 unit1302 unit1303 unit1304 unit1305 unit1307 \
|
||||||
unit1308 unit1309 unit1330
|
unit1308 unit1309 unit1330 unit1394
|
||||||
|
|
||||||
unit1300_SOURCES = unit1300.c $(UNITFILES)
|
unit1300_SOURCES = unit1300.c $(UNITFILES)
|
||||||
unit1300_CPPFLAGS = $(AM_CPPFLAGS)
|
unit1300_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
@ -38,3 +38,6 @@ unit1309_CPPFLAGS = $(AM_CPPFLAGS)
|
|||||||
unit1330_SOURCES = unit1330.c $(UNITFILES)
|
unit1330_SOURCES = unit1330.c $(UNITFILES)
|
||||||
unit1330_CPPFLAGS = $(AM_CPPFLAGS)
|
unit1330_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
|
|
||||||
|
unit1394_SOURCES = unit1394.c $(UNITFILES)
|
||||||
|
unit1394_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
|
|
||||||
|
@ -1,9 +1,48 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 2013, 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 http://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 "tool_getparam.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
int main(int argc, char **argv) {
|
#include "curl_memory.h"
|
||||||
char *values[] = {
|
#include "memdebug.h" /* LAST include file */
|
||||||
|
|
||||||
|
static CURLcode unit_setup(void)
|
||||||
|
{
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void unit_stop(void)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
UNITTEST_START
|
||||||
|
|
||||||
|
const char *values[] = {
|
||||||
/* -E parameter */ /* exp. cert name */ /* exp. passphrase */
|
/* -E parameter */ /* exp. cert name */ /* exp. passphrase */
|
||||||
"foo:bar:baz", "foo", "bar:baz",
|
"foo:bar:baz", "foo", "bar:baz",
|
||||||
"foo\\:bar:baz", "foo:bar", "baz",
|
"foo\\:bar:baz", "foo:bar", "baz",
|
||||||
@ -18,6 +57,7 @@ int main(int argc, char **argv) {
|
|||||||
"foo:bar\\\\", "foo", "bar\\\\",
|
"foo:bar\\\\", "foo", "bar\\\\",
|
||||||
"foo:bar:", "foo", "bar:",
|
"foo:bar:", "foo", "bar:",
|
||||||
"foo\\::bar\\:", "foo:", "bar\\:",
|
"foo\\::bar\\:", "foo:", "bar\\:",
|
||||||
|
#ifdef WIN32
|
||||||
"c:\\foo:bar:baz", "c:\\foo", "bar:baz",
|
"c:\\foo:bar:baz", "c:\\foo", "bar:baz",
|
||||||
"c:\\foo\\:bar:baz", "c:\\foo:bar", "baz",
|
"c:\\foo\\:bar:baz", "c:\\foo:bar", "baz",
|
||||||
"c:\\foo\\\\:bar:baz", "c:\\foo\\", "bar:baz",
|
"c:\\foo\\\\:bar:baz", "c:\\foo\\", "bar:baz",
|
||||||
@ -31,9 +71,10 @@ int main(int argc, char **argv) {
|
|||||||
"c:\\foo:bar\\\\", "c:\\foo", "bar\\\\",
|
"c:\\foo:bar\\\\", "c:\\foo", "bar\\\\",
|
||||||
"c:\\foo:bar:", "c:\\foo", "bar:",
|
"c:\\foo:bar:", "c:\\foo", "bar:",
|
||||||
"c:\\foo\\::bar\\:", "c:\\foo:", "bar\\:",
|
"c:\\foo\\::bar\\:", "c:\\foo:", "bar\\:",
|
||||||
|
#endif
|
||||||
NULL, NULL, NULL,
|
NULL, NULL, NULL,
|
||||||
};
|
};
|
||||||
char **p;
|
const char **p;
|
||||||
char *certname, *passphrase;
|
char *certname, *passphrase;
|
||||||
for(p = values; *p; p += 3) {
|
for(p = values; *p; p += 3) {
|
||||||
parse_cert_parameter(p[0], &certname, &passphrase);
|
parse_cert_parameter(p[0], &certname, &passphrase);
|
||||||
@ -42,15 +83,18 @@ int main(int argc, char **argv) {
|
|||||||
if(strcmp(p[1], certname)) {
|
if(strcmp(p[1], certname)) {
|
||||||
printf("expected certname '%s' but got '%s' "
|
printf("expected certname '%s' but got '%s' "
|
||||||
"for -E param '%s'\n", p[1], certname, p[0]);
|
"for -E param '%s'\n", p[1], certname, p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
printf("expected certname '%s' but got NULL "
|
printf("expected certname '%s' but got NULL "
|
||||||
"for -E param '%s'\n", p[1], p[0]);
|
"for -E param '%s'\n", p[1], p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(certname) {
|
if(certname) {
|
||||||
printf("expected certname NULL but got '%s' "
|
printf("expected certname NULL but got '%s' "
|
||||||
"for -E param '%s'\n", certname, p[0]);
|
"for -E param '%s'\n", certname, p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(p[2]) {
|
if(p[2]) {
|
||||||
@ -58,18 +102,22 @@ int main(int argc, char **argv) {
|
|||||||
if(strcmp(p[2], passphrase)) {
|
if(strcmp(p[2], passphrase)) {
|
||||||
printf("expected passphrase '%s' but got '%s'"
|
printf("expected passphrase '%s' but got '%s'"
|
||||||
"for -E param '%s'\n", p[2], passphrase, p[0]);
|
"for -E param '%s'\n", p[2], passphrase, p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
printf("expected passphrase '%s' but got NULL "
|
printf("expected passphrase '%s' but got NULL "
|
||||||
"for -E param '%s'\n", p[2], p[0]);
|
"for -E param '%s'\n", p[2], p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if(passphrase) {
|
if(passphrase) {
|
||||||
printf("expected passphrase NULL but got '%s' "
|
printf("expected passphrase NULL but got '%s' "
|
||||||
"for -E param '%s'\n", passphrase, p[0]);
|
"for -E param '%s'\n", passphrase, p[0]);
|
||||||
|
fail("assertion failure");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(certname) free(certname);
|
if(certname) free(certname);
|
||||||
if(passphrase) free(passphrase);
|
if(passphrase) free(passphrase);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
UNITTEST_STOP
|
||||||
|
Loading…
x
Reference in New Issue
Block a user