1#!/bin/bash
2
3# Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
4# Use of this source code is governed by a BSD-style license that can be
5# found in the LICENSE file.
6#
7# Run tests for RSA Signature verification.
8
9# Load common constants and variables.
10. "$(dirname "$0")/common.sh"
11
12set -e
13
14return_code=0
15TEST_FILE=${TESTCASE_DIR}/test_file
16
17function test_signatures {
18  algorithmcounter=0
19  for keylen in ${key_lengths[@]}
20  do
21    for hashalgo in ${hash_algos[@]}
22    do
23      echo -e "For ${COL_YELLOW}RSA-$keylen and $hashalgo${COL_STOP}:"
24      ${BIN_DIR}/verify_data $algorithmcounter \
25        ${TESTKEY_DIR}/key_rsa${keylen}.keyb \
26        ${TEST_FILE}.rsa${keylen}_${hashalgo}.sig \
27        ${TEST_FILE}
28      if [ $? -ne 0 ]
29      then
30        return_code=255
31      fi
32      let algorithmcounter=algorithmcounter+1
33    done
34  done
35  echo -e "Peforming ${COL_YELLOW}PKCS #1 v1.5 Padding Tests${COL_STOP}..."
36  ${TEST_DIR}/vb20_rsa_padding_tests ${TESTKEY_DIR}/rsa_padding_test_pubkey.keyb
37}
38
39check_test_keys
40echo "Testing signature verification..."
41test_signatures
42
43exit $return_code
44
45