| /* |
| * Copyright (C) 2020 The Android Open Source Project |
| * |
| * 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. |
| */ |
| |
| #include <radio_hidl_hal_utils_v1_6.h> |
| |
| #define ASSERT_OK(ret) ASSERT_TRUE(ret.isOk()) |
| |
| /* |
| * Test IRadio.setupDataCall_1_6() for the response returned. |
| */ |
| TEST_P(RadioHidlTest_v1_6, setupDataCall_1_6) { |
| serial = GetRandomSerialNumber(); |
| |
| ::android::hardware::radio::V1_5::AccessNetwork accessNetwork = |
| ::android::hardware::radio::V1_5::AccessNetwork::EUTRAN; |
| |
| android::hardware::radio::V1_5::DataProfileInfo dataProfileInfo; |
| memset(&dataProfileInfo, 0, sizeof(dataProfileInfo)); |
| dataProfileInfo.profileId = DataProfileId::DEFAULT; |
| dataProfileInfo.apn = hidl_string("internet"); |
| dataProfileInfo.protocol = PdpProtocolType::IP; |
| dataProfileInfo.roamingProtocol = PdpProtocolType::IP; |
| dataProfileInfo.authType = ApnAuthType::NO_PAP_NO_CHAP; |
| dataProfileInfo.user = hidl_string("username"); |
| dataProfileInfo.password = hidl_string("password"); |
| dataProfileInfo.type = DataProfileInfoType::THREE_GPP; |
| dataProfileInfo.maxConnsTime = 300; |
| dataProfileInfo.maxConns = 20; |
| dataProfileInfo.waitTime = 0; |
| dataProfileInfo.enabled = true; |
| dataProfileInfo.supportedApnTypesBitmap = 320; |
| dataProfileInfo.bearerBitmap = 161543; |
| dataProfileInfo.mtuV4 = 0; |
| dataProfileInfo.mtuV6 = 0; |
| dataProfileInfo.preferred = true; |
| dataProfileInfo.persistent = false; |
| |
| bool roamingAllowed = false; |
| |
| std::vector<::android::hardware::radio::V1_5::LinkAddress> addresses = {}; |
| std::vector<hidl_string> dnses = {}; |
| |
| ::android::hardware::radio::V1_2::DataRequestReason reason = |
| ::android::hardware::radio::V1_2::DataRequestReason::NORMAL; |
| |
| Return<void> res = radio_v1_6->setupDataCall_1_6(serial, accessNetwork, dataProfileInfo, |
| roamingAllowed, reason, addresses, dnses); |
| ASSERT_OK(res); |
| |
| EXPECT_EQ(std::cv_status::no_timeout, wait()); |
| EXPECT_EQ(RadioResponseType::SOLICITED, radioRsp_v1_6->rspInfo.type); |
| EXPECT_EQ(serial, radioRsp_v1_6->rspInfo.serial); |
| |
| if (cardStatus.base.base.base.cardState == CardState::ABSENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::SIM_ABSENT, |
| ::android::hardware::radio::V1_6::RadioError::RADIO_NOT_AVAILABLE, |
| ::android::hardware::radio::V1_6::RadioError::OP_NOT_ALLOWED_BEFORE_REG_TO_NW})); |
| } else if (cardStatus.base.base.base.cardState == CardState::PRESENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::NONE, |
| ::android::hardware::radio::V1_6::RadioError::RADIO_NOT_AVAILABLE, |
| ::android::hardware::radio::V1_6::RadioError::OP_NOT_ALLOWED_BEFORE_REG_TO_NW})); |
| } |
| } |
| |
| /* |
| * Test IRadio_1_6.sendSms() for the response returned. |
| */ |
| TEST_P(RadioHidlTest_v1_6, sendSms_1_6) { |
| LOG(DEBUG) << "sendSms"; |
| serial = GetRandomSerialNumber(); |
| GsmSmsMessage msg; |
| msg.smscPdu = ""; |
| msg.pdu = "01000b916105770203f3000006d4f29c3e9b01"; |
| |
| radio_v1_6->sendSms(serial, msg); |
| |
| EXPECT_EQ(std::cv_status::no_timeout, wait()); |
| EXPECT_EQ(RadioResponseType::SOLICITED, radioRsp_v1_6->rspInfo.type); |
| EXPECT_EQ(serial, radioRsp_v1_6->rspInfo.serial); |
| |
| if (cardStatus.base.base.base.cardState == CardState::ABSENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::INVALID_ARGUMENTS, |
| ::android::hardware::radio::V1_6::RadioError::INVALID_STATE, |
| ::android::hardware::radio::V1_6::RadioError::SIM_ABSENT}, |
| CHECK_GENERAL_ERROR)); |
| EXPECT_EQ(0, radioRsp_v1_6->sendSmsResult.errorCode); |
| } |
| LOG(DEBUG) << "sendSms finished"; |
| } |
| |
| /* |
| * Test IRadio_1_6.sendSMSExpectMore() for the response returned. |
| */ |
| TEST_P(RadioHidlTest_v1_6, sendSMSExpectMore_1_6) { |
| LOG(DEBUG) << "sendSMSExpectMore"; |
| serial = GetRandomSerialNumber(); |
| GsmSmsMessage msg; |
| msg.smscPdu = ""; |
| msg.pdu = "01000b916105770203f3000006d4f29c3e9b01"; |
| |
| radio_v1_6->sendSMSExpectMore(serial, msg); |
| |
| EXPECT_EQ(std::cv_status::no_timeout, wait()); |
| EXPECT_EQ(RadioResponseType::SOLICITED, radioRsp_v1_6->rspInfo.type); |
| EXPECT_EQ(serial, radioRsp_v1_6->rspInfo.serial); |
| |
| if (cardStatus.base.base.base.cardState == CardState::ABSENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::INVALID_ARGUMENTS, |
| ::android::hardware::radio::V1_6::RadioError::INVALID_STATE, |
| ::android::hardware::radio::V1_6::RadioError::SIM_ABSENT}, |
| CHECK_GENERAL_ERROR)); |
| } |
| LOG(DEBUG) << "sendSMSExpectMore finished"; |
| } |
| |
| /* |
| * Test IRadio_1_6.sendCdmaSms() for the response returned. |
| */ |
| TEST_P(RadioHidlTest_v1_6, sendCdmaSms_1_6) { |
| LOG(DEBUG) << "sendCdmaSms"; |
| serial = GetRandomSerialNumber(); |
| |
| // Create a CdmaSmsAddress |
| CdmaSmsAddress cdmaSmsAddress; |
| cdmaSmsAddress.digitMode = CdmaSmsDigitMode::FOUR_BIT; |
| cdmaSmsAddress.numberMode = CdmaSmsNumberMode::NOT_DATA_NETWORK; |
| cdmaSmsAddress.numberType = CdmaSmsNumberType::UNKNOWN; |
| cdmaSmsAddress.numberPlan = CdmaSmsNumberPlan::UNKNOWN; |
| cdmaSmsAddress.digits = (std::vector<uint8_t>){11, 1, 6, 5, 10, 7, 7, 2, 10, 3, 10, 3}; |
| |
| // Create a CdmaSmsSubAddress |
| CdmaSmsSubaddress cdmaSmsSubaddress; |
| cdmaSmsSubaddress.subaddressType = CdmaSmsSubaddressType::NSAP; |
| cdmaSmsSubaddress.odd = false; |
| cdmaSmsSubaddress.digits = (std::vector<uint8_t>){}; |
| |
| // Create a CdmaSmsMessage |
| android::hardware::radio::V1_0::CdmaSmsMessage cdmaSmsMessage; |
| cdmaSmsMessage.teleserviceId = 4098; |
| cdmaSmsMessage.isServicePresent = false; |
| cdmaSmsMessage.serviceCategory = 0; |
| cdmaSmsMessage.address = cdmaSmsAddress; |
| cdmaSmsMessage.subAddress = cdmaSmsSubaddress; |
| cdmaSmsMessage.bearerData = |
| (std::vector<uint8_t>){15, 0, 3, 32, 3, 16, 1, 8, 16, 53, 76, 68, 6, 51, 106, 0}; |
| |
| radio_v1_6->sendCdmaSms(serial, cdmaSmsMessage); |
| |
| EXPECT_EQ(std::cv_status::no_timeout, wait()); |
| EXPECT_EQ(RadioResponseType::SOLICITED, radioRsp_v1_6->rspInfo.type); |
| EXPECT_EQ(serial, radioRsp_v1_6->rspInfo.serial); |
| |
| if (cardStatus.base.base.base.cardState == CardState::ABSENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::INVALID_ARGUMENTS, |
| ::android::hardware::radio::V1_6::RadioError::INVALID_STATE, |
| ::android::hardware::radio::V1_6::RadioError::SIM_ABSENT}, |
| CHECK_GENERAL_ERROR)); |
| } |
| LOG(DEBUG) << "sendCdmaSms finished"; |
| } |
| |
| /* |
| * Test IRadio_1_6.sendCdmaSmsExpectMore() for the response returned. |
| */ |
| TEST_P(RadioHidlTest_v1_6, sendCdmaSmsExpectMore_1_6) { |
| serial = GetRandomSerialNumber(); |
| |
| // Create a CdmaSmsAddress |
| CdmaSmsAddress cdmaSmsAddress; |
| cdmaSmsAddress.digitMode = CdmaSmsDigitMode::FOUR_BIT; |
| cdmaSmsAddress.numberMode = CdmaSmsNumberMode::NOT_DATA_NETWORK; |
| cdmaSmsAddress.numberType = CdmaSmsNumberType::UNKNOWN; |
| cdmaSmsAddress.numberPlan = CdmaSmsNumberPlan::UNKNOWN; |
| cdmaSmsAddress.digits = (std::vector<uint8_t>){11, 1, 6, 5, 10, 7, 7, 2, 10, 3, 10, 3}; |
| |
| // Create a CdmaSmsSubAddress |
| CdmaSmsSubaddress cdmaSmsSubaddress; |
| cdmaSmsSubaddress.subaddressType = CdmaSmsSubaddressType::NSAP; |
| cdmaSmsSubaddress.odd = false; |
| cdmaSmsSubaddress.digits = (std::vector<uint8_t>){}; |
| |
| // Create a CdmaSmsMessage |
| android::hardware::radio::V1_0::CdmaSmsMessage cdmaSmsMessage; |
| cdmaSmsMessage.teleserviceId = 4098; |
| cdmaSmsMessage.isServicePresent = false; |
| cdmaSmsMessage.serviceCategory = 0; |
| cdmaSmsMessage.address = cdmaSmsAddress; |
| cdmaSmsMessage.subAddress = cdmaSmsSubaddress; |
| cdmaSmsMessage.bearerData = |
| (std::vector<uint8_t>){15, 0, 3, 32, 3, 16, 1, 8, 16, 53, 76, 68, 6, 51, 106, 0}; |
| |
| radio_v1_6->sendCdmaSmsExpectMore(serial, cdmaSmsMessage); |
| |
| EXPECT_EQ(std::cv_status::no_timeout, wait()); |
| EXPECT_EQ(RadioResponseType::SOLICITED, radioRsp_v1_6->rspInfo.type); |
| EXPECT_EQ(serial, radioRsp_v1_6->rspInfo.serial); |
| |
| if (cardStatus.base.base.base.cardState == CardState::ABSENT) { |
| ASSERT_TRUE(CheckAnyOfErrors( |
| radioRsp_v1_6->rspInfo.error, |
| {::android::hardware::radio::V1_6::RadioError::INVALID_ARGUMENTS, |
| ::android::hardware::radio::V1_6::RadioError::INVALID_STATE, |
| ::android::hardware::radio::V1_6::RadioError::SIM_ABSENT}, |
| CHECK_GENERAL_ERROR)); |
| } |
| } |