| #!/bin/bash |
| |
| # Copyright (c) 2010 The Chromium OS Authors. All rights reserved. |
| # Use of this source code is governed by a BSD-style license that can be |
| # found in the LICENSE file. |
| |
| # Generate test cases for use for the RSA verify benchmark. |
| |
| # Load common constants and variables. |
| . "$(dirname "$0")/common.sh" |
| |
| TEST_FILE=${TESTCASE_DIR}/test_file |
| TEST_FILE_SIZE=1000000 |
| |
| # Generate public key signatures on an input file for various combinations |
| # of message digest algorithms and RSA key sizes. |
| function generate_test_signatures { |
| echo "Generating test signatures..." |
| algorithmcounter=0 |
| for keylen in ${key_lengths[@]} |
| do |
| for hashalgo in ${hash_algos[@]} |
| do |
| openssl dgst -${hashalgo} -binary ${TEST_FILE} > \ |
| ${TEST_FILE}.${hashalgo}.digest |
| ${BIN_DIR}/signature_digest_utility $algorithmcounter \ |
| ${TEST_FILE} | openssl rsautl \ |
| -sign -pkcs -inkey ${TESTKEY_DIR}/key_rsa${keylen}.pem \ |
| > ${TEST_FILE}.rsa${keylen}_${hashalgo}.sig |
| let algorithmcounter=algorithmcounter+1 |
| done |
| done |
| } |
| |
| # Generate a file with random bytes for signature tests. |
| function generate_test_file { |
| echo "Generating test file..." |
| if [ -f "${TEST_FILE}" ]; then |
| echo "(skipping, file already exists)" |
| return |
| fi |
| dd if=/dev/urandom of=${TEST_FILE} bs=${TEST_FILE_SIZE} count=1 |
| } |
| |
| mkdir -p ${TESTCASE_DIR} |
| check_test_keys |
| generate_test_file |
| generate_test_signatures |