summaryrefslogtreecommitdiffstats
path: root/Modules/_blake2/impl/blake2sp-test.c
diff options
context:
space:
mode:
authorDavid Carlier <dcarlier@afilias.info>2019-05-23 04:32:44 (GMT)
committerInada Naoki <songofacandy@gmail.com>2019-05-23 04:32:44 (GMT)
commit51aa35e9e17eef60d04add9619fe2a7eb938358c (patch)
tree87251bf2800e940f6872fa45d84342bb1dc455ec /Modules/_blake2/impl/blake2sp-test.c
parent20e1e2582e5e69e43af88ff58699c8883d146acb (diff)
downloadcpython-51aa35e9e17eef60d04add9619fe2a7eb938358c.zip
cpython-51aa35e9e17eef60d04add9619fe2a7eb938358c.tar.gz
cpython-51aa35e9e17eef60d04add9619fe2a7eb938358c.tar.bz2
bpo-33164: update blake2 implementation (GH-6286)
Diffstat (limited to 'Modules/_blake2/impl/blake2sp-test.c')
-rw-r--r--Modules/_blake2/impl/blake2sp-test.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/Modules/_blake2/impl/blake2sp-test.c b/Modules/_blake2/impl/blake2sp-test.c
new file mode 100644
index 0000000..621e350
--- /dev/null
+++ b/Modules/_blake2/impl/blake2sp-test.c
@@ -0,0 +1,43 @@
+/*
+ BLAKE2 reference source code package - optimized C implementations
+
+ Written in 2012 by Samuel Neves <sneves@dei.uc.pt>
+
+ To the extent possible under law, the author(s) have dedicated all copyright
+ and related and neighboring rights to this software to the public domain
+ worldwide. This software is distributed without any warranty.
+
+ You should have received a copy of the CC0 Public Domain Dedication along with
+ this software. If not, see <http://creativecommons.org/publicdomain/zero/1.0/>.
+*/
+#include <stdio.h>
+#include <string.h>
+#include "blake2.h"
+#include "blake2-kat.h"
+
+int main( int argc, char **argv )
+{
+ uint8_t key[BLAKE2S_KEYBYTES];
+ uint8_t buf[KAT_LENGTH];
+
+ for( size_t i = 0; i < BLAKE2S_KEYBYTES; ++i )
+ key[i] = ( uint8_t )i;
+
+ for( size_t i = 0; i < KAT_LENGTH; ++i )
+ buf[i] = ( uint8_t )i;
+
+ for( size_t i = 0; i < KAT_LENGTH; ++i )
+ {
+ uint8_t hash[BLAKE2S_OUTBYTES];
+ if( blake2sp( hash, buf, key, BLAKE2S_OUTBYTES, i, BLAKE2S_KEYBYTES ) < 0 ||
+ 0 != memcmp( hash, blake2sp_keyed_kat[i], BLAKE2S_OUTBYTES ) )
+ {
+ puts( "error" );
+ return -1;
+ }
+ }
+
+ puts( "ok" );
+ return 0;
+}
+