From d1dac7891cd3234c935ce7e4d742b6f87663a5e1 Mon Sep 17 00:00:00 2001 From: Christian Mauderer Date: Tue, 26 Mar 2019 11:08:47 +0100 Subject: bin/openssl: Port to RTEMS. --- testsuite/openssl02/test_main.c | 135 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 135 insertions(+) create mode 100644 testsuite/openssl02/test_main.c (limited to 'testsuite') diff --git a/testsuite/openssl02/test_main.c b/testsuite/openssl02/test_main.c new file mode 100644 index 00000000..ccd48dc9 --- /dev/null +++ b/testsuite/openssl02/test_main.c @@ -0,0 +1,135 @@ +/* + * Copyright (c) 2013-2019 embedded brains GmbH. All rights reserved. + * + * embedded brains GmbH + * Dornierstr. 4 + * 82178 Puchheim + * Germany + * + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + */ + +#include + +#include +#include +#include +#include +#include + +#include + +#include +#include + +#include +#include + +#define TEST_NAME "LIBBSD OPENSSL 2" + +#define ARGC(x) RTEMS_BSD_ARGC(x) + +#ifdef RTEMS_BSD_MODULE_USR_BIN_OPENSSL +static void +test_cmd_gencert(void) +{ + int fd; + int rv; + struct stat sb; + char *openssl_gencert[] = { + "openssl", + "req", + "-config", + "/openssl.cfg", + "-nodes", + "-newkey", + "rsa:2048", + "-keyout", + "/example.key", + "-out", + "example.csr", + "-subj", + "/C=GB/ST=London/L=London/O=Global Security/OU=IT Department/CN=example.com", + NULL + }; + + static const char config[] = + "[ req ]\n" + "distinguished_name = req_distinguished_name\n" + "[ req_distinguished_name ]\n" + "countryName = Country Name (2 letter code)\n" + "stateOrProvinceName = State or Province Name (full name)\n" + "localityName = Locality Name (eg, city)\n" + "0.organizationName = Organization Name (eg, company)\n" + "0.organizationName_default = Internet Widgits Pty Ltd\n" + "organizationalUnitName = Organizational Unit Name (eg, section)\n" + "organizationalUnitName_default =\n" + "commonName = Common Name (e.g. server FQDN or YOUR name)\n" + "commonName_max = 64\n" + "emailAddress = Email Address\n" + "emailAddress_max = 64\n"; + + /* Create config file. */ + fd = open("/openssl.cfg", O_WRONLY | O_CREAT, S_IRWXU | S_IRWXG | S_IRWXO); + assert(fd != -1); + rv = write(fd, config, sizeof(config)); + assert(rv == sizeof(config)); + rv = close(fd); + assert(rv == 0); + + rtems_bsd_command_openssl(ARGC(openssl_gencert), openssl_gencert); + + assert(stat("/example.key", &sb) == 0); + assert(stat("/example.csr", &sb) == 0); +} + +static void +test_cmd_speed(void) +{ + int fd; + int rv; + struct stat sb; + char *openssl_speed[] = { + "openssl", + "speed", + "sha1", + NULL + }; + + rtems_bsd_command_openssl(ARGC(openssl_speed), openssl_speed); +} +#endif /* RTEMS_BSD_MODULE_USR_BIN_OPENSSL */ + +static void +test_main(void) +{ +#ifdef RTEMS_BSD_MODULE_USR_BIN_OPENSSL + test_cmd_gencert(); + test_cmd_speed(); +#else /* ! RTEMS_BSD_MODULE_USR_BIN_OPENSSL */ + puts("openssl command not enabled in the current build set"); +#endif /* RTEMS_BSD_MODULE_USR_BIN_OPENSSL */ + exit(0); +} + +#include -- cgit v1.2.3