From 1022e754f4b164e2130639d6d83c8c527d999bde Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Tue, 4 Jan 2011 16:42:31 +0100 Subject: unittest: test base64 encode/decode --- tests/data/test1302 | 26 ++++++++++++++++ tests/unit/Makefile.inc | 3 +- tests/unit/unit1302.c | 82 +++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 110 insertions(+), 1 deletion(-) create mode 100644 tests/data/test1302 create mode 100644 tests/unit/unit1302.c diff --git a/tests/data/test1302 b/tests/data/test1302 new file mode 100644 index 000000000..bf6ea3b83 --- /dev/null +++ b/tests/data/test1302 @@ -0,0 +1,26 @@ + + + +unittest +llist + + + +# +# Client-side + + +none + + +unittest + + +base64 encode/decode unit tests + + +unit1302 + + + + diff --git a/tests/unit/Makefile.inc b/tests/unit/Makefile.inc index adfcc4420..e56279049 100644 --- a/tests/unit/Makefile.inc +++ b/tests/unit/Makefile.inc @@ -3,7 +3,8 @@ UNITFILES = curlcheck.h # These are all unit test programs -noinst_PROGRAMS = unit1300 unit1301 +noinst_PROGRAMS = unit1300 unit1301 unit1302 unit1300_SOURCES = unit1300.c $(UNITFILES) unit1301_SOURCES = unit1301.c $(UNITFILES) +unit1302_SOURCES = unit1302.c $(UNITFILES) diff --git a/tests/unit/unit1302.c b/tests/unit/unit1302.c new file mode 100644 index 000000000..d300a14ee --- /dev/null +++ b/tests/unit/unit1302.c @@ -0,0 +1,82 @@ +#include +#include "curl_config.h" +#include "setup.h" + +#include "urldata.h" +#include "curl_base64.h" +#include "curlcheck.h" +#include "memdebug.h" /* LAST include file */ + +static struct SessionHandle *data; + +static void unit_setup( void ) +{ + data = curl_easy_init(); +} +static void unit_stop( void ) +{ + curl_easy_cleanup(data); +} + +UNITTEST_START + +char *output; +unsigned char *decoded; +size_t rc; + +rc = Curl_base64_encode(data, "i", 1, &output); +fail_unless( rc == 4 , "return code should be 4" ); +verify_memory( output, "aQ==", 4); +free(output); + +rc = Curl_base64_encode(data, "ii", 2, &output); +fail_unless( rc == 4 , "return code should be 4" ); +verify_memory( output, "aWk=", 4); +free(output); + +rc = Curl_base64_encode(data, "iii", 3, &output); +fail_unless( rc == 4 , "return code should be 4" ); +verify_memory( output, "aWlp", 4); +free(output); + +rc = Curl_base64_encode(data, "iiii", 4, &output); +fail_unless( rc == 8 , "return code should be 8" ); +verify_memory( output, "aWlpaQ==", 8); +free(output); + +/* 0 length makes it do strlen() */ +rc = Curl_base64_encode(data, "iiii", 0, &output); +fail_unless( rc == 8 , "return code should be 8" ); +verify_memory( output, "aWlpaQ==", 8); +free(output); + +rc = Curl_base64_decode("aWlpaQ==", &decoded); +fail_unless(rc == 4, "return code should be 4"); +verify_memory(decoded, "iiii", 4); +free(decoded); + +rc = Curl_base64_decode("aWlp", &decoded); +fail_unless(rc == 3, "return code should be 3"); +verify_memory(decoded, "iii", 3); +free(decoded); + +rc = Curl_base64_decode("aWk=", &decoded); +fail_unless(rc == 2, "return code should be 2"); +verify_memory(decoded, "ii", 2); +free(decoded); + +rc = Curl_base64_decode("aQ==", &decoded); +fail_unless(rc == 1, "return code should be 1"); +verify_memory(decoded, "i", 2); +free(decoded); + +/* this is an illegal input */ +rc = Curl_base64_decode("aQ", &decoded); +fail_unless(rc == 0, "return code should be 0"); + +/* this is garbage input that libcurl decodes as far as possible */ +rc = Curl_base64_decode("a\x1f==", &decoded); +fail_unless(rc == 1, "return code should be 1"); +free(decoded); + +UNITTEST_STOP -- cgit v1.2.3