2018-08-28 06:57:56 +00:00
## Running Icetea tests located under mbed-os
2018-01-23 10:26:14 +00:00
### Structure
2018-09-10 20:37:39 +00:00
Mbed OS has a folder called `TEST_APPS` that contains everything related to Icetea testing.
2018-01-23 10:26:14 +00:00
2018-09-11 17:49:28 +00:00
There are currently three folders:
- `device` - contains all the different test applications you can flash to your board.
- `icetea_plugins` - contains plugins that are being used by some of the testcases, needed for the test execution.
- `testcases` - contains Icetea testcases written in Python.
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
The testcases depend on test applications.
2018-01-23 10:26:14 +00:00
### Preparing your work environment
2018-09-10 20:37:39 +00:00
#### Prerequisites
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
You need Icetea and version 1.8.0 or higher of Mbed CLI installed.
2018-01-23 10:26:14 +00:00
#### Selecting the network interface to use
2018-09-11 17:49:28 +00:00
Depending on the device, there might be a default network interface type defined in `mbed-os/targets/targets.json` , which you can use to locate a default test-config file.
If the default network interface type is not defined or you want to use a different interface than the default, you need to provide a test-config file to the mbed test with `--test-config` option.
2018-09-10 20:37:39 +00:00
The test-config file contains the necessary information for the test application. There are some test-config files located under `mbed-os/tools/test_configs` .
2018-09-11 17:49:28 +00:00
Devices that have their network drivers residing inside `mbed-os` can use generic `test_configs` , such as `HeapBlockDeviceAndEthernetInterface.json` and `HeapBlockDeviceAndWifiInterface.json` . Otherwise, you need to use a device-specific test-config.
2018-01-23 10:26:14 +00:00
### Running the tests
2018-09-11 17:49:28 +00:00
Now that you have selected the interface, you can run the Icetea tests from the `mbed-os` root on your command-line by running the following command:
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
`mbed test -m <target> -t <toolchain> --icetea`
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
This command compiles the OS, compiles the test applications, creates a test suite and then starts running the tests.
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
If you only want to run some specific tests, you can use the `-n` option. You can choose multiple tests by separating them with a comma (`,`):
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
`mbed test -m <target> -t <toolchain> --icetea -n test1,test2`
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
#### Running the tests with a specific test-config
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
Some devices may offer multiple network interfaces to operate with. For example, `UBLOX_EVK_ODIN_W2` offers ethernet and Wi-Fi capabilities.
2018-09-11 17:49:28 +00:00
2018-01-23 10:26:14 +00:00
The tests can be run for either one of those using already existing test-config -files.
2018-09-10 20:37:39 +00:00
To run the tests with the Wi-Fi interface:
2018-09-11 17:49:28 +00:00
2018-09-10 20:37:39 +00:00
`mbed test -m UBLOX_EVK_ODIN_W2 -t <toolchain> --icetea --test-config tools/test_configs/HeapBlockDeviceAndWifiInterface.json`
2018-01-23 10:26:14 +00:00
2018-09-10 20:37:39 +00:00
To run the tests with the ethernet interface:
2018-09-11 17:49:28 +00:00
2018-09-10 20:37:39 +00:00
`mbed test -m UBLOX_EVK_ODIN_W2 -t <toolchain> --icetea --test-config tools/test_configs/HeapBlockDeviceAndEthernetInterface.json`
2018-01-23 10:26:14 +00:00
#### Providing Wi-Fi access point information
2018-09-10 20:37:39 +00:00
If you are using the Wi-Fi interface for running the tests, you need to also provide information about the used access point.
2018-09-11 17:49:28 +00:00
2018-08-31 07:30:20 +00:00
The information can be provided in the used test-config file.
2018-01-23 10:26:14 +00:00
2018-08-29 07:49:37 +00:00
Example of access point information:
2018-09-11 17:49:28 +00:00
2018-01-23 10:26:14 +00:00
```
2018-08-29 07:49:37 +00:00
"target_overrides": {
"*": {
"target.network-default-interface-type": "WIFI",
"nsapi.default-wifi-ssid": "\"ssid\"",
"nsapi.default-wifi-password": "\"password\"",
"nsapi.default-wifi-security": "WPA_WPA2"
}
}
2018-01-23 10:26:14 +00:00
```
### Test results
2018-09-11 17:49:28 +00:00
Icetea prints the results from the test run to the command-line, and the final result looks similar to this:
2018-01-23 10:26:14 +00:00
```
+--------------------------------+---------+-------------+-------------+-----------+----------+
| Testcase | Verdict | Fail Reason | Skip Reason | platforms | duration |
+--------------------------------+---------+-------------+-------------+-----------+----------+
| test_cmdline | pass | | | K64F | 8.555 |
| UDPSOCKET_BIND_PORT | pass | | | K64F | 19.614 |
| TCPSOCKET_BIND_PORT | pass | | | K64F | 15.852 |
| TCPSERVER_ACCEPT | pass | | | K64F | 41.629 |
| TCPSOCKET_ECHOTEST_BURST_SHORT | pass | | | K64F | 19.926 |
+--------------------------------+---------+-------------+-------------+-----------+----------+
+---------------+----------------+
| Summary | |
+---------------+----------------+
| Final Verdict | PASS |
| count | 5 |
| passrate | 100.00 % |
| pass | 5 |
| Duration | 0:01:45.576000 |
+---------------+----------------+
```
2018-09-11 17:49:28 +00:00
You can also find the results from the tests in the `mbed-os/log` folder.
You probably want to add the log folder to your `.mbedignore` file to prevent issues with build commands becoming too long over the time.