Add get_key_pair_info feature for spdm_emu #10
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Version 1.2 with Certificates | |
on: | |
push: | |
branches: [ main ] | |
pull_request: | |
branches: [ main ] | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} | |
cancel-in-progress: true | |
env: | |
BUILD_TYPE: Release | |
jobs: | |
format_check: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
# If any *.c *.h *.md file(except:libspdm) have Tab, the check will fail. | |
- name: Check code format | |
run: | | |
if grep -rn " " * --include=*.c --include=*.h --include=*.md; | |
then exit 1 | |
fi | |
gcc_mbedtls_build: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
submodules: recursive | |
- name: Build | |
run: | | |
mkdir build | |
cd build | |
cmake -E env CFLAGS="-DLIBSPDM_DEBUG_LIBSPDM_ASSERT_CONFIG=3" cmake -DARCH=x64 -DTOOLCHAIN=GCC -DTARGET=Release -DCRYPTO=mbedtls .. | |
make copy_sample_key | |
make -j`nproc` | |
- name: Emu_Test | |
run: | | |
cd build/bin | |
test_port=2323 | |
TCPListeningnum=`netstat -an | grep ":$test_port " | awk '/^tcp.*/ && $NF == "LISTEN" {print $0}' | wc -l` | |
UDPListeningnum=`netstat -an | grep ":$test_port " | awk '/^udp.*/ && $NF == "0.0.0.0:*" {print $0}' | wc -l` | |
Listeningnum=$((TCPListeningnum + UDPListeningnum)) | |
if [ $Listeningnum -eq 0 ]; then | |
echo "port is not used" | |
else | |
echo "port is used" | |
fi | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu >requester.log | |
sleep 10s | |
- name: Responder_validator_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_device_validator_sample | |
- name: Test_RECORD_TRANSCRIPT_DATA_consistent | |
# open LIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT flag | |
# mkdir build1 folder, gen spdm_requester_emu.exe and spdm_responder_emu.exe | |
# check the log size and end of log to ensure that hashes/signatures over transcripts are consistent | |
run: | | |
sed -i '17a add_definitions(-DLIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT=1)' CMakeLists.txt | |
mkdir build1 | |
cd build1 | |
cmake -E env CFLAGS="-DLIBSPDM_DEBUG_LIBSPDM_ASSERT_CONFIG=3" cmake -DARCH=x64 -DTOOLCHAIN=GCC -DTARGET=Release -DCRYPTO=mbedtls .. | |
make copy_sample_key | |
make -j`nproc` | |
cd bin | |
echo "requester (DATA_SUPPORT = 0) <=> responder (DATA_SUPPORT = 1)" | |
./spdm_responder_emu & | |
sleep 5s | |
./../../build/bin/spdm_requester_emu >requester.log | |
sleep 10s | |
echo "requester (DATA_SUPPORT = 1) <=> responder (DATA_SUPPORT = 0)" | |
./../../build/bin/spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu >requester.log | |
- name: Emu_PCIDOE_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu --trans PCI_DOE & | |
sleep 5s | |
./spdm_requester_emu --trans PCI_DOE | |
sleep 10s | |
gcc_openssl_build: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
submodules: recursive | |
- name: Build | |
run: | | |
mkdir build | |
cd build | |
cmake -E env CFLAGS="-DLIBSPDM_DEBUG_LIBSPDM_ASSERT_CONFIG=3" cmake -DARCH=x64 -DTOOLCHAIN=GCC -DTARGET=Release -DCRYPTO=openssl .. | |
make copy_sample_key | |
make -j`nproc` | |
- name: Emu_Test | |
run: | | |
cd build/bin | |
test_port=2323 | |
TCPListeningnum=`netstat -an | grep ":$test_port " | awk '/^tcp.*/ && $NF == "LISTEN" {print $0}' | wc -l` | |
UDPListeningnum=`netstat -an | grep ":$test_port " | awk '/^udp.*/ && $NF == "0.0.0.0:*" {print $0}' | wc -l` | |
Listeningnum=$((TCPListeningnum + UDPListeningnum)) | |
if [ $Listeningnum -eq 0 ]; then | |
echo "port is not used" | |
else | |
echo "port is used" | |
fi | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu >requester.log | |
sleep 10s | |
- name: Responder_validator_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_device_validator_sample | |
- name: Test_RECORD_TRANSCRIPT_DATA_consistent | |
# open LIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT flag | |
# mkdir build1 folder, gen spdm_requester_emu.exe and spdm_responder_emu.exe | |
# check the log size and the end of log to ensure that hashes/signatures over transcripts are consistent | |
run: | | |
sed -i '17a add_definitions(-DLIBSPDM_RECORD_TRANSCRIPT_DATA_SUPPORT=1)' CMakeLists.txt | |
mkdir build1 | |
cd build1 | |
cmake -DARCH=x64 -DTOOLCHAIN=GCC -DTARGET=Release -DCRYPTO=openssl .. | |
make copy_sample_key | |
make -j`nproc` | |
cd bin | |
echo "requester (DATA_SUPPORT = 0) <=> responder (DATA_SUPPORT = 1)" | |
./spdm_responder_emu & | |
sleep 5s | |
./../../build/bin/spdm_requester_emu >requester.log | |
sleep 10s | |
echo "requester (DATA_SUPPORT = 1) <=> responder (DATA_SUPPORT = 0)" | |
./../../build/bin/spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu >requester.log | |
- name: Emu_PCIDOE_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu --trans PCI_DOE & | |
sleep 5s | |
./spdm_requester_emu --trans PCI_DOE | |
sleep 10s | |
VS2019_mbedtls_build: | |
runs-on: windows-latest | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
submodules: recursive | |
#ilammy/msvc-dev-cmd@v1 is GitHub Action for configuring Developer Command Prompt for Microsoft Visual Studio on Windows. | |
#This sets up the environment for compiling C/C++ code from command line. | |
- name: Add msbuild to PATH | |
uses: ilammy/msvc-dev-cmd@v1 | |
with: | |
arch: x64 | |
- name: Build | |
run: | | |
mkdir build | |
cd build | |
cmake -E env CFLAGS="-DLIBSPDM_DEBUG_LIBSPDM_ASSERT_CONFIG=3" cmake -G"NMake Makefiles" -DARCH=x64 -DTOOLCHAIN=VS2019 -DTARGET=Release -DCRYPTO=mbedtls .. | |
nmake copy_sample_key | |
nmake | |
- name: Emu_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu | |
sleep 10s | |
- name: Responder_validator_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_device_validator_sample | |
- name: Emu_PCIDOE_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu --trans PCI_DOE & | |
sleep 5s | |
./spdm_requester_emu --trans PCI_DOE | |
sleep 10s | |
VS2019_openssl_build: | |
runs-on: windows-latest | |
steps: | |
- uses: actions/checkout@v2 | |
with: | |
submodules: recursive | |
#ilammy/msvc-dev-cmd@v1 is GitHub Action for configuring Developer Command Prompt for Microsoft Visual Studio on Windows. | |
#This sets up the environment for compiling C/C++ code from command line. | |
- name: Add msbuild to PATH | |
uses: ilammy/msvc-dev-cmd@v1 | |
with: | |
arch: x64 | |
- name: Build | |
run: | | |
mkdir build | |
cd build | |
cmake -E env CFLAGS="-DLIBSPDM_DEBUG_LIBSPDM_ASSERT_CONFIG=3" cmake -G"NMake Makefiles" -DARCH=x64 -DTOOLCHAIN=VS2019 -DTARGET=Release -DCRYPTO=openssl .. | |
nmake copy_sample_key | |
nmake | |
- name: Emu_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_requester_emu | |
sleep 10s | |
- name: Responder_validator_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu & | |
sleep 5s | |
./spdm_device_validator_sample | |
- name: Emu_PCIDOE_Test | |
run: | | |
cd build/bin | |
./spdm_responder_emu --trans PCI_DOE & | |
sleep 5s | |
./spdm_requester_emu --trans PCI_DOE | |
sleep 10s |