55 lines
1.7 KiB
Bash
Raw Normal View History

2025-01-17 18:27:46 +03:00
#!/bin/bash
# SPDX-License-Identifier: MIT
file=$2
build_dir=$3
# input part
keygen_z=$(grep "keygen_z: " "$file" | sed 's/keygen_z: //g')
keygen_d=$(grep "keygen_d: " "$file" | sed 's/keygen_d: //g')
encaps_m=$(grep "encaps_m: " "$file" | sed 's/encaps_m: //g')
encaps_ek=$(grep "encaps_ek: " "$file" | sed 's/encaps_ek: //g')
encaps_k=$(grep "encaps_K: " "$file" | sed 's/encaps_K: //g')
decaps_dk=$(grep "decaps_dk: " "$file" | sed 's/decaps_dk: //g')
decaps_c=$(grep "decaps_c: " "$file" | sed 's/decaps_c: //g')
decaps_kprime=$(grep "decaps_KPrime: " "$file" | sed 's/decaps_KPrime: //g')
# KAT part
keygen_pk=$(grep "keygen_ek: " "$file")
keygen_sk=$(grep "keygen_dk: " "$file")
encaps_c=$(grep "encaps_c: " "$file")
encaps_K=$(grep "encaps_K: " "$file")
output=$($build_dir/tests/vectors_kem $1 "$keygen_d$keygen_z$encaps_m" "$encaps_ek" "$encaps_k" "$decaps_dk" "$decaps_c" "$decaps_kprime")
if [ $? != 0 ]; then
echo "$output"
exit 1
fi
# Parse output: pk, sk, signature
output_pk=$(echo "$output" | grep "ek: " | sed 's/ek: /keygen_ek: /g')
output_sk=$(echo "$output" | grep "dk: " | sed 's/dk: /keygen_dk: /g')
output_c=$(echo "$output" | grep "c: " | sed 's/c: /encaps_c: /g')
output_K=$(echo "$output" | grep "K: " | sed 's/K: /encaps_K: /g')
if [ "$keygen_pk" != "$output_pk" ]; then
echo "keygen_pk mismatch for $1"
echo "$keygen_pk\n$output_pk"
exit 1
elif [ "$keygen_sk" != "$output_sk" ]; then
echo "keygen_sk mismatch for $1"
exit 1
elif [ "$encaps_c" != "$output_c" ]; then
echo "$encaps_c\n$output_c"
echo "encaps_c mismatch for $1"
exit 1
elif [ "$encaps_K" != "$output_K" ]; then
echo "encaps_K mismatch for $1"
exit 1
else
echo "Vector tests succeeded for $1"
fi