summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikos Mavrogiannopoulos <nmav@gnutls.org>2016-04-29 19:02:45 +0200
committerNikos Mavrogiannopoulos <nmav@gnutls.org>2016-04-29 19:02:45 +0200
commit6d9b6f4a44eb5228ac26c22a0f7be47ed4bf39ce (patch)
treeb50828958064c404ee944c73134c0b94bc290998
parent754a98026825b6c3cf8022266f84aeebf57bda8d (diff)
downloadgnutls-6d9b6f4a44eb5228ac26c22a0f7be47ed4bf39ce.tar.gz
tests: added checks for base64 functions
-rw-r--r--tests/Makefile.am2
-rw-r--r--tests/base64.c211
-rw-r--r--tests/srpbase64.c177
3 files changed, 389 insertions, 1 deletions
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 63719a7efe..ff2c027fc5 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -100,7 +100,7 @@ ctests = mini-record-2 simple gc set_pkcs12_cred certder certuniqueid \
handshake-false-start version-checks key-material-dtls key-material-set-dtls \
system-prio-file name-constraints-merge crl-basic crq-basic \
send-client-cert custom-urls-override hex rehandshake-switch-psk-id \
- rehandshake-switch-srp-id
+ rehandshake-switch-srp-id base64 srpbase64
if HAVE_SECCOMP_TESTS
ctests += dtls-with-seccomp tls-with-seccomp dtls-client-with-seccomp tls-client-with-seccomp
diff --git a/tests/base64.c b/tests/base64.c
new file mode 100644
index 0000000000..65af597068
--- /dev/null
+++ b/tests/base64.c
@@ -0,0 +1,211 @@
+/*
+ * Copyright (C) 2016 Red Hat, Inc.
+ *
+ * Author: Nikos Mavrogiannopoulos
+ *
+ * This file is part of GnuTLS.
+ *
+ * GnuTLS is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GnuTLS is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with GnuTLS; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+/* Parts copied from GnuTLS example programs. */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include <string.h>
+#include <gnutls/gnutls.h>
+
+#include "utils.h"
+
+static void encode(const char *test_name, const gnutls_datum_t *raw, const char *expected)
+{
+ int ret;
+ gnutls_datum_t out, in;
+
+ ret = gnutls_pem_base64_encode2(test_name, raw, &out);
+ if (ret < 0) {
+ fail("%s: gnutls_pem_base64_encode2: %s\n", test_name, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (strlen(expected)!=out.size) {
+ fail("%s: gnutls_pem_base64_encode2: output has incorrect size (%d, expected %d)\n", test_name, (int)out.size, (int)strlen(expected));
+ exit(1);
+ }
+
+ if (strncasecmp(expected, (char*)out.data, out.size) != 0) {
+ fail("%s: gnutls_pem_base64_encode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ in.data = (void*)expected;
+ in.size = strlen(expected);
+ ret = gnutls_pem_base64_decode2(test_name, &in, &out);
+ if (ret < 0) {
+ fail("%s: gnutls_pem_base64_decode2: %s\n", test_name, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (raw->size!=out.size) {
+ fail("%s: gnutls_pem_base64_decode2: output has incorrect size (%d, expected %d)\n", test_name, out.size, raw->size);
+ exit(1);
+ }
+
+ if (memcmp(raw->data, out.data, out.size) != 0) {
+ fail("%s: gnutls_pem_base64_decode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ return;
+}
+
+static void decode(const char *test_name, const gnutls_datum_t *raw, const char *hex, int res)
+{
+ int ret;
+ gnutls_datum_t out, in;
+
+ in.data = (void*)hex;
+ in.size = strlen(hex);
+ ret = gnutls_pem_base64_decode2(test_name, &in, &out);
+ if (ret < 0) {
+ if (res == ret) /* expected */
+ return;
+ fail("%s: gnutls_pem_base64_decode2: %d/%s\n", test_name, ret, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (res != 0) {
+ fail("%s: gnutls_pem_base64_decode2: expected failure, but succeeded!\n", test_name);
+ exit(1);
+ }
+
+ if (raw->size!=out.size) {
+ fail("%s: gnutls_pem_base64_decode2: output has incorrect size (%d, expected %d)\n", test_name, out.size, raw->size);
+ exit(1);
+ }
+
+ if (memcmp(raw->data, out.data, out.size) != 0) {
+ fail("%s: gnutls_pem_base64_decode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ return;
+}
+
+struct encode_tests_st {
+ const char *name;
+ gnutls_datum_t raw;
+ const char *pem;
+};
+
+struct encode_tests_st encode_tests[] = {
+ {
+ .name = "rnd1",
+ .pem = "-----BEGIN rnd1-----\n"
+ "9ppGioRpeiiD2lLNYC85eA==\n"
+ "-----END rnd1-----\n",
+ .raw = {(void*)"\xf6\x9a\x46\x8a\x84\x69\x7a\x28\x83\xda\x52\xcd\x60\x2f\x39\x78", 16}
+ },
+ {
+ .name = "rnd2",
+ .pem = "-----BEGIN rnd2-----\n"
+ "LJ/7hUZ3TtPIz2dlc5+YvELe+Q==\n"
+ "-----END rnd2-----\n",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19}
+ }
+};
+
+struct decode_tests_st {
+ const char *name;
+ gnutls_datum_t raw;
+ const char *pem;
+ int res;
+};
+
+struct decode_tests_st decode_tests[] = {
+ {
+ .name = "dec-rnd1",
+ .pem = "-----BEGIN dec-rnd1-----\n"
+ "9ppGioRpeiiD2lLNYC85eA==\n"
+ "-----END rnd1-----\n",
+ .raw = {(void*)"\xf6\x9a\x46\x8a\x84\x69\x7a\x28\x83\xda\x52\xcd\x60\x2f\x39\x78", 16},
+ .res = 0
+ },
+ {
+ .name = "dec-rnd2",
+ .pem = "-----BEGIN dec-rnd2-----\n"
+ "LJ/7hUZ3TtPIz2dlc5+YvELe+Q==\n"
+ "-----END rnd2-----\n",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = 0
+ },
+ {
+ .name = "dec-extra-chars",
+ .pem = "-----BEGIN dec-extra-chars----- \n\n"
+ "\n\n LJ/7hUZ3TtPIz2dlc5+YvELe+Q== \n"
+ " -----END rnd2----- \n ",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = 0
+ },
+ {
+ .name = "dec-invalid-header",
+ .pem = "-----BEGIN dec-xxx-----\n"
+ "LJ/7hUZ3TtPIz2dlc5+YvELe+Q==\n"
+ "-----END rnd2-----\n",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = GNUTLS_E_BASE64_UNEXPECTED_HEADER_ERROR
+ },
+ {
+ .name = "dec-invalid-data",
+ .pem = "-----BEGIN dec-invalid-data-----\n"
+ "XLJ/7hUZ3TtPIz2dlc5+YvELe+Q==\n"
+ "-----END rnd2-----\n",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = GNUTLS_E_BASE64_DECODING_ERROR
+ },
+ {
+ .name = "dec-invalid-suffix",
+ .pem = "-----BEGIN dec-invalid-suffix-----\n"
+ "LJ/7hUZ3TtPIz2dlc5+YvELe+Q==XXX\n"
+ "-----END rnd2-----\n",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = GNUTLS_E_BASE64_DECODING_ERROR
+ }
+};
+
+void doit(void)
+{
+ unsigned i;
+
+ for (i=0;i<sizeof(encode_tests)/sizeof(encode_tests[0]);i++) {
+ encode(encode_tests[i].name, &encode_tests[i].raw, encode_tests[i].pem);
+ }
+
+ for (i=0;i<sizeof(decode_tests)/sizeof(decode_tests[0]);i++) {
+ decode(decode_tests[i].name, &decode_tests[i].raw, decode_tests[i].pem, decode_tests[i].res);
+ }
+}
+
diff --git a/tests/srpbase64.c b/tests/srpbase64.c
new file mode 100644
index 0000000000..80c1752cc2
--- /dev/null
+++ b/tests/srpbase64.c
@@ -0,0 +1,177 @@
+/*
+ * Copyright (C) 2016 Red Hat, Inc.
+ *
+ * Author: Nikos Mavrogiannopoulos
+ *
+ * This file is part of GnuTLS.
+ *
+ * GnuTLS is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * GnuTLS is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with GnuTLS; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+/* Parts copied from GnuTLS example programs. */
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include <string.h>
+#include <gnutls/gnutls.h>
+
+#include "utils.h"
+
+static void encode(const char *test_name, const gnutls_datum_t *raw, const char *expected)
+{
+ int ret;
+ gnutls_datum_t out, in;
+
+ ret = gnutls_srp_base64_encode2(raw, &out);
+ if (ret < 0) {
+ fail("%s: gnutls_srp_base64_encode2: %s\n", test_name, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (strlen(expected)!=out.size) {
+ fail("%s: gnutls_srp_base64_encode2: output has incorrect size (%d, expected %d)\n", test_name, (int)out.size, (int)strlen(expected));
+ exit(1);
+ }
+
+ if (strncasecmp(expected, (char*)out.data, out.size) != 0) {
+ fail("%s: gnutls_srp_base64_encode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ in.data = (void*)expected;
+ in.size = strlen(expected);
+ ret = gnutls_srp_base64_decode2(&in, &out);
+ if (ret < 0) {
+ fail("%s: gnutls_srp_base64_decode2: %s\n", test_name, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (raw->size!=out.size) {
+ fail("%s: gnutls_srp_base64_decode2: output has incorrect size (%d, expected %d)\n", test_name, out.size, raw->size);
+ exit(1);
+ }
+
+ if (memcmp(raw->data, out.data, out.size) != 0) {
+ fail("%s: gnutls_srp_base64_decode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ return;
+}
+
+static void decode(const char *test_name, const gnutls_datum_t *raw, const char *hex, int res)
+{
+ int ret;
+ gnutls_datum_t out, in;
+
+ in.data = (void*)hex;
+ in.size = strlen(hex);
+ ret = gnutls_srp_base64_decode2(&in, &out);
+ if (ret < 0) {
+ if (res == ret) /* expected */
+ return;
+ fail("%s: gnutls_srp_base64_decode2: %d/%s\n", test_name, ret, gnutls_strerror(ret));
+ exit(1);
+ }
+
+ if (res != 0) {
+ fail("%s: gnutls_srp_base64_decode2: expected failure, but succeeded!\n", test_name);
+ exit(1);
+ }
+
+ if (raw->size!=out.size) {
+ fail("%s: gnutls_srp_base64_decode2: output has incorrect size (%d, expected %d)\n", test_name, out.size, raw->size);
+ exit(1);
+ }
+
+ if (memcmp(raw->data, out.data, out.size) != 0) {
+ fail("%s: gnutls_srp_base64_decode2: output does not match the expected\n", test_name);
+ exit(1);
+ }
+
+ gnutls_free(out.data);
+
+ return;
+}
+
+struct encode_tests_st {
+ const char *name;
+ gnutls_datum_t raw;
+ const char *sb64;
+};
+
+struct encode_tests_st encode_tests[] = {
+ {
+ .name = "rnd1",
+ .sb64 = "3scaQAX6bwA8FQKirWBpbu",
+ .raw = {(void*)"\xf6\x9a\x46\x8a\x84\x69\x7a\x28\x83\xda\x52\xcd\x60\x2f\x39\x78", 16}
+ },
+ {
+ .name = "rnd2",
+ .sb64 = "id/k5HdTEqyZFPsLpdvYyGjxv",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19}
+ }
+};
+
+struct decode_tests_st {
+ const char *name;
+ gnutls_datum_t raw;
+ const char *sb64;
+ int res;
+};
+
+struct decode_tests_st decode_tests[] = {
+ {
+ .name = "dec-rnd1",
+ .sb64 = "3scaQAX6bwA8FQKirWBpbu",
+ .raw = {(void*)"\xf6\x9a\x46\x8a\x84\x69\x7a\x28\x83\xda\x52\xcd\x60\x2f\x39\x78", 16},
+ .res = 0
+ },
+ {
+ .name = "dec-rnd2",
+ .sb64 = "id/k5HdTEqyZFPsLpdvYyGjxv",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = 0
+ },
+ {
+ .name = "dec-extra-chars",
+ .sb64 = " id/k5HdTEqyZFPsLpdvYyGjxv ",
+ .raw = {(void*)"\x2c\x9f\xfb\x85\x46\x77\x4e\xd3\xc8\xcf\x67\x65\x73\x9f\x98\xbc\x42\xde\xf9", 19},
+ .res = GNUTLS_E_BASE64_DECODING_ERROR
+ }
+};
+
+void doit(void)
+{
+ unsigned i;
+
+ for (i=0;i<sizeof(encode_tests)/sizeof(encode_tests[0]);i++) {
+ encode(encode_tests[i].name, &encode_tests[i].raw, encode_tests[i].sb64);
+ }
+
+ for (i=0;i<sizeof(decode_tests)/sizeof(decode_tests[0]);i++) {
+ decode(decode_tests[i].name, &decode_tests[i].raw, decode_tests[i].sb64, decode_tests[i].res);
+ }
+}
+