1#!/usr/bin/env python3.4
2#
3#   Copyright 2016 - Google
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"""
17    Test Script for epdg RF shield box related tests.
18"""
19
20import time
21from acts.test_decorators import test_tracker_info
22from acts_contrib.test_utils.tel.TelephonyBaseTest import TelephonyBaseTest
23from acts_contrib.test_utils.tel.tel_atten_utils import set_rssi
24from acts_contrib.test_utils.tel.tel_defines import CELL_WEAK_RSSI_VALUE
25from acts_contrib.test_utils.tel.tel_defines import INVALID_WIFI_RSSI
26from acts_contrib.test_utils.tel.tel_defines import MAX_RSSI_RESERVED_VALUE
27from acts_contrib.test_utils.tel.tel_defines import MIN_RSSI_RESERVED_VALUE
28from acts_contrib.test_utils.tel.tel_defines import WAIT_TIME_WIFI_RSSI_CALIBRATION_SCREEN_ON
29from acts_contrib.test_utils.tel.tel_defines import WAIT_TIME_WIFI_RSSI_CALIBRATION_WIFI_CONNECTED
30from acts_contrib.test_utils.tel.tel_defines import WFC_MODE_CELLULAR_PREFERRED
31from acts_contrib.test_utils.tel.tel_defines import WFC_MODE_WIFI_PREFERRED
32from acts_contrib.test_utils.tel.tel_defines import WIFI_WEAK_RSSI_VALUE
33from acts_contrib.test_utils.tel.tel_defines import SignalStrengthContainer
34from acts_contrib.test_utils.tel.tel_test_utils import ensure_phones_default_state
35from acts_contrib.test_utils.tel.tel_test_utils import ensure_phone_subscription
36from acts_contrib.test_utils.tel.tel_test_utils import ensure_wifi_connected
37from acts_contrib.test_utils.tel.tel_test_utils import set_wfc_mode
38from acts_contrib.test_utils.tel.tel_test_utils import wait_for_wifi_data_connection
39from acts_contrib.test_utils.tel.tel_test_utils import verify_internet_connection
40from TelLiveConnectivityMonitorBaseTest import TelLiveConnectivityMonitorBaseTest
41
42# Attenuator name
43ATTEN_NAME_FOR_WIFI_2G = 'wifi0'
44ATTEN_NAME_FOR_WIFI_5G = 'wifi1'
45ATTEN_NAME_FOR_CELL_3G = 'cell0'
46ATTEN_NAME_FOR_CELL_4G = 'cell1'
47
48# WiFi RSSI settings for ROVE_IN test
49WIFI_RSSI_FOR_ROVE_IN_TEST_PHONE_ROVE_IN = -60
50WIFI_RSSI_FOR_ROVE_IN_TEST_PHONE_NOT_ROVE_IN = -70
51
52# WiFi RSSI settings for ROVE_OUT test
53WIFI_RSSI_FOR_ROVE_OUT_TEST_PHONE_INITIAL_STATE = -60
54WIFI_RSSI_FOR_ROVE_OUT_TEST_PHONE_NOT_ROVE_OUT = -70
55WIFI_RSSI_FOR_ROVE_OUT_TEST_PHONE_ROVE_OUT = -90
56
57# WiFi RSSI settings for HAND_IN test
58WIFI_RSSI_FOR_HAND_IN_TEST_PHONE_NOT_HAND_IN = -80
59WIFI_RSSI_FOR_HAND_IN_TEST_PHONE_HAND_IN = -50
60
61# WiFi RSSI settings for HAND_OUT test
62WIFI_RSSI_FOR_HAND_OUT_TEST_PHONE_NOT_HAND_OUT = -60
63WIFI_RSSI_FOR_HAND_OUT_TEST_PHONE_HAND_OUT = -85
64
65CS_LINK_LOST = "Radio Link Lost"
66IMS_LINK_LOST = "Media Timeout"
67
68
69class TelLiveConnectivityMonitorMobilityTest(
70        TelLiveConnectivityMonitorBaseTest):
71    def setup_class(self):
72        TelLiveConnectivityMonitorBaseTest.setup_class(self)
73
74        self.attens = {}
75        for atten in self.attenuators:
76            self.attens[atten.path] = atten
77            atten.set_atten(atten.get_max_atten())  # Default all attens to max
78
79
80        # Do WiFi RSSI calibration.
81        self.set_wifi_strong_cell_strong()
82
83        if not ensure_phone_subscription(self.log, self.dut):
84            self.dut.log.error("Failed to find valid subscription")
85            return False
86        if not ensure_wifi_connected(self.log, self.dut,
87                                     self.wifi_network_ssid,
88                                     self.wifi_network_pass):
89            self.dut.log.error("Fail to connect to WiFI")
90            return False
91        if (not wait_for_wifi_data_connection(self.log, self.dut, True)
92                or not verify_internet_connection(self.log, self.dut)):
93            self.dut.log.error("No Data on Wifi")
94            return False
95
96        # Delay WAIT_TIME_WIFI_RSSI_CALIBRATION_WIFI_CONNECTED after WiFi
97        # Connected to make sure WiFi RSSI reported value is correct.
98        time.sleep(WAIT_TIME_WIFI_RSSI_CALIBRATION_WIFI_CONNECTED)
99        # Turn On Screen and delay WAIT_TIME_WIFI_RSSI_CALIBRATION_SCREEN_ON
100        # then get WiFi RSSI to avoid WiFi RSSI report -127(invalid value).
101        self.dut.droid.wakeUpNow()
102        time.sleep(WAIT_TIME_WIFI_RSSI_CALIBRATION_SCREEN_ON)
103
104        setattr(self, "wifi_rssi_with_no_atten",
105                self.dut.droid.wifiGetConnectionInfo()['rssi'])
106        if self.wifi_rssi_with_no_atten == INVALID_WIFI_RSSI:
107            self.dut.log.error(
108                "Initial WiFi RSSI calibration value is wrong: -127.")
109            return False
110        self.dut.log.info("WiFi RSSI calibration info: atten=0, RSSI=%s",
111                          self.wifi_rssi_with_no_atten)
112        ensure_phones_default_state(self.log, [self.dut])
113
114        # Do Cellular RSSI calibration.
115        setattr(self, "cell_rssi_with_no_atten",
116                self.dut.droid.telephonyGetSignalStrength()[
117                    SignalStrengthContainer.SIGNAL_STRENGTH_LTE_DBM])
118        self.dut.log.info("Cellular RSSI calibration info: atten=0, RSSI=%s",
119                          self.cell_rssi_with_no_atten)
120        return True
121
122    def teardown_class(self):
123        self.dut.droid.telephonyStopTrackingSignalStrengthChange()
124        super().teardown_class()
125        return True
126
127    def setup_test(self):
128        super().setup_test()
129        self.set_wifi_strong_cell_strong()
130        return True
131
132    def teardown_test(self):
133        super().teardown_test()
134        self.set_wifi_strong_cell_strong()
135        return True
136
137    def set_wifi_strong_cell_strong(self):
138        self.log.info("--->Setting WiFi strong cell strong<---")
139        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
140                 MAX_RSSI_RESERVED_VALUE)
141        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
142                 MAX_RSSI_RESERVED_VALUE)
143        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
144                 MAX_RSSI_RESERVED_VALUE)
145        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
146                 MAX_RSSI_RESERVED_VALUE)
147        return True
148
149    def set_wifi_strong_cell_weak(self):
150        self.log.info("--->Setting WiFi strong cell weak<---")
151        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
152                 MAX_RSSI_RESERVED_VALUE)
153        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
154                 MAX_RSSI_RESERVED_VALUE)
155        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G],
156                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
157        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G],
158                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
159        return True
160
161    def set_wifi_strong_cell_absent(self):
162        self.log.info("--->Setting WiFi strong cell absent<---")
163        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
164                 MAX_RSSI_RESERVED_VALUE)
165        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
166                 MAX_RSSI_RESERVED_VALUE)
167        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
168                 MIN_RSSI_RESERVED_VALUE)
169        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
170                 MIN_RSSI_RESERVED_VALUE)
171        return True
172
173    def set_wifi_weak_cell_strong(self):
174        self.log.info("--->Setting WiFi weak cell strong<---")
175        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G],
176                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
177        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G],
178                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
179        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
180                 MAX_RSSI_RESERVED_VALUE)
181        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
182                 MAX_RSSI_RESERVED_VALUE)
183        return True
184
185    def set_wifi_weak_cell_weak(self):
186        self.log.info("--->Setting WiFi weak cell weak<---")
187        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G],
188                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
189        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G],
190                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
191        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G],
192                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
193        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G],
194                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
195        return True
196
197    def set_wifi_weak_cell_absent(self):
198        self.log.info("--->Setting WiFi weak cell absent<---")
199        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G],
200                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
201        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G],
202                 self.wifi_rssi_with_no_atten, WIFI_WEAK_RSSI_VALUE)
203        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
204                 MIN_RSSI_RESERVED_VALUE)
205        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
206                 MIN_RSSI_RESERVED_VALUE)
207        return True
208
209    def set_wifi_absent_cell_strong(self):
210        self.log.info("--->Setting WiFi absent cell strong<---")
211        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
212                 MIN_RSSI_RESERVED_VALUE)
213        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
214                 MIN_RSSI_RESERVED_VALUE)
215        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
216                 MAX_RSSI_RESERVED_VALUE)
217        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
218                 MAX_RSSI_RESERVED_VALUE)
219        return True
220
221    def set_wifi_absent_cell_weak(self):
222        self.log.info("--->Setting WiFi absent cell weak<---")
223        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
224                 MIN_RSSI_RESERVED_VALUE)
225        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
226                 MIN_RSSI_RESERVED_VALUE)
227        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G],
228                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
229        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G],
230                 self.cell_rssi_with_no_atten, CELL_WEAK_RSSI_VALUE)
231        return True
232
233    def set_wifi_absent_cell_absent(self):
234        self.log.info("--->Setting WiFi absent cell absent<---")
235        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_2G], 0,
236                 MIN_RSSI_RESERVED_VALUE)
237        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_WIFI_5G], 0,
238                 MIN_RSSI_RESERVED_VALUE)
239        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_3G], 0,
240                 MIN_RSSI_RESERVED_VALUE)
241        set_rssi(self.log, self.attens[ATTEN_NAME_FOR_CELL_4G], 0,
242                 MIN_RSSI_RESERVED_VALUE)
243        return True
244
245    """ Tests Begin """
246
247    @test_tracker_info(uuid="d474725b-c34d-4686-8b5f-c0d4733a0cc1")
248    @TelephonyBaseTest.tel_test_wrap
249    def test_volte_call_drop_by_poor_signals(self):
250        return self.forced_call_drop_test(
251            setup="volte",
252            triggers=[
253                "set_wifi_absent_cell_absent", "set_wifi_strong_cell_strong"
254            ],
255            expected_drop_reason=IMS_LINK_LOST)
256
257    @test_tracker_info(uuid="7f62f1c0-6d9e-4e7e-812f-b1c60d2f4b41")
258    @TelephonyBaseTest.tel_test_wrap
259    def test_csfb_call_drop_by_poor_signals(self):
260        return self.forced_call_drop_test(
261            setup="csfb",
262            triggers=[
263                "set_wifi_absent_cell_absent", "set_wifi_strong_cell_strong"
264            ],
265            expected_drop_reason=CS_LINK_LOST)
266
267    @test_tracker_info(uuid="8d1c8c44-be54-43ec-892c-c3f41855c7c8")
268    @TelephonyBaseTest.tel_test_wrap
269    def test_3g_call_drop_by_poor_signal(self):
270        return self.forced_call_drop_test(
271            setup="3g",
272            triggers=[
273                "set_wifi_absent_cell_absent", "set_wifi_strong_cell_strong"
274            ],
275            expected_drop_reason=CS_LINK_LOST)
276
277    @test_tracker_info(uuid="66e01cb3-3bea-4d08-9ab4-7f22790c57b1")
278    @TelephonyBaseTest.tel_test_wrap
279    def test_wfc_apm_call_drop_by_poor_signal(self):
280        return self.forced_call_drop_test(
281            setup="wfc_apm",
282            triggers=[
283                "set_wifi_absent_cell_absent", "set_wifi_strong_cell_strong"
284            ],
285            expected_drop_reason=IMS_LINK_LOST)
286
287    @test_tracker_info(uuid="669e9f97-6931-403a-a13d-4f179bd4406f")
288    @TelephonyBaseTest.tel_test_wrap
289    def test_wfc_non_apm_call_drop_by_poor_signal(self):
290        self.setup_wfc_non_apm()
291        return self.forced_call_drop_test(
292            setup="wfc_non_apm",
293            triggers=[
294                "set_wifi_absent_cell_absent", "set_wifi_strong_cell_strong"
295            ],
296            expected_drop_reason=IMS_LINK_LOST)
297
298    @test_tracker_info(uuid="c7619788-2357-4c49-a754-50ffaf433d59")
299    @TelephonyBaseTest.tel_test_wrap
300    def test_volte_handover_to_wfc_then_hangup(self):
301        self.connect_to_wifi()
302        self.enable_wfc()
303        set_wfc_mode(self.log, self.dut, WFC_MODE_CELLULAR_PREFERRED)
304        self.setup_volte()
305        return self.call_setup_and_connectivity_monitor_checking(
306            setup="volte",
307            handover="wfc_non_apm",
308            triggers=["set_wifi_strong_cell_absent"],
309            expected_drop_reason=None,
310            expected_trouble=None,
311            expected_action=None)
312
313    @test_tracker_info(uuid="c10c8406-6a0c-4039-b2ce-3782593774f2")
314    @TelephonyBaseTest.tel_test_wrap
315    def test_csfb_handover_to_wfc_then_hangup(self):
316        self.setup_csfb()
317        self.connect_to_wifi()
318        self.enable_wfc()
319        self.set_wifi_absent_cell_strong()
320        return self.call_setup_and_connectivity_monitor_checking(
321            setup="csfb",
322            handover="wfc_non_apm",
323            triggers=[
324                "set_wifi_strong_cell_strong", "connect_to_wifi",
325                "is_wfc_enabled", "set_wifi_strong_cell_absent"
326            ],
327            expected_drop_reason=None,
328            expected_trouble=None,
329            expected_action=None)
330
331    @test_tracker_info(uuid="fcb62ea3-3a39-407c-90d8-21896c981ef4")
332    @TelephonyBaseTest.tel_test_wrap
333    def test_3g_handover_to_wfc_then_hangup(self):
334        self.setup_3g()
335        self.connect_to_wifi()
336        self.enable_wfc()
337        set_wfc_mode(self.log, self.dut, WFC_MODE_CELLULAR_PREFERRED)
338        if not self.is_wfc_enabled():
339            self.dut.log.error("WFC is not enabled")
340            return False
341        return self.call_setup_and_connectivity_monitor_checking(
342            setup="3g",
343            handover="wfc_non_apm",
344            triggers=["set_wifi_strong_cell_absent"],
345            expected_drop_reason=None,
346            expected_trouble=None,
347            expected_action=None)
348
349    @test_tracker_info(uuid="85f32373-d1b2-4763-8812-d7ff43a9b3e6")
350    @TelephonyBaseTest.tel_test_wrap
351    def test_wfc_handover_to_volte_then_hangup(self):
352        self.setup_volte()
353        self.connect_to_wifi()
354        self.enable_wfc()
355        self.set_wifi_strong_cell_absent()
356        if not self.is_wfc_enabled():
357            self.dut.log.error("WFC is not enabled")
358            return False
359        return self.call_setup_and_connectivity_monitor_checking(
360            setup="wfc_non_apm",
361            handover="volte",
362            triggers=[
363                "set_wifi_strong_cell_strong", "set_wifi_absent_cell_strong"
364            ],
365            expected_drop_reason=None,
366            expected_trouble=None,
367            expected_action=None)
368
369    @test_tracker_info(uuid="c3dee2ba-1637-4382-97a7-ec9ca795f3dc")
370    @TelephonyBaseTest.tel_test_wrap
371    def test_wfc_handover_to_volte_then_call_drop(self):
372        self.setup_volte()
373        self.connect_to_wifi()
374        self.enable_wfc()
375        self.set_wifi_strong_cell_absent()
376        if not self.is_wfc_enabled():
377            self.dut.log.error("WFC is not enabled")
378            return False
379        return self.call_drop_test(
380            setup="wfc_non_apm",
381            handover="volte",
382            count=1,
383            triggers=[
384                "set_wifi_strong_cell_strong", "set_wifi_absent_cell_strong",
385                "set_wifi_absent_cell_absent"
386            ],
387            expected_drop_reason=IMS_LINK_LOST,
388            expected_trouble=None,
389            expected_action=None)
390
391    @test_tracker_info(uuid="90bc318a-b8ba-45c9-8d8f-e642eeb00460")
392    @TelephonyBaseTest.tel_test_wrap
393    def test_wfc_handover_to_csfb_then_call_drop(self):
394        self.setup_csfb()
395        self.set_wifi_strong_cell_absent()
396        self.connect_to_wifi()
397        self.enable_wfc()
398        if not self.is_wfc_enabled():
399            self.dut.log.error("WFC is not enabled")
400            return False
401        return self.call_drop_test(
402            setup="wfc_apm",
403            handover="csfb",
404            count=1,
405            triggers=[
406                "set_wifi_strong_cell_strong", "set_wifi_absent_cell_strong",
407                "set_wifi_absent_cell_absent"
408            ],
409            expected_drop_reason=CS_LINK_LOST,
410            expected_trouble=None,
411            expected_action=None)
412
413    @test_tracker_info(uuid="0557709e-6d82-4c66-b622-6f36db8bdcc2")
414    @TelephonyBaseTest.tel_test_wrap
415    def test_volte_handover_to_wfc_then_call_drop(self):
416        self.setup_volte()
417        self.connect_to_wifi()
418        self.enable_wfc()
419        self.set_wifi_absent_cell_strong()
420        return self.call_drop_test(
421            setup="volte",
422            handover="wfc_non_apm",
423            count=1,
424            triggers=[
425                "set_wifi_strong_cell_strong", "connect_to_wifi",
426                "is_wfc_enabled", "set_wifi_strong_cell_absent",
427                "set_wifi_absent_cell_absent"
428            ],
429            expected_drop_reason=IMS_LINK_LOST,
430            expected_trouble=None,
431            expected_action=None)
432
433    @test_tracker_info(uuid="3453ed14-8227-4050-96f1-e9ac7973df3b")
434    @TelephonyBaseTest.tel_test_wrap
435    def test_csfb_handover_to_wfc_then_call_drop(self):
436        self.setup_csfb()
437        self.connect_to_wifi()
438        self.enable_wfc()
439        self.set_wifi_absent_cell_strong()
440        return self.call_drop_test(
441            setup="csfb",
442            handover="wfc",
443            count=1,
444            triggers=[
445                "set_wifi_strong_cell_strong", "connect_to_wifi",
446                "is_wfc_enabled", "set_wifi_strong_cell_absent",
447                "set_wifi_absent_cell_absent"
448            ],
449            expected_drop_reason=IMS_LINK_LOST,
450            expected_trouble=None,
451            expected_action=None)
452
453    @test_tracker_info(uuid="68cc68db-c60b-4c4a-a974-8e0d1fa211f2")
454    @TelephonyBaseTest.tel_test_wrap
455    def test_3g_handover_to_wfc_then_call_drop(self):
456        self.setup_3g()
457        self.connect_to_wifi()
458        self.enable_wfc()
459        self.set_wifi_absent_cell_strong()
460        return self.call_drop_test(
461            setup="3g",
462            handover="wfc_non_apm",
463            count=1,
464            triggers=[
465                "set_wifi_strong_cell_strong", "connect_to_wifi",
466                "is_wfc_enabled", "set_wifi_strong_cell_absent",
467                "set_wifi_absent_cell_absent"
468            ],
469            expected_drop_reason=IMS_LINK_LOST,
470            expected_trouble=None,
471            expected_action=None)
472
473
474""" Tests End """
475