Neels Hofmeyr | d3b5873 | 2017-03-15 01:52:58 +0100 | [diff] [blame] | 1 | #!/bin/sh |
| 2 | osmo_auc_gen="$1" |
| 3 | |
Neels Hofmeyr | 9ca7d3e | 2017-08-26 22:57:07 +0200 | [diff] [blame] | 4 | if [ -z "$osmo_auc_gen" ]; then |
| 5 | echo 'Error: pass a path to the osmo-auc-gen binary as argument:' |
| 6 | echo ' ./osmo-auc-gen_test.sh /path/to/osmo-auc-gen' |
| 7 | exit 1 |
| 8 | fi |
| 9 | |
Neels Hofmeyr | d3b5873 | 2017-03-15 01:52:58 +0100 | [diff] [blame] | 10 | set -e |
| 11 | |
| 12 | # run the osmo-auc-gen binary verbosely without showing its absolute path |
| 13 | # for identical expected output everywhere. |
| 14 | invoke() { |
| 15 | echo |
| 16 | echo |
| 17 | echo '>' osmo-auc-gen $@ |
| 18 | $osmo_auc_gen $@ |
| 19 | } |
| 20 | |
Neels Hofmeyr | 3cb0827 | 2017-08-26 21:45:33 +0200 | [diff] [blame] | 21 | invoke_err() { |
| 22 | echo |
| 23 | echo |
| 24 | echo expecting error: |
| 25 | echo '>' osmo-auc-gen $@ |
| 26 | echo expecting error: >&2 |
| 27 | echo '>' osmo-auc-gen $@ >&2 |
| 28 | $osmo_auc_gen $@ && exit 1 || true |
| 29 | } |
| 30 | |
Neels Hofmeyr | d3b5873 | 2017-03-15 01:52:58 +0100 | [diff] [blame] | 31 | bytes1="6a61050765caa32c90371370e5d6dc2d" |
| 32 | bytes2="1dc4f974325cce611e54f516dc1fec56" |
| 33 | bytes3="2a48162ff3edca4adf0b7b5e527d6c16" |
| 34 | |
| 35 | invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 0 |
| 36 | invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 1 |
| 37 | invoke -3 -a milenage -r $bytes1 -k $bytes2 -o $bytes3 -s 23 |
| 38 | invoke -3 -a milenage -r $bytes2 -k $bytes3 -o $bytes1 -s 42 |
| 39 | invoke -3 -a milenage -r $bytes3 -k $bytes1 -o $bytes2 -s 99 |
| 40 | invoke -3 -a milenage -r $bytes1 -k $bytes3 -o $bytes2 -s 281474976710655 |
| 41 | |
| 42 | k="EB215756028D60E3275E613320AEC880" |
| 43 | opc="FB2A3D1B360F599ABAB99DB8669F8308" |
| 44 | rand="39fa2f4e3d523d8619a73b4f65c3e14d" |
Neels Hofmeyr | 3cb0827 | 2017-08-26 21:45:33 +0200 | [diff] [blame] | 45 | auts="979498b1f72d3e28c59fa2e72f9c" # --> SQN.MS = 23 |
Neels Hofmeyr | d3b5873 | 2017-03-15 01:52:58 +0100 | [diff] [blame] | 46 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts |
Neels Hofmeyr | 3cb0827 | 2017-08-26 21:45:33 +0200 | [diff] [blame] | 47 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 5 |
| 48 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 23 |
| 49 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 31 |
| 50 | |
Neels Hofmeyr | b1af6ef | 2017-08-26 21:38:51 +0200 | [diff] [blame] | 51 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 0 |
| 52 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 1 |
| 53 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 1 --ind 1 |
| 54 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 8 |
| 55 | invoke -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 8 --ind 1 |
| 56 | |
Neels Hofmeyr | 3cb0827 | 2017-08-26 21:45:33 +0200 | [diff] [blame] | 57 | # expect error: IND is too large for IND-bitlen of 5 (max 31) |
| 58 | invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind -1 |
| 59 | invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 32 |
| 60 | invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind 42 |
Neels Hofmeyr | b1af6ef | 2017-08-26 21:38:51 +0200 | [diff] [blame] | 61 | |
| 62 | invoke_err -3 -a milenage -r $rand -k $k -o $opc -A $auts --ind-len 0 --ind 1 |