1#!/usr/bin/env python3.4
2#
3#   Copyright 2018 - The Android Open Source Project
4#
5#   Licensed under the Apache License, Version 2.0 (the 'License');
6#   you may not use this file except in compliance with the License.
7#   You may obtain a copy of the License at
8#
9#       http://www.apache.org/licenses/LICENSE-2.0
10#
11#   Unless required by applicable law or agreed to in writing, software
12#   distributed under the License is distributed on an 'AS IS' BASIS,
13#   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14#   See the License for the specific language governing permissions and
15#   limitations under the License.
16
17import time
18from acts.test_decorators import test_tracker_info
19from acts_contrib.test_utils.power import PowerWiFiBaseTest as PWBT
20from acts_contrib.test_utils.wifi import wifi_test_utils as wutils
21
22UNLOCK_SCREEN = 'input keyevent 82'
23LOCATION_ON = 'settings put secure location_mode 3'
24
25
26class PowerWiFiscanTest(PWBT.PowerWiFiBaseTest):
27    def setup_class(self):
28        super().setup_class()
29        # Setup scan command
30        SINGLE_SHOT_SCAN = (
31            'nohup am instrument -w -r  -e min_scan_count \"700\"'
32            ' -e WifiScanTest-testWifiSingleShotScan %d'
33            ' -e class com.google.android.platform.powertests.'
34            'WifiScanTest#testWifiSingleShotScan'
35            ' com.google.android.platform.powertests/'
36            'androidx.test.runner.AndroidJUnitRunner > /dev/null &' %
37            (self.mon_duration + self.mon_offset + 10))
38        self.APK_SCAN_CMDS = {
39            'singleshot': SINGLE_SHOT_SCAN
40        }
41
42    def setup_test(self):
43        super().setup_test()
44        # Reset attenuation to minimum
45        self.set_attenuation([0, 0, 0, 0])
46        # Turn on location for WiFi Scans
47        self.dut.adb.shell(LOCATION_ON)
48
49    def scan_setup(self):
50        """Setup for scan based on the type of scan.
51
52        Trigger the desired scan.
53        """
54        self.log.info('Trigger {} scans'.format(self.test_configs.scan_mode))
55        if self.test_configs.scan_type == 'apk':
56            atten_setting = self.test_configs.wifi_band + '_' + self.test_configs.rssi
57            self.set_attenuation(self.atten_level[atten_setting])
58            self.dut.adb.shell_nb(
59                self.APK_SCAN_CMDS[self.test_configs.scan_mode])
60        else:
61            self.mon_info.offset = 0
62            if self.test_configs.scan_mode == 'pno':
63                self.log.info('Set attenuation to trigger PNO scan')
64                self.set_attenuation(self.atten_level['max_atten'])
65            elif self.test_configs.scan_mode == 'connectivity':
66                self.dut.droid.wakeUpNow()
67                self.log.info(
68                    'Now turn on screen to trigger connectivity scans')
69                self.dut.adb.shell(UNLOCK_SCREEN)
70            elif self.test_configs.scan_mode == 'roaming':
71                atten_setting = self.test_configs.wifi_band + '_roaming'
72                self.set_attenuation(self.atten_level[atten_setting])
73
74    def wifi_scan_test_func(self):
75
76        attrs = [
77            'screen_status', 'wifi_status', 'wifi_band', 'rssi', 'scan_type',
78            'scan_mode'
79        ]
80        indices = [2, 4, 6, 8, 10, 11]
81        self.decode_test_configs(attrs, indices)
82        if self.test_configs.wifi_status == 'Disconnected':
83            self.setup_ap_connection(
84                self.main_network[self.test_configs.wifi_band], connect=False)
85        elif self.test_configs.wifi_status == 'Connected':
86            self.setup_ap_connection(
87                self.main_network[self.test_configs.wifi_band])
88        else:
89            wutils.wifi_toggle_state(self.dut, True)
90        if self.test_configs.screen_status == 'OFF':
91            self.dut.droid.goToSleepNow()
92            self.dut.log.info('Screen is OFF')
93        time.sleep(2)
94        self.scan_setup()
95        self.measure_power_and_validate()
96
97    # Test cases
98    # Power.apk triggered singleshot scans
99    @test_tracker_info(uuid='e5539b01-e208-43c6-bebf-6f1e73d8d8cb')
100    def test_screen_OFF_WiFi_Disconnected_band_2g_RSSI_high_scan_apk_singleshot(
101            self):
102        self.wifi_scan_test_func()
103
104    @test_tracker_info(uuid='14c5a762-95bc-40ea-9fd4-27126df7d86c')
105    def test_screen_OFF_WiFi_Disconnected_band_2g_RSSI_low_scan_apk_singleshot(
106            self):
107        self.wifi_scan_test_func()
108
109    @test_tracker_info(uuid='a6506600-c567-43b5-9c25-86b505099b97')
110    def test_screen_OFF_WiFi_Disconnected_band_2g_RSSI_none_scan_apk_singleshot(
111            self):
112        self.wifi_scan_test_func()
113
114    @test_tracker_info(uuid='1a458248-1159-4c8e-a39f-92fc9e69c4dd')
115    def test_screen_OFF_WiFi_Disconnected_band_5g_RSSI_high_scan_apk_singleshot(
116            self):
117        self.wifi_scan_test_func()
118
119    @test_tracker_info(uuid='bd4da426-a621-4131-9f89-6e5a77f321d2')
120    def test_screen_OFF_WiFi_Disconnected_band_5g_RSSI_low_scan_apk_singleshot(
121            self):
122        self.wifi_scan_test_func()
123
124    @test_tracker_info(uuid='288b3add-8925-4803-81c0-53debf157ffc')
125    def test_screen_OFF_WiFi_Disconnected_band_5g_RSSI_none_scan_apk_singleshot(
126            self):
127        self.wifi_scan_test_func()
128
129    # Firmware/framework scans
130    @test_tracker_info(uuid='ff5ea952-ee31-4968-a190-82935ce7a8cb')
131    def test_screen_OFF_WiFi_ON_band_5g_RSSI_high_scan_system_connectivity(
132            self):
133        """WiFi disconected, turn on Screen to trigger connectivity scans.
134
135        """
136        self.wifi_scan_test_func()
137
138    @test_tracker_info(uuid='9a836e5b-8128-4dd2-8e96-e79177810bdd')
139    def test_screen_OFF_WiFi_Connected_band_2g_RSSI_high_scan_system_connectivity(
140            self):
141        """WiFi connected to 2g, turn on screen to trigger connectivity scans.
142
143        """
144        self.wifi_scan_test_func()
145
146    @test_tracker_info(uuid='51e3c4f1-742b-45af-afd5-ae3552a03272')
147    def test_screen_OFF_WiFi_Connected_band_2g_RSSI_high_scan_system_roaming(
148            self):
149        """WiFi connected to 2g, low RSSI to be below roaming threshold.
150
151        """
152        self.wifi_scan_test_func()
153
154    @test_tracker_info(uuid='a16ae337-326f-4d09-990f-42232c3c0dc4')
155    def test_screen_OFF_WiFi_Connected_band_2g_RSSI_high_scan_system_pno(self):
156        """WiFi connected to 2g, trigger pno scan.
157
158        """
159        self.wifi_scan_test_func()
160