/*
** Copyright 2001-2005 Double Precision, Inc.
** See COPYING for distribution information.
*/

#include	"config.h"
#include	"sha1.h"
#include	<stdio.h>
#include	<stdlib.h>
#include	<string.h>

static const char rcsid[]="$Id: testsuite.c,v 1.3 2005/02/21 03:18:31 mrsam Exp $";

static char foo[1000001];

static void sha1()
{
SHA1_DIGEST	digest;
unsigned i, n;

static char *testcases[]={"abc",
"abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq", foo};

	for (n=0; n<sizeof(testcases)/sizeof(testcases[0]); n++)
	{
		i=strlen(testcases[n]);
		sha1_digest(testcases[n], i, digest);
		printf( (i < 200 ? "SHA1(%s)=":
			"SHA1(%-1.20s...)="), testcases[n]);

		for (i=0; i<20; i++)
		{
			if (i && (i & 3) == 0)	putchar(' ');
			printf("%02X", digest[i]);
		}
		printf("\n");
	}
}

static void sha256()
{
	SHA256_DIGEST	digest;
	unsigned i, n;

	static char *testcases[]={"abc",
				  "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq",
				  foo};

	for (n=0; n<sizeof(testcases)/sizeof(testcases[0]); n++)
	{
		i=strlen(testcases[n]);
		sha256_digest(testcases[n], i, digest);
		printf( (i < 200 ? "SHA256(%s)=":
			 "SHA1(%-1.20s...)="), testcases[n]);

		for (i=0; i<sizeof(digest); i++)
		{
			if (i && (i & 3) == 0)	putchar(' ');
			printf("%02X", digest[i]);
		}
		printf("\n");
	}
}

int main()
{
	memset(foo, 'a', 1000000);
	sha1();
	sha256();
	exit (0);
	return (0);
}


syntax highlighted by Code2HTML, v. 0.9.1