Blame tests/random-art.c

Packit aea12f
/*
Packit aea12f
 * Copyright (C) 2016, 2017 Red Hat, Inc.
Packit aea12f
 *
Packit aea12f
 * Author: Nikos Mavrogiannopoulos
Packit aea12f
 *
Packit aea12f
 * This file is part of GnuTLS.
Packit aea12f
 *
Packit aea12f
 * GnuTLS is free software; you can redistribute it and/or modify it
Packit aea12f
 * under the terms of the GNU General Public License as published by
Packit aea12f
 * the Free Software Foundation; either version 3 of the License, or
Packit aea12f
 * (at your option) any later version.
Packit aea12f
 *
Packit aea12f
 * GnuTLS is distributed in the hope that it will be useful, but
Packit aea12f
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit aea12f
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit aea12f
 * General Public License for more details.
Packit aea12f
 *
Packit aea12f
 * You should have received a copy of the GNU General Public License
Packit aea12f
 * along with GnuTLS; if not, write to the Free Software Foundation,
Packit aea12f
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
Packit aea12f
 */
Packit aea12f
Packit aea12f
/* Parts copied from GnuTLS example programs. */
Packit aea12f
Packit aea12f
#ifdef HAVE_CONFIG_H
Packit aea12f
#include <config.h>
Packit aea12f
#endif
Packit aea12f
Packit aea12f
#include <stdio.h>
Packit aea12f
#include <stdlib.h>
Packit aea12f
Packit aea12f
#include <string.h>
Packit aea12f
#include <gnutls/gnutls.h>
Packit aea12f
Packit aea12f
#include "utils.h"
Packit aea12f
Packit aea12f
/* This checks random art encoding */
Packit aea12f
Packit aea12f
static void encode(const char *test_name, const char *type, unsigned key_size, unsigned char *input, unsigned input_size, const char *expected)
Packit aea12f
{
Packit aea12f
	int ret;
Packit aea12f
	gnutls_datum_t out;
Packit aea12f
Packit aea12f
	ret = gnutls_random_art(GNUTLS_RANDOM_ART_OPENSSH, type, key_size, input, input_size, &out;;
Packit aea12f
	if (ret < 0) {
Packit aea12f
		fail("%s: gnutls_random_art: %s\n", test_name, gnutls_strerror(ret));
Packit aea12f
		exit(1);
Packit aea12f
	}
Packit aea12f
Packit aea12f
	if (strlen(expected)!=out.size) {
Packit aea12f
		fail("%s: gnutls_random_art: output has incorrect size (%d, expected %d)\n%s\n", test_name, (int)out.size, (int)strlen(expected), out.data);
Packit aea12f
		exit(1);
Packit aea12f
	}
Packit aea12f
Packit aea12f
	if (strncasecmp(expected, (char*)out.data, out.size) != 0) {
Packit aea12f
		fail("%s: gnutls_random_art: output does not match the expected:\n%s\n", test_name, out.data);
Packit aea12f
		exit(1);
Packit aea12f
	}
Packit aea12f
Packit aea12f
	gnutls_free(out.data);
Packit aea12f
Packit aea12f
	return;
Packit aea12f
}
Packit aea12f
Packit aea12f
Packit aea12f
struct encode_tests_st {
Packit aea12f
	const char *name;
Packit aea12f
	unsigned char *raw;
Packit aea12f
	unsigned raw_size;
Packit aea12f
	const char *key_type;
Packit aea12f
	unsigned key_size;
Packit aea12f
	const char *art;
Packit aea12f
};
Packit aea12f
Packit aea12f
struct encode_tests_st encode_tests[] = {
Packit aea12f
	{
Packit aea12f
		.name = "key1",
Packit aea12f
		.raw = (void*)"\x38\x17\x0c\x08\xcb\x45\x8f\xd4\x87\x9c\x34\xb6\xf6\x08\x29\x4c\x50\x31\x2b\xbb",
Packit aea12f
		.raw_size = 20,
Packit aea12f
		.key_type = "RSA",
Packit aea12f
		.key_size = 2048,
Packit aea12f
		.art =	"+--[ RSA 2048]----+\n"
Packit aea12f
			"|.o*++==o         |\n"
Packit aea12f
			"| + *.===.        |\n"
Packit aea12f
			"|. * + +.o        |\n"
Packit aea12f
			"| o . o + .       |\n"
Packit aea12f
			"|.     + S        |\n"
Packit aea12f
			"| .     o         |\n"
Packit aea12f
			"|E                |\n"
Packit aea12f
			"|                 |\n"
Packit aea12f
			"|                 |\n"
Packit aea12f
			"+-----------------+"
Packit aea12f
	},
Packit aea12f
	{
Packit aea12f
		.name = "key2",
Packit aea12f
		.raw = (void*)"\xf8\xa7\x1c\x08\x76\x47\x2c\x08\x38\x17\x0c\x08\x38\x17\x0c\x08\xcb\x45\x8f\xd4\x87\x9c\xa4\xb6\xf6\xf8\x29\xfc\x50\x3f\x2b\xbb",
Packit aea12f
		.raw_size = 32,
Packit aea12f
		.key_type = "RSA",
Packit aea12f
		.key_size = 3072,
Packit aea12f
		.art =	"+--[ RSA 3072]----+\n"
Packit aea12f
			"|@*=*+.o          |\n"
Packit aea12f
			"|O.B.+* o         |\n"
Packit aea12f
			"|.* +..o o        |\n"
Packit aea12f
			"|  . .  +         |\n"
Packit aea12f
			"|   oo.o S        |\n"
Packit aea12f
			"|  ..+o.+         |\n"
Packit aea12f
			"|  .o ..oo .      |\n"
Packit aea12f
			"|   oo...o+       |\n"
Packit aea12f
			"|    oE+.o        |\n"
Packit aea12f
			"+-----------------+"
Packit aea12f
	},
Packit aea12f
	{
Packit aea12f
		.name = "key3",
Packit aea12f
		.raw = (void*)"\x38\xf7\x0c\x08\xcb\x34\x8a\xd4\xb7\x9c\x34\xb4\xf6\x08\x29\x4c\x50\x3f\x2b\xbb",
Packit aea12f
		.raw_size = 20,
Packit aea12f
		.key_type = "ECDSA",
Packit aea12f
		.key_size = 256,
Packit aea12f
		.art =	"+--[ECDSA  256]---+\n"
Packit aea12f
			"|oo.  .           |\n"
Packit aea12f
			"|o ..o .          |\n"
Packit aea12f
			"| + +**           |\n"
Packit aea12f
			"|...+***o         |\n"
Packit aea12f
			"|. o +=+.S        |\n"
Packit aea12f
			"|   o   o +       |\n"
Packit aea12f
			"|  .       o      |\n"
Packit aea12f
			"|   .             |\n"
Packit aea12f
			"|  E              |\n"
Packit aea12f
			"+-----------------+"
Packit aea12f
	}
Packit aea12f
};
Packit aea12f
Packit aea12f
void doit(void)
Packit aea12f
{
Packit aea12f
	unsigned i;
Packit aea12f
Packit aea12f
	for (i=0;i
Packit aea12f
		encode(encode_tests[i].name, encode_tests[i].key_type, encode_tests[i].key_size,
Packit aea12f
			encode_tests[i].raw, encode_tests[i].raw_size, encode_tests[i].art);
Packit aea12f
	}
Packit aea12f
}
Packit aea12f