mirror of
https://github.com/nsacyber/HIRS.git
synced 2025-01-12 07:52:48 +00:00
7a1a6b73b0
* Adding ACA Policy tests with modifications to related files * Separating the system tests setup from the tests themselves + Splitting up ACA Policy Tests into different steps in workflow file * Creating separate script for setting up system tests in workflow, and one script for running system tests locally. Adding details to system test steps.
83 lines
2.7 KiB
Bash
Executable File
83 lines
2.7 KiB
Bash
Executable File
#!/bin/bash
|
|
#########################################################################################
|
|
# HIRS ACA Policy System Tests
|
|
#
|
|
#########################################################################################
|
|
source ./.ci/system-tests/sys_test_common.sh
|
|
testResult=false
|
|
totalTests=0;
|
|
failedTests=0;
|
|
test="all"
|
|
case $1 in
|
|
1) test="1" ;;
|
|
2) test="2" ;;
|
|
3) test="3" ;;
|
|
4) test="4" ;;
|
|
5) test="5" ;;
|
|
6) test="6" ;;
|
|
7) test="7" ;;
|
|
8) test="8" ;;
|
|
esac
|
|
|
|
# Start ACA Policy Tests
|
|
# provisionTpm2 takes 1 parameter (the expected result): "pass" or "fail"
|
|
|
|
if [ "$test" = "1" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 1: Test ACA default policy ###"
|
|
setPlatformCerts "laptop" "empty"
|
|
provisionTpm2 "pass"
|
|
fi
|
|
if [ "$test" = "2" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 2: Test EK cert Only Validation Policy without a EK Issuer Cert in the trust store ###"
|
|
setPolicyEkOnly
|
|
provisionTpm2 "fail"
|
|
fi
|
|
if [ "$test" = "3" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 3: Test EK Only Validation Policy ###"
|
|
uploadTrustedCerts
|
|
provisionTpm2 "pass"
|
|
fi
|
|
if [ "$test" = "4" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 4: Test PC Validation Policy with no PC ###"
|
|
setPolicyEkPc_noAttCheck
|
|
provisionTpm2 "fail"
|
|
fi
|
|
if [ "$test" = "5" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 5: Test FW and PC Validation Policy with no PC ###"
|
|
setPolicyEkPcFw
|
|
provisionTpm2 "fail"
|
|
fi
|
|
if [ "$test" = "6" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 6: Test PC Validation Policy with valid PC with no Attribute Check ###"
|
|
clearAcaDb
|
|
setPolicyEkPc_noAttCheck
|
|
uploadTrustedCerts
|
|
setPlatformCerts "laptop" "default"
|
|
provisionTpm2 "pass"
|
|
fi
|
|
if [ "$test" = "7" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 7: Test PC Validation Policy with valid PC with Attribute Check ###"
|
|
clearAcaDb
|
|
setPolicyEkPc
|
|
uploadTrustedCerts
|
|
setPlatformCerts "laptop" "default"
|
|
setPlatformOutput
|
|
provisionTpm2 "pass"
|
|
fi
|
|
if [ "$test" = "8" ] || [ "$test" = "all" ]; then
|
|
writeToLogs "### ACA POLICY TEST 8: Test PC with RIM Validation Policy with valid PC and RIM ###"
|
|
clearAcaDb
|
|
setPolicyEkPcFw
|
|
uploadTrustedCerts
|
|
setPlatformCerts "laptop" "default"
|
|
setRims "laptop" "default"
|
|
provisionTpm2 "pass"
|
|
fi
|
|
|
|
# Process Test Results, any single failure will send back a failed result.
|
|
if [[ $failedTests != 0 ]]; then
|
|
export TEST_STATUS=1;
|
|
echo "**** $failedTests out of $totalTests ACA Policy Tests Failed! ****"
|
|
else
|
|
echo "**** $totalTests ACA Policy Tests Passed! ****"
|
|
fi |