123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204 |
- set -e
- source helpers.sh
- start_up
- CRYPTO_PROFILE="ECC"
- setup_fapi $CRYPTO_PROFILE
- function cleanup {
- tss2 delete --path=/
- shut_down
- }
- trap cleanup EXIT
- NV_PATH=/nv/Owner/myNVwrite
- PCR_DIGEST_FILE=$TEMP_DIR/pcr_digest.file
- PCR_LOG_FILE_WRITE=$TEMP_DIR/pcr_log_write.file
- echo "{\"test\": \"myfile\"}" > $PCR_LOG_FILE_WRITE
- PCR_LOG_FILE_READ=$TEMP_DIR/pcr_log_read.file
- PCR_EVENT_DATA=$TEMP_DIR/pcr_event_data.file
- echo "0,1,2,3,4,5,6,7,8,9" > $PCR_EVENT_DATA
- EMPTY_FILE=$TEMP_DIR/empty.file
- BIG_FILE=$TEMP_DIR/big_file.file
- LOG_FILE=$TEMP_DIR/log.file
- touch $LOG_FILE
- tss2 provision
- tss2 pcrextend --pcr=16 --data=$PCR_EVENT_DATA \
- --logData=$PCR_LOG_FILE_WRITE
- echo "tss2 pcrextend with EMPTY_FILE data" # Expected to fail
- expect <<EOF
- spawn sh -c "tss2 pcrextend --pcr=16 --data=$EMPTY_FILE \
- --logData=$PCR_LOG_FILE_WRITE 2> $LOG_FILE"
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- set file [open $LOG_FILE r]
- set log [read \$file]
- close $file
- send_user "[lindex \$log]\n"
- exit 1
- }
- EOF
- if [[ "`cat $LOG_FILE`" == $SANITIZER_FILTER ]]; then
- echo "Error: AddressSanitizer triggered."
- cat $LOG_FILE
- exit 1
- fi
- echo "tss2 pcrextend with BIG_FILE data" # Expected to fail
- expect <<EOF
- spawn sh -c "tss2 pcrextend --pcr=16 --data=$BIG_FILE \
- --logData=$PCR_LOG_FILE_WRITE 2> $LOG_FILE"
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- set file [open $LOG_FILE r]
- set log [read \$file]
- close $file
- send_user "[lindex \$log]\n"
- exit 1
- }
- EOF
- if [[ "`cat $LOG_FILE`" == $SANITIZER_FILTER ]]; then
- echo "Error: AddressSanitizer triggered."
- cat $LOG_FILE
- exit 1
- fi
- echo "tss2 pcrextend with EMPTY_FILE logData" # Expected to fail
- expect <<EOF
- spawn sh -c "tss2 pcrextend --pcr=16 --data=$PCR_EVENT_DATA \
- --logData=$EMPTY_FILE 2> $LOG_FILE"
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1 } {
- set file [open $LOG_FILE r]
- set log [read \$file]
- close $file
- send_user "[lindex \$log]\n"
- exit 1
- }
- EOF
- if [[ "`cat $LOG_FILE`" == $SANITIZER_FILTER ]]; then
- echo "Error: AddressSanitizer triggered."
- cat $LOG_FILE
- exit 1
- fi
- echo "tss2 pcrextend with BIG_FILE logData" # Expected to fail
- expect <<EOF
- spawn sh -c "tss2 pcrextend --pcr=16 --data=$PCR_EVENT_DATA \
- --logData=$BIG_FILE 2> $LOG_FILE"
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- set file [open $LOG_FILE r]
- set log [read \$file]
- close $file
- send_user "[lindex \$log]\n"
- exit 1
- }
- EOF
- if [[ "`cat $LOG_FILE`" == $SANITIZER_FILTER ]]; then
- echo "Error: AddressSanitizer triggered."
- cat $LOG_FILE
- exit 1
- fi
- tss2 pcrread --pcrIndex=16 --pcrValue=$PCR_DIGEST_FILE \
- --pcrLog=$PCR_LOG_FILE_READ --force
- if [ ! -s $PCR_DIGEST_FILE ] || [ ! -s $PCR_LOG_FILE_READ ]; then
- echo "At least one returned file is empty"
- exit 1
- fi
- expect <<EOF
- # Try with missing pcr
- spawn tss2 pcrextend --data=$PCR_EVENT_DATA --logData=$PCR_LOG_FILE_WRITE
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- expect <<EOF
- # Try with missing data
- spawn tss2 pcrextend --pcr=16 --logData=$PCR_LOG_FILE_WRITE
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- expect <<EOF
- # Try with wrong pcr
- spawn tss2 pcrextend --pcr=abc --data=$PCR_EVENT_DATA \
- --logData=$PCR_LOG_FILE_WRITE
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- expect <<EOF
- # Try with multiple stdins
- spawn tss2 pcrextend --pcr=16 --data=- --logData=-
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- # Try with missing logData
- tss2 pcrextend --pcr=16 --data=$PCR_EVENT_DATA
- expect <<EOF
- # Try with missing pcrIndex
- spawn tss2 pcrread --pcrValue=$PCR_DIGEST_FILE --pcrLog=$PCR_LOG_FILE_READ --force
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- # Try with missing pcrValue
- tss2 pcrread --pcrIndex=16 --pcrLog=$PCR_LOG_FILE_READ --force
- # Try with missing pcrLog
- tss2 pcrread --pcrIndex=16 --pcrValue=$PCR_DIGEST_FILE --force
- expect <<EOF
- # Try with multiple stdins (1)
- spawn tss2 pcrread --pcrIndex=16 --pcrValue=- \
- --pcrLog=-
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- expect <<EOF
- # Try with wrong pcrIndex
- spawn tss2 pcrread --pcrIndex=abc --pcrValue=$PCR_DIGEST_FILE \
- --pcrLog=$PCR_LOG_FILE_READ --force
- set ret [wait]
- if {[lindex \$ret 2] || [lindex \$ret 3] != 1} {
- Command has not failed as expected\n"
- exit 1
- }
- EOF
- exit 0
|