chiark / gitweb /
Build fix for Linux
[disorder] / libtests / t-arcfour.c
CommitLineData
fcdff139
RK
1/*
2 * This file is part of DisOrder.
3 * Copyright (C) 2008 Richard Kettlewell
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
18 * USA
19 */
20#include "test.h"
21#include "arcfour.h"
22
23#define TEST_ARCFOUR(K, P, C) do { \
24 arcfour_setkey(ac, K, strlen(K)); \
25 arcfour_stream(ac, P, (char *)output, strlen(P)); \
26 output_hex = hex(output, strlen(P)); \
27 check_string(output_hex, C); \
28} while(0)
29
30static void test_arcfour(void) {
31 arcfour_context ac[1];
32 uint8_t output[64];
33 char *output_hex;
34
35 /* from wikipedia */
36 TEST_ARCFOUR("Key", "Plaintext", "bbf316e8d940af0ad3");
37 TEST_ARCFOUR("Wiki", "pedia", "1021bf0420");
38 TEST_ARCFOUR("Secret", "Attack at dawn", "45a01f645fc35b383552544b9bf5");
39
40}
41
42TEST(arcfour);
43
44/*
45Local Variables:
46c-basic-offset:2
47comment-column:40
48fill-column:79
49indent-tabs-mode:nil
50End:
51*/