diff options
| author | Lennart Poettering <lennart@poettering.net> | 2016-02-21 21:22:55 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2016-02-21 21:22:55 +0100 | 
| commit | c7044f9ed295ca2d83bcd0059a86a9443361eaec (patch) | |
| tree | 4a16b1d792d13da8b7bd27045c12f7fcd29b816c /src/test | |
| parent | 714c62b46379abb7558c544665522aca91691e10 (diff) | |
| parent | fdd21be6f5f0360c4627bcf5a7957e69ad08be74 (diff) | |
Merge pull request #2681 from keszybz/udev-rules
udev-rules cleanup and coverity warning silencing
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/test-siphash24.c | 47 | 
1 files changed, 44 insertions, 3 deletions
| diff --git a/src/test/test-siphash24.c b/src/test/test-siphash24.c index caae911f30..b74b7ad2dd 100644 --- a/src/test/test-siphash24.c +++ b/src/test/test-siphash24.c @@ -22,9 +22,9 @@  #define ITERATIONS 10000000ULL -static int do_test(const uint8_t *in, size_t len, const uint8_t *key) { +static void do_test(const uint8_t *in, size_t len, const uint8_t *key) {          struct siphash state = {}; -        uint64_t out = 0; +        uint64_t out;          unsigned i, j;          out = siphash24(in, len, key); @@ -60,7 +60,46 @@ static int do_test(const uint8_t *in, size_t len, const uint8_t *key) {                          assert_se(out == 0xa129ca6149be45e5);                  }          } -        return 0; +} + +static void test_short_hashes(void) { +        const uint8_t one[] = { 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, +                                0x09, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16 }; +        const uint8_t  key[16] = { 0x22, 0x24, 0x41, 0x22, 0x55, 0x77, 0x88, 0x07, +                                   0x23, 0x09, 0x23, 0x14, 0x0c, 0x33, 0x0e, 0x0f}; +        uint8_t two[sizeof one] = {}; + +        struct siphash state1 = {}, state2 = {}; +        unsigned i, j; + +        siphash24_init(&state1, key); +        siphash24_init(&state2, key); + +        /* hashing 1, 2, 3, 4, 5, ..., 16 bytes, with the byte after the buffer different */ +        for (i = 1; i <= sizeof one; i++) { +                siphash24_compress(one, i, &state1); + +                two[i-1] = one[i-1]; +                siphash24_compress(two, i, &state2); + +                assert_se(memcmp(&state1, &state2, sizeof state1) == 0); +        } + +        /* hashing n and 1, n and 2, n and 3, ..., n-1 and 1, n-2 and 2, ... */ +        for (i = sizeof one; i > 0; i--) { +                zero(two); + +                for (j = 1; j <= sizeof one; j++) { +                        siphash24_compress(one, i, &state1); +                        siphash24_compress(one, j, &state1); + +                        siphash24_compress(one, i, &state2); +                        two[j-1] = one[j-1]; +                        siphash24_compress(two, j, &state2); + +                        assert_se(memcmp(&state1, &state2, sizeof state1) == 0); +                } +        }  }  /* see https://131002.net/siphash/siphash.pdf, Appendix A */ @@ -80,4 +119,6 @@ int main(int argc, char *argv[]) {          do_test(in_buf + 2, sizeof(in), key);          memcpy(in_buf + 4, in, sizeof(in));          do_test(in_buf + 4, sizeof(in), key); + +        test_short_hashes();  } | 
