#!/bin/sh osmo_auc_gen="$1" if [ -z "$osmo_auc_gen" ]; then echo 'Error: pass a path to the osmo-auc-gen binary as argument:' echo ' ./osmo-auc-gen_test.sh /path/to/osmo-auc-gen' exit 1 fi set -e # run the osmo-auc-gen binary verbosely without showing its absolute path # for identical expected output everywhere. invoke() { echo echo echo '>' osmo-auc-gen $@ $osmo_auc_gen $@ } invoke_err() { echo echo echo expecting error: echo '>' osmo-auc-gen $@ echo expecting error: >&2 echo '>' osmo-auc-gen $@ >&2 $osmo_auc_gen $@ && exit 1 || true } bytes1="6a61050765caa32c90371370e5d6dc2d" bytes2="1dc4f974325cce611e54f516dc1fec56" bytes3="2a48162ff3edca4adf0b7b5e527d6c16" invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 0 invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 1 invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 23 invoke -3 -a milenage -r $bytes2 -k $bytes3 -o $bytes1 -s 42 invoke -3 -a milenage -r $bytes3 -k $bytes1 -o $bytes2 -s 99 invoke -3 -a milenage -r $bytes1 -k $bytes3 -o $bytes2 -s 281474976710655 k="EB215756028D60E3275E613320AEC880" opc="FB2A3D1B360F599ABAB99DB8669F8308" rand="39fa2f4e3d523d8619a73b4f65c3e14d" auts="979498b1f72d3e28c59fa2e72f9c" # --> SQN.MS = 23 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 5 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 23 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 31 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 0 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 1 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 1 --ind 1 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 8 invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 8 --ind 1 # expect error: IND is too large for IND-bitlen of 5 (max 31) invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind -1 invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 32 invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 42 invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 0 --ind 1