/*- * Copyright (c) 2015 Dag-Erling Smørgrav * All rights reserved. * * 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. * 3. The name of the author may not be used to endorse or promote * products derived from this software without specific prior written * permission. * * 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 "cryb/impl.h" #include #include #include #include "t.h" struct t_case { const char *desc; const char *data; size_t len; uint32_t sum; }; /*************************************************************************** * Test cases */ static struct t_case t_cases[] = { { .desc = "len == 0", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 0, .sum = 0x00000001, }, { .desc = "len == 1", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 1, .sum = 0x00020002, }, { .desc = "len == 2", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 2, .sum = 0x00060004, }, { .desc = "len == 3", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 3, .sum = 0x000d0007, }, { .desc = "len == 4", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 4, .sum = 0x0018000b, }, { .desc = "len == 5", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 5, .sum = 0x00280010, }, { .desc = "len == 6", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 6, .sum = 0x003e0016, }, { .desc = "len == 7", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 7, .sum = 0x005b001d, }, { .desc = "len == 8", .data = "\x01\x02\x03\x04\x05\x06\x07\x08", .len = 8, .sum = 0x00800025, }, { .desc = "zeroes", .data = (const char *)t_zero, .len = sizeof t_zero, .sum = (sizeof t_zero << 16) | 1, }, /* XXX need non-zero cases which exercise modulo */ }; /*************************************************************************** * Test function */ static int t_adler(char **desc CRYB_UNUSED, void *arg) { struct t_case *t = arg; int ret; ret = t_compare_x32(t->sum, adler32_hash(t->data, t->len)); return (ret); } /*************************************************************************** * Boilerplate */ int t_prepare(int argc, char *argv[]) { int i, n; (void)argc; (void)argv; n = sizeof t_cases / sizeof t_cases[0]; for (i = 0; i < n; ++i) t_add_test(t_adler, &t_cases[i], t_cases[i].desc); return (0); } void t_cleanup(void) { }