| #!/usr/bin/env python3.4 |
| # |
| # Copyright 2020 - Google |
| # |
| # Licensed under the Apache License, Version 2.0 (the "License"); |
| # you may not use this file except in compliance with the License. |
| # You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| """ |
| Test Script for 5G SMS scenarios |
| """ |
| |
| import time |
| from acts.utils import rand_ascii_str |
| from acts.test_decorators import test_tracker_info |
| from acts_contrib.test_utils.tel.TelephonyBaseTest import TelephonyBaseTest |
| from acts_contrib.test_utils.tel.tel_defines import WAIT_TIME_ANDROID_STATE_SETTLING |
| from acts_contrib.test_utils.tel.tel_test_utils import ensure_phones_idle |
| from acts_contrib.test_utils.tel.tel_test_utils import hangup_call |
| from acts_contrib.test_utils.tel.tel_voice_utils import is_phone_in_call_iwlan |
| from acts_contrib.test_utils.tel.tel_voice_utils import is_phone_in_call_volte |
| from acts_contrib.test_utils.tel.tel_voice_utils import is_phone_in_call_csfb |
| from acts_contrib.test_utils.tel.tel_5g_utils import disable_apm_mode_both_devices |
| from acts_contrib.test_utils.tel.tel_5g_utils import provision_both_devices_for_5g |
| from acts_contrib.test_utils.tel.tel_5g_utils import provision_both_devices_for_volte |
| from acts_contrib.test_utils.tel.tel_5g_utils import provision_both_devices_for_wfc_cell_pref |
| from acts_contrib.test_utils.tel.tel_5g_utils import provision_both_devices_for_wfc_wifi_pref |
| from acts_contrib.test_utils.tel.tel_5g_utils import verify_5g_attach_for_both_devices |
| from acts_contrib.test_utils.tel.tel_5g_utils import provision_both_devices_for_csfb |
| from acts_contrib.test_utils.tel.tel_sms_utils import _sms_test_mo |
| from acts_contrib.test_utils.tel.tel_sms_utils import _long_sms_test_mo |
| from acts_contrib.test_utils.tel.tel_sms_utils import test_sms_mo_in_call |
| |
| |
| class Nsa5gSmsTest(TelephonyBaseTest): |
| def setup_class(self): |
| super().setup_class() |
| |
| def setup_test(self): |
| TelephonyBaseTest.setup_test(self) |
| |
| def teardown_test(self): |
| ensure_phones_idle(self.log, self.android_devices) |
| |
| |
| """ Tests Begin """ |
| |
| |
| @test_tracker_info(uuid="4a64a262-7433-4a7f-b5c6-a36ff60aeaa2") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt(self): |
| """Test SMS between two phones in 5g NSA |
| |
| Provision devices in 5g NSA |
| Send and Verify SMS from PhoneA to PhoneB |
| Verify both devices are still on 5g NSA |
| |
| Returns: |
| True if success. |
| False if failed. |
| """ |
| ads = self.android_devices |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not _sms_test_mo(self.log, ads): |
| return False |
| |
| if not verify_5g_attach_for_both_devices(self.log, ads): |
| return False |
| |
| self.log.info("PASS - SMS test over 5G NSA validated") |
| return True |
| |
| |
| @test_tracker_info(uuid="2ce809d4-cbf6-4233-81ad-43f91107b201") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_volte(self): |
| """Test SMS between two phones with VoLTE on 5G NSA |
| |
| Provision devices on VoLTE |
| Provision devices in 5g NSA |
| Send and Verify SMS from PhoneA to PhoneB |
| Verify both devices are still on 5g NSA |
| |
| Returns: |
| True if success. |
| False if failed. |
| """ |
| |
| ads = self.android_devices |
| if not provision_both_devices_for_volte(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not _sms_test_mo(self.log, ads): |
| return False |
| |
| if not hangup_call(self.log, ads[0]): |
| ads[0].log.info("Failed to hang up call.!") |
| return False |
| |
| if not verify_5g_attach_for_both_devices(self.log, ads): |
| return False |
| |
| self.log.info("PASS - VoLTE SMS test over 5G NSA validated") |
| return True |
| |
| |
| @test_tracker_info(uuid="49bfb4b3-a6ec-45d4-ad96-09282fb07d1d") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_in_call_volte(self): |
| """ Test MO SMS during a MO VoLTE call over 5G NSA. |
| |
| Provision devices on VoLTE |
| Provision devices in 5g NSA |
| Make a Voice call from PhoneA to PhoneB |
| Send and Verify SMS from PhoneA to PhoneB |
| Verify both devices are still on 5g NSA |
| |
| Returns: |
| True if pass; False if fail. |
| """ |
| ads = self.android_devices |
| if not provision_both_devices_for_volte(self.log, ads): |
| return False |
| time.sleep(WAIT_TIME_ANDROID_STATE_SETTLING) |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not test_sms_mo_in_call(self.log, |
| ads, |
| caller_func=is_phone_in_call_volte): |
| return False |
| |
| if not verify_5g_attach_for_both_devices(self.log, ads): |
| return False |
| return True |
| |
| |
| @test_tracker_info(uuid="1f914d5c-ac24-4794-9fcb-cb28e483d69a") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_iwlan(self): |
| """ Test SMS text function between two phones, |
| Phones in APM, WiFi connected, WFC Cell Preferred mode. |
| |
| Disable APM on both devices |
| Provision devices in 5g NSA |
| Provision devices for WFC Cell Pref with APM ON |
| Send and Verify SMS from PhoneA to PhoneB |
| |
| Returns: |
| True if pass; False if fail. |
| """ |
| |
| ads = self.android_devices |
| if not disable_apm_mode_both_devices(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_wfc_cell_pref(self.log, |
| ads, |
| self.wifi_network_ssid, |
| self.wifi_network_pass, |
| apm_mode=True): |
| return False |
| time.sleep(WAIT_TIME_ANDROID_STATE_SETTLING) |
| |
| if not _sms_test_mo(self.log, ads): |
| return False |
| |
| self.log.info("PASS - iwlan sms test over 5g nsa validated") |
| return True |
| |
| |
| @test_tracker_info(uuid="7274be32-b9dd-4ce3-83d1-f32ab14ce05e") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_iwlan_apm_off(self): |
| """ Test MO SMS, Phone in APM off, WiFi connected, WFC WiFi Preferred mode. |
| |
| Disable APM on both devices |
| Provision devices in 5g NSA |
| Provision devices for WFC Wifi Pref with APM OFF |
| Send and Verify SMS from PhoneA to PhoneB |
| Verify 5g NSA attach for both devices |
| |
| Returns: |
| True if pass; False if fail. |
| """ |
| |
| ads = self.android_devices |
| if not disable_apm_mode_both_devices(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_wfc_wifi_pref(self.log, |
| ads, |
| self.wifi_network_ssid, |
| self.wifi_network_pass, |
| apm_mode=False): |
| return False |
| time.sleep(WAIT_TIME_ANDROID_STATE_SETTLING) |
| |
| if not _sms_test_mo(self.log, ads): |
| self.log.error("failed to send receive sms over 5g nsa") |
| return False |
| self.log.info("PASS - iwlan sms test over 5g nsa validated") |
| |
| if not verify_5g_attach_for_both_devices(self.log, ads): |
| return False |
| return True |
| |
| |
| @test_tracker_info(uuid="2d1787f2-d6fe-4b41-b389-2a8f817594e4") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_in_call_iwlan(self): |
| """ Test MO SMS, Phone in APM, WiFi connected, WFC WiFi Preferred mode. |
| |
| Disable APM on both devices |
| Provision devices in 5g NSA |
| Provision devices for WFC Wifi Pref with APM ON |
| Make a Voice call from PhoneA to PhoneB |
| Send and Verify SMS from PhoneA to PhoneB |
| |
| Returns: |
| True if pass; False if fail. |
| """ |
| |
| ads = self.android_devices |
| |
| if not disable_apm_mode_both_devices(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_wfc_wifi_pref(self.log, |
| ads, |
| self.wifi_network_ssid, |
| self.wifi_network_pass, |
| apm_mode=True): |
| return False |
| time.sleep(WAIT_TIME_ANDROID_STATE_SETTLING) |
| |
| return test_sms_mo_in_call(self.log, |
| ads, |
| caller_func=is_phone_in_call_iwlan) |
| |
| |
| @test_tracker_info(uuid="784062e8-02a4-49ce-8fc1-5359ab40bbdd") |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_long_message_mo_mt(self): |
| """Test SMS basic function between two phone. Phones in nsa 5G network. |
| |
| Airplane mode is off. |
| Send SMS from PhoneA to PhoneB. |
| Verify received message on PhoneB is correct. |
| |
| Returns: |
| True if success. |
| False if failed. |
| """ |
| |
| ads = self.android_devices |
| |
| if not disable_apm_mode_both_devices(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| return _long_sms_test_mo(self.log, ads) |
| |
| |
| @TelephonyBaseTest.tel_test_wrap |
| def test_5g_nsa_sms_mo_mt_in_call_csfb(self): |
| """ Test MO/MT SMS during a MO csfb call over 5G NSA. |
| |
| Disable APM on both devices |
| Set up PhoneA/B are in CSFB mode. |
| Provision PhoneA/B in 5g NSA. |
| Make sure PhoneA/B is able to make/receive call. |
| Call from PhoneA to PhoneB, accept on PhoneB, send SMS on PhoneA, |
| receive SMS on PhoneB. |
| |
| Returns: |
| True if pass; False if fail. |
| """ |
| ads = self.android_devices |
| |
| if not disable_apm_mode_both_devices(self.log, ads): |
| return False |
| |
| if not provision_both_devices_for_csfb(self.log, ads): |
| return False |
| time.sleep(WAIT_TIME_ANDROID_STATE_SETTLING) |
| |
| if not provision_both_devices_for_5g(self.log, ads): |
| return False |
| |
| return test_sms_mo_in_call(self.log, |
| ads, |
| caller_func=is_phone_in_call_csfb) |
| |
| """ Tests End """ |