api-hash_stable.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. #include "hash/hash.h"
  2. #include "tap/tap.h"
  3. #include <stdbool.h>
  4. #include <string.h>
  5. #define ARRAY_WORDS 5
  6. int main(int argc, char *argv[])
  7. {
  8. unsigned int i;
  9. uint8_t u8array[ARRAY_WORDS];
  10. uint16_t u16array[ARRAY_WORDS];
  11. uint32_t u32array[ARRAY_WORDS];
  12. uint64_t u64array[ARRAY_WORDS];
  13. /* Initialize arrays. */
  14. for (i = 0; i < ARRAY_WORDS; i++) {
  15. u8array[i] = i;
  16. u16array[i] = i;
  17. u32array[i] = i;
  18. u64array[i] = i;
  19. }
  20. plan_tests(132);
  21. /* hash_stable is API-guaranteed. */
  22. ok1(hash_stable(u8array, ARRAY_WORDS, 0) == 0x1d4833cc);
  23. ok1(hash_stable(u8array, ARRAY_WORDS, 1) == 0x37125e2 );
  24. ok1(hash_stable(u8array, ARRAY_WORDS, 2) == 0x330a007a);
  25. ok1(hash_stable(u8array, ARRAY_WORDS, 4) == 0x7b0df29b);
  26. ok1(hash_stable(u8array, ARRAY_WORDS, 8) == 0xe7e5d741);
  27. ok1(hash_stable(u8array, ARRAY_WORDS, 16) == 0xaae57471);
  28. ok1(hash_stable(u8array, ARRAY_WORDS, 32) == 0xc55399e5);
  29. ok1(hash_stable(u8array, ARRAY_WORDS, 64) == 0x67f21f7 );
  30. ok1(hash_stable(u8array, ARRAY_WORDS, 128) == 0x1d795b71);
  31. ok1(hash_stable(u8array, ARRAY_WORDS, 256) == 0xeb961671);
  32. ok1(hash_stable(u8array, ARRAY_WORDS, 512) == 0xc2597247);
  33. ok1(hash_stable(u8array, ARRAY_WORDS, 1024) == 0x3f5c4d75);
  34. ok1(hash_stable(u8array, ARRAY_WORDS, 2048) == 0xe65cf4f9);
  35. ok1(hash_stable(u8array, ARRAY_WORDS, 4096) == 0xf2cd06cb);
  36. ok1(hash_stable(u8array, ARRAY_WORDS, 8192) == 0x443041e1);
  37. ok1(hash_stable(u8array, ARRAY_WORDS, 16384) == 0xdfc618f5);
  38. ok1(hash_stable(u8array, ARRAY_WORDS, 32768) == 0x5e3d5b97);
  39. ok1(hash_stable(u8array, ARRAY_WORDS, 65536) == 0xd5f64730);
  40. ok1(hash_stable(u8array, ARRAY_WORDS, 131072) == 0x372bbecc);
  41. ok1(hash_stable(u8array, ARRAY_WORDS, 262144) == 0x7c194c8d);
  42. ok1(hash_stable(u8array, ARRAY_WORDS, 524288) == 0x16cbb416);
  43. ok1(hash_stable(u8array, ARRAY_WORDS, 1048576) == 0x53e99222);
  44. ok1(hash_stable(u8array, ARRAY_WORDS, 2097152) == 0x6394554a);
  45. ok1(hash_stable(u8array, ARRAY_WORDS, 4194304) == 0xd83a506d);
  46. ok1(hash_stable(u8array, ARRAY_WORDS, 8388608) == 0x7619d9a4);
  47. ok1(hash_stable(u8array, ARRAY_WORDS, 16777216) == 0xfe98e5f6);
  48. ok1(hash_stable(u8array, ARRAY_WORDS, 33554432) == 0x6c262927);
  49. ok1(hash_stable(u8array, ARRAY_WORDS, 67108864) == 0x3f0106fd);
  50. ok1(hash_stable(u8array, ARRAY_WORDS, 134217728) == 0xc91e3a28);
  51. ok1(hash_stable(u8array, ARRAY_WORDS, 268435456) == 0x14229579);
  52. ok1(hash_stable(u8array, ARRAY_WORDS, 536870912) == 0x9dbefa76);
  53. ok1(hash_stable(u8array, ARRAY_WORDS, 1073741824) == 0xb05c0c78);
  54. ok1(hash_stable(u8array, ARRAY_WORDS, 2147483648U) == 0x88f24d81);
  55. ok1(hash_stable(u16array, ARRAY_WORDS, 0) == 0xecb5f507);
  56. ok1(hash_stable(u16array, ARRAY_WORDS, 1) == 0xadd666e6);
  57. ok1(hash_stable(u16array, ARRAY_WORDS, 2) == 0xea0f214c);
  58. ok1(hash_stable(u16array, ARRAY_WORDS, 4) == 0xae4051ba);
  59. ok1(hash_stable(u16array, ARRAY_WORDS, 8) == 0x6ed28026);
  60. ok1(hash_stable(u16array, ARRAY_WORDS, 16) == 0xa3917a19);
  61. ok1(hash_stable(u16array, ARRAY_WORDS, 32) == 0xf370f32b);
  62. ok1(hash_stable(u16array, ARRAY_WORDS, 64) == 0x807af460);
  63. ok1(hash_stable(u16array, ARRAY_WORDS, 128) == 0xb4c8cd83);
  64. ok1(hash_stable(u16array, ARRAY_WORDS, 256) == 0xa10cb5b0);
  65. ok1(hash_stable(u16array, ARRAY_WORDS, 512) == 0x8b7d7387);
  66. ok1(hash_stable(u16array, ARRAY_WORDS, 1024) == 0x9e49d1c );
  67. ok1(hash_stable(u16array, ARRAY_WORDS, 2048) == 0x288830d1);
  68. ok1(hash_stable(u16array, ARRAY_WORDS, 4096) == 0xbe078a43);
  69. ok1(hash_stable(u16array, ARRAY_WORDS, 8192) == 0xa16d5d88);
  70. ok1(hash_stable(u16array, ARRAY_WORDS, 16384) == 0x46839fcd);
  71. ok1(hash_stable(u16array, ARRAY_WORDS, 32768) == 0x9db9bd4f);
  72. ok1(hash_stable(u16array, ARRAY_WORDS, 65536) == 0xedff58f8);
  73. ok1(hash_stable(u16array, ARRAY_WORDS, 131072) == 0x95ecef18);
  74. ok1(hash_stable(u16array, ARRAY_WORDS, 262144) == 0x23c31b7d);
  75. ok1(hash_stable(u16array, ARRAY_WORDS, 524288) == 0x1d85c7d0);
  76. ok1(hash_stable(u16array, ARRAY_WORDS, 1048576) == 0x25218842);
  77. ok1(hash_stable(u16array, ARRAY_WORDS, 2097152) == 0x711d985c);
  78. ok1(hash_stable(u16array, ARRAY_WORDS, 4194304) == 0x85470eca);
  79. ok1(hash_stable(u16array, ARRAY_WORDS, 8388608) == 0x99ed4ceb);
  80. ok1(hash_stable(u16array, ARRAY_WORDS, 16777216) == 0x67b3710c);
  81. ok1(hash_stable(u16array, ARRAY_WORDS, 33554432) == 0x77f1ab35);
  82. ok1(hash_stable(u16array, ARRAY_WORDS, 67108864) == 0x81f688aa);
  83. ok1(hash_stable(u16array, ARRAY_WORDS, 134217728) == 0x27b56ca5);
  84. ok1(hash_stable(u16array, ARRAY_WORDS, 268435456) == 0xf21ba203);
  85. ok1(hash_stable(u16array, ARRAY_WORDS, 536870912) == 0xd48d1d1 );
  86. ok1(hash_stable(u16array, ARRAY_WORDS, 1073741824) == 0xa542b62d);
  87. ok1(hash_stable(u16array, ARRAY_WORDS, 2147483648U) == 0xa04c7058);
  88. ok1(hash_stable(u32array, ARRAY_WORDS, 0) == 0x13305f8c);
  89. ok1(hash_stable(u32array, ARRAY_WORDS, 1) == 0x171abf74);
  90. ok1(hash_stable(u32array, ARRAY_WORDS, 2) == 0x7646fcc7);
  91. ok1(hash_stable(u32array, ARRAY_WORDS, 4) == 0xa758ed5);
  92. ok1(hash_stable(u32array, ARRAY_WORDS, 8) == 0x2dedc2e4);
  93. ok1(hash_stable(u32array, ARRAY_WORDS, 16) == 0x28e2076b);
  94. ok1(hash_stable(u32array, ARRAY_WORDS, 32) == 0xb73091c5);
  95. ok1(hash_stable(u32array, ARRAY_WORDS, 64) == 0x87daf5db);
  96. ok1(hash_stable(u32array, ARRAY_WORDS, 128) == 0xa16dfe20);
  97. ok1(hash_stable(u32array, ARRAY_WORDS, 256) == 0x300c63c3);
  98. ok1(hash_stable(u32array, ARRAY_WORDS, 512) == 0x255c91fc);
  99. ok1(hash_stable(u32array, ARRAY_WORDS, 1024) == 0x6357b26);
  100. ok1(hash_stable(u32array, ARRAY_WORDS, 2048) == 0x4bc5f339);
  101. ok1(hash_stable(u32array, ARRAY_WORDS, 4096) == 0x1301617c);
  102. ok1(hash_stable(u32array, ARRAY_WORDS, 8192) == 0x506792c9);
  103. ok1(hash_stable(u32array, ARRAY_WORDS, 16384) == 0xcd596705);
  104. ok1(hash_stable(u32array, ARRAY_WORDS, 32768) == 0xa8713cac);
  105. ok1(hash_stable(u32array, ARRAY_WORDS, 65536) == 0x94d9794);
  106. ok1(hash_stable(u32array, ARRAY_WORDS, 131072) == 0xac753e8);
  107. ok1(hash_stable(u32array, ARRAY_WORDS, 262144) == 0xcd8bdd20);
  108. ok1(hash_stable(u32array, ARRAY_WORDS, 524288) == 0xd44faf80);
  109. ok1(hash_stable(u32array, ARRAY_WORDS, 1048576) == 0x2547ccbe);
  110. ok1(hash_stable(u32array, ARRAY_WORDS, 2097152) == 0xbab06dbc);
  111. ok1(hash_stable(u32array, ARRAY_WORDS, 4194304) == 0xaac0e882);
  112. ok1(hash_stable(u32array, ARRAY_WORDS, 8388608) == 0x443f48d0);
  113. ok1(hash_stable(u32array, ARRAY_WORDS, 16777216) == 0xdff49fcc);
  114. ok1(hash_stable(u32array, ARRAY_WORDS, 33554432) == 0x9ce0fd65);
  115. ok1(hash_stable(u32array, ARRAY_WORDS, 67108864) == 0x9ddb1def);
  116. ok1(hash_stable(u32array, ARRAY_WORDS, 134217728) == 0x86096f25);
  117. ok1(hash_stable(u32array, ARRAY_WORDS, 268435456) == 0xe713b7b5);
  118. ok1(hash_stable(u32array, ARRAY_WORDS, 536870912) == 0x5baeffc5);
  119. ok1(hash_stable(u32array, ARRAY_WORDS, 1073741824) == 0xde874f52);
  120. ok1(hash_stable(u32array, ARRAY_WORDS, 2147483648U) == 0xeca13b4e);
  121. ok1(hash_stable(u64array, ARRAY_WORDS, 0) == 0x12ef6302);
  122. ok1(hash_stable(u64array, ARRAY_WORDS, 1) == 0xe9aeb406);
  123. ok1(hash_stable(u64array, ARRAY_WORDS, 2) == 0xc4218ceb);
  124. ok1(hash_stable(u64array, ARRAY_WORDS, 4) == 0xb3d11412);
  125. ok1(hash_stable(u64array, ARRAY_WORDS, 8) == 0xdafbd654);
  126. ok1(hash_stable(u64array, ARRAY_WORDS, 16) == 0x9c336cba);
  127. ok1(hash_stable(u64array, ARRAY_WORDS, 32) == 0x65059721);
  128. ok1(hash_stable(u64array, ARRAY_WORDS, 64) == 0x95b5bbe6);
  129. ok1(hash_stable(u64array, ARRAY_WORDS, 128) == 0xe7596b84);
  130. ok1(hash_stable(u64array, ARRAY_WORDS, 256) == 0x503622a2);
  131. ok1(hash_stable(u64array, ARRAY_WORDS, 512) == 0xecdcc5ca);
  132. ok1(hash_stable(u64array, ARRAY_WORDS, 1024) == 0xc40d0513);
  133. ok1(hash_stable(u64array, ARRAY_WORDS, 2048) == 0xaab25e4d);
  134. ok1(hash_stable(u64array, ARRAY_WORDS, 4096) == 0xcc353fb9);
  135. ok1(hash_stable(u64array, ARRAY_WORDS, 8192) == 0x18e2319f);
  136. ok1(hash_stable(u64array, ARRAY_WORDS, 16384) == 0xfddaae8d);
  137. ok1(hash_stable(u64array, ARRAY_WORDS, 32768) == 0xef7976f2);
  138. ok1(hash_stable(u64array, ARRAY_WORDS, 65536) == 0x86359fc9);
  139. ok1(hash_stable(u64array, ARRAY_WORDS, 131072) == 0x8b5af385);
  140. ok1(hash_stable(u64array, ARRAY_WORDS, 262144) == 0x80d4ee31);
  141. ok1(hash_stable(u64array, ARRAY_WORDS, 524288) == 0x42f5f85b);
  142. ok1(hash_stable(u64array, ARRAY_WORDS, 1048576) == 0x9a6920e1);
  143. ok1(hash_stable(u64array, ARRAY_WORDS, 2097152) == 0x7b7c9850);
  144. ok1(hash_stable(u64array, ARRAY_WORDS, 4194304) == 0x69573e09);
  145. ok1(hash_stable(u64array, ARRAY_WORDS, 8388608) == 0xc942bc0e);
  146. ok1(hash_stable(u64array, ARRAY_WORDS, 16777216) == 0x7a89f0f1);
  147. ok1(hash_stable(u64array, ARRAY_WORDS, 33554432) == 0x2dd641ca);
  148. ok1(hash_stable(u64array, ARRAY_WORDS, 67108864) == 0x89bbd391);
  149. ok1(hash_stable(u64array, ARRAY_WORDS, 134217728) == 0xbcf88e31);
  150. ok1(hash_stable(u64array, ARRAY_WORDS, 268435456) == 0xfa7a3460);
  151. ok1(hash_stable(u64array, ARRAY_WORDS, 536870912) == 0x49a37be0);
  152. ok1(hash_stable(u64array, ARRAY_WORDS, 1073741824) == 0x1b346394);
  153. ok1(hash_stable(u64array, ARRAY_WORDS, 2147483648U) == 0x6c3a1592);
  154. return exit_status();
  155. }