mirror of
https://github.com/nsacyber/HIRS.git
synced 2025-01-06 05:04:21 +00:00
7609759356
* Adding run script, Dockerfile, and container setup script for provisioning with TPM Simulator and Provisioner.Net * Replacing Docker container setup script with Docker Compose .yml file with respective configurations in related files * Adding system_test.yml for GitHub actions to run system tests upon V3 branch pushes. Modifying related files accordingly * Replacing V2 ACA with V3 ACA built from Rocky 9
47 lines
2.1 KiB
Bash
47 lines
2.1 KiB
Bash
#!/bin/bash
|
|
#########################################################################################
|
|
# Script to run the System Tests for HIRS TPM 2.0 Provisoner
|
|
# Notes for running manually/locally (not from GitHub Actions)
|
|
# 1. Uncomment the "cd ../.." line below to make working directory = /HIRS/
|
|
# 2. Run with the desired HIRS branch as an argument (i.e. $./run_system_tests.sh main)
|
|
#########################################################################################
|
|
# cd ../..
|
|
|
|
# Setting variables
|
|
aca_container=hirs-aca1
|
|
tpm2_container=hirs-provisioner1-tpm2
|
|
|
|
# Start System Testing Docker Environment
|
|
echo "******** Setting up for HIRS System Tests for TPM 2.0 ******** "
|
|
docker compose -f ./.ci/docker/docker-compose-system-test.yml up -d
|
|
|
|
# Switching to current/desired branch
|
|
docker exec $tpm2_container sh -c "cd / && ./tmp/auto_clone_branch $1 1> /dev/null && cd hirs"
|
|
|
|
# Install HIRS Provisioner.Net and setup tpm2 simulator.
|
|
# In doing so, tests a single provision between Provisioner.Net and ACA.
|
|
docker exec $tpm2_container /.ci/setup/container/setup_tpm2provisioner_dotnet.sh
|
|
|
|
# HERE is where other system tests will be called, including:
|
|
# aca_policy_tests.sh, platform_cert_tests.sh, rim_system_tests.sh
|
|
echo "******** HIRS System Tests Complete ******** "
|
|
|
|
# Collecting ACA and Provisioner.Net logs for workflow artifact
|
|
echo "*** Extracting ACA and Provisioner.Net logs ..."
|
|
docker exec $aca_container sh -c "cd .. && mkdir -p /HIRS/logs/aca/ && cp -arp /var/log/hirs/* /HIRS/logs/aca/"
|
|
docker exec $tpm2_container sh -c "cd .. && mkdir -p /HIRS/logs/provisioner/ && cp -ap hirs*.log /HIRS/logs/provisioner/ && chmod -R 777 /HIRS/logs"
|
|
|
|
# Clean up services and network
|
|
echo "*** Exiting and removing Docker containers and network ..."
|
|
docker compose -f ./.ci/docker/docker-compose-system-test.yml down -v
|
|
|
|
# Return container exit code
|
|
if [[ ${TEST_STATUS} == "0" ]]; then
|
|
echo "******** SUCCESS: System Tests for TPM 2.0 passed ********"
|
|
echo "TEST_STATUS=0" >> $GITHUB_ENV
|
|
exit 0;
|
|
else
|
|
echo "******** FAILURE: System Tests for TPM 2.0 failed ********"
|
|
echo "TEST_STATUS=1" >> $GITHUB_ENV
|
|
exit 1
|
|
fi |