This repository demonstrates the use of pytest and labgrid for interacting with a QEMU virtual machine (VM) running the OpenWrt firmware.
Utilizing pytest and labgrid simplifies the creation of complex test scenarios, ensuring the reliable and efficient operation of the system under test with minimal code (i.e. less than 500 lines of Python code).
The controlled virtual testing environment enhances both accuracy and reliability of the firmare under test, providing a scalable solution for continuous integration and quality assurance in embedded systems.
Our goal is to validate the ability of OpenWrt to establish an OpenVPN connection using a server hosted in a standalone Docker Compose environment which is set up in the course of the test execution process as well.
Test steps:
- Boot the Firmware
- Set up SSH access to the OpenWrt firmware
- Generate PKI (CA + server/client certs)
- Start dedicated docker compose environment with the OpenVPN server
- Update list of packages in OpenWrt
- Install OpenVPN client in OpenWrt
- Set up OpenVPN client in OpenWrt
- Configure firewall in OpenWrt
- Verify the OpenVPN tunnel has been established successfully
This section outlines the architecture implemented for the pytest/labgrid demonstration:
The system is initiated by utilizing GNU Make, which starts a Docker Compose setup. This environment runs both the tests based on the pytest/labgrid test framework and QEMU, the latter serving as the execution environment for the firmware under test. As part of the test fixtures, a Public Key Infrastructure (PKI) is generated. This PKI includes the key material necessary for the OpenVPN server, and it is provided to the OpenVPN server as its Docker Compose environment is started.
During the test execution phase, the test scripts configure the firmware to establish a connection with the OpenVPN server. This involves transferring the key material specific to the firmware under test. In the verification phase, the test script first pings the OpenVPN server from the firmware within the Docker Compose environment. Subsequently, it verifies connectivity in the reverse direction by pinging the firmware from within the OpenVPN server. This process ensures proper communication and confirms that the OpenVPN client in the firmware works as designed.
- Linux Host
- Docker Engine + Docker Compose (see Installation Instructions)
- GNU Make
- Clone the repository:
git clone https://github.com/honeytreelabs/labgrid-qemu-sample.git
cd labgrid-qemu-sample
- Prepare the Environment:
Ensure all the necessary dependencies are met on your host machine.
- Running Tests:
make test-docker
This is what you should see when running this sample: