- Introduction
- Architecture
- Windows Prerequisites
- Generating Interop Assembly
- PTS Workspace Setup
- Running in Client/Server Mode
- Running Test Script on Windows
- Running AutoPTSClientBot
- IRC Channel on freenode.net
The Bluetooth Profile Tuning Suite (PTS) is a Bluetooth testing tool provided by Bluetooth SIG. The PTS is a Windows program that is normally used in manual mode via its GUI
auto-pts is the Bluetooth PTS automation framework. auto-pts uses PTSControl COM API of PTS to automate testing.
Over 460 test cases have been automated for Zephyr OS which reduced testing time from one man-month to 9 hours. auto-pts has been used to automate testing of two Bluetooth stacks thus far:
- BlueZ
- Zephyr BLE
auto-pts server: runs on Windows and provides over-the-network XML-RPC interface to PTS. It is implemented in Python and executed using IronPython
auto-pts client: runs on GNU/Linux, communicates with the auto-pts server (to start/stop test cases, to send response to PTS inquiries) and communicates with the Implementation Under Test to take appropriate actions. It is implemented in Python and executed using CPython.
Implementation Under Test (IUT): It is the host running Bluetooth stack to be tested, this could be an emulator or real hardware. The IUT is controlled by using Bluetooth Test Protocol.
Bluetooth Test Protocol (BTP): Used to communicate with the IUT. Specified in Zephyr tester directory, btp_spec.txt
Since this PTS automation framework uses IronPython it needs COM interop assembly Interop.PTSConrol.dll to be located in the same directory as the auto-pts server.
You need to use 32 bit IronPython to run these scripts because PTS is a 32 bit application.
To be able to run PTS in automation mode, there should be no PTS instances running in the GUI mode. Hence, before running these scripts close the PTS GUI.
On Windows, run this command:
TlbImp.exe PTSControl.dll /out:Interop.PTSControl.dll /verbose
Before running any scripts you have to create a workspace in the PTS, add needed projects to the workspace and configure PICs and PIXITs.
Alternatively, you can use auto-pts workspaces. Auto-pts provides ready PTS workspaces with readily configured PICS in the "workspaces" directory. Currently it provides workspaces for the Zephyr HCI stack. To select ready made workspace pass to the auto-pts client as the workspace argument:
- zephyr-hci
The auto-pts framework uses a client server architecture. With this setup the PTS automation server runs on Windows and the client runs on GNU/Linux. So on Windows you start the server:
ipy.exe autoptsserver.py
And on GNU/Linux you select either the AOSP BlueZ, Zephyr or BlueZ client, then pass it the IP address of the server and the path to the PTS workspace file on the Windows machine. So for AOSP BlueZ projects:
./autoptsclient-aospbluez.py "C:\Users\USER_NAME\Documents\Profile Tuning Suite\PTS_PROJECT\PTS_PROJECT.pqw6" -i IP_ADDRESS
For Zephyr projects running under QEMU:
Start a proxy for Bluetooth adapter by using btproxy from BlueZ:
sudo bluez/tools/btproxy -u -z
Then start the client:
./autoptsclient-zephyr.py "C:\Users\USER_NAME\Documents\Profile Tuning Suite\PTS_PROJECT\PTS_PROJECT.pqw6" zephyr.elf -i IP_ADDRESS
Zephyr running in Arduino:
./autoptsclient-zephyr.py "C:\Users\USER_NAME\Documents\Profile Tuning Suite\PTS_PROJECT\PTS_PROJECT.pqw6" -i IP_ADDRESS zephyr.elf -t /dev/ttyUSB0 -b arduino_101 -d
The command to run auto-pts client using auto-pts Zephyr HCI workspace is:
./autoptsclient-zephyr.py zephyr-hci zephyr.elf -i IP_ADDRESS -t /dev/ttyUSB0 -b arduino_101 -d
It is also possible to run tests on Windows, without using client/server mode of auto-pts. On Windows instead of starting the auto-pts server start test script as:
ipy.exe autopts.py
autopts.py has been used to test AOSP BlueZ Bluetooth stack, and serves a good reference on how to create a tester for Windows.
AutoPTSClientBot has been added to automate running test cases on various configurations and reporting the results. Initial bot implementation supports running Zephyr tests on nrf52 board.
Key features
- Scheduler to run the script periodically
- Fetching recent project sources
- Applying changes to project configuration files via "iut_config" with "overlay" that need to be applied for "test_cases"
- Building ZephyrOS image
- Flashing board
- Running all the test cases
- Archiving test execution logs
- Storing the results in Excel spreadsheet file
- test case statuses
- pie chart
- Sending the files to the Google Drive
- Sending e-mail
Configuration
Bot is configured via "bot/config.py" file. Sample bot/config.py.sample
file
is provided. The configuration file is composed of project configurations.
This may contain few sections:
- 'name' - AutoPTS project name
- 'auto_pts' - AutoPTS configuration
- 'server_ip' - AutoPTSServer IP address
- 'client_port' - local AutoPTSClient port
- 'project_path' - path to project source directory
- 'workspace' - PTS workspace path to be used
- 'board' - IUT used. Currently nrf52 is supported only
- 'enable_max_logs' - enable debug logs
- 'retry' - maximum repeat count per test
- 'bd_addr' - IUT Bluetooth Address (optional)
- 'mail' - Mail configuration (optional)
- 'sender' - sender e-mail address
- 'smtp_host', 'smtp_port' - sender SMTP configuration
- 'name' - to be used in message footer
- 'passwd' - sender mailbox password. When Google account is used allow less secure apps to access account
- 'recipients' - list of e-mail addresses
- 'gdrive' - GDrive configuration (optional)
- 'root_directory_id' - Root Directory ID, can be obtained from URL,
https://drive.google.com/drive/u/0/folders/<GoogleDriveDirID>
- 'credentials_file' - path to credentials file to access Google Account. Read more here.
- 'root_directory_id' - Root Directory ID, can be obtained from URL,
- 'iut_config' - IUT configuration overlay. This is used to apply test case
specific changes in IUT configuration. It consists of dict of configuration
names and related key: value pairs:
- 'overlay' - changes in config to be applied
- 'test_cases' - test cases to be ran with this config
- 'scheduler' - Scheduler configuration (optional)
- "weekday": "time" dictionary.
Installation
Install required Python modules ( schedule, gitpython, xlsxwriter, google-api-python-client ) with:
cd ~/auto-pts # or to your directory where AutoPTS is cloned
pip2 install --user -r bot/requirements.txt
Usage
cd ~/auto-pts # or to your directory where AutoPTS is cloned
./autoptsclient_bot.py
Our IRC channel on freenode.net is #autopts