1# Wi-Fi RTT (IEEE 802.11mc) Integrated (ACTS/sl4a) Test Suite
2
3This directory contains ACTS/sl4a test scripts to verify and characterize
4the Wi-Fi RTT (IEEE 802.11mc) implementation in Android.
5
6There are 2 groups of tests (in 2 sub-directories):
7
8* functional: Functional tests that each implementation must pass. These
9are pass/fail tests.
10* stress: Tests which run through a large number of iterations to stress
11test the implementation. Considering that some failures are expected,
12especially in an over-the-air situation, pass/fail criteria are either
13not provided or may not apply to all implementations or test environments.
14
15The tests can be executed using:
16
17`act.py -c <config> -tc {<test_class>|<test_class>:<test_name>}`
18
19Where a test file is any of the `.py` files in any of the test sub-directories.
20If a test class is specified, then all tests within that test class are executed.
21
22## Test Beds
23The Wi-Fi RTT tests support several different test scenarios which require different test bed
24configuration. The test beds and their corresponding test files are:
25
26* Device Under Test + AP which supports IEEE 802.11mc
27  * functional/RangeApSupporting11McTest.py
28  * functional/RttRequestManagementTest.py
29  * functional/RttDisableTest.py
30  * stress/StressRangeApTest.py
31* Device Under Test + AP which does **not** support IEEE 802.11mc
32  * functional/RangeApNonSupporting11McTest.py
33* 2 Devices Under Test
34  * functional/RangeAwareTest.py
35  * functional/AwareDiscoveryWithRangingTest.py
36  * functional/RangeSoftApTest.py
37  * stress/StressRangeAwareTest.py
38
39## Test Configurations
40The test configuration, the `<config>` in the commands above, is stored in
41the *config* sub-directory. The configuration simply uses all connected
42devices without listing specific serial numbers. Note that some tests use a
43single device while others use 2 devices.
44
45The only provided configuration is *wifi_rtt.json*.
46
47The configuration defines the following keys to configure the test:
48
49* **lci_reference**, **lcr_reference**: Arrays of bytes used to validate that the *correct* LCI and
50LCR were received from the AP. These are empty by default and should be configured to match the
51configuration of the AP used in the test.
52* **rtt_reference_distance_mm**: The reference distance, in mm, between the test device and the test
53AP or between the two test devices (for Aware ranging tests).
54* **stress_test_min_iteration_count**, **stress_test_target_run_time_sec**: Parameters used to
55control the length and duration of the stress tests. The stress test runs for the specified number
56of iterations or for the specified duration - whichever is longer.
57* **dbs_supported_models**: A list of device models which support DBS. Used to determine whether
58RTT will run while a SoftAP (SAP) is enabled. The model name corresponds to the value returned by
59*android_device.model*.
60