blob: 0572ac61e3160095ce51381d8eb5b3277a90ec8b [file] [log] [blame]
/*
* Copyright (C) 2022 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 <VtsHalHidlTargetCallbackBase.h>
#include <android-base/logging.h>
#undef NAN // NAN is defined in bionic/libc/include/math.h:38
#include <VtsCoreUtil.h>
#include <android/hardware/wifi/1.6/IWifi.h>
#include <android/hardware/wifi/1.6/IWifiChip.h>
#include <android/hardware/wifi/1.6/IWifiRttController.h>
#include <android/hardware/wifi/1.6/IWifiRttControllerEventCallback.h>
#include <android/hardware/wifi/1.6/IWifiStaIface.h>
#include <gtest/gtest.h>
#include <hidl/GtestPrinter.h>
#include <hidl/ServiceManagement.h>
#include "wifi_hidl_call_util.h"
#include "wifi_hidl_test_utils.h"
using ::android::sp;
using ::android::hardware::hidl_vec;
using ::android::hardware::Return;
using ::android::hardware::Void;
using ::android::hardware::wifi::V1_0::CommandId;
using ::android::hardware::wifi::V1_0::RttPeerType;
using ::android::hardware::wifi::V1_0::RttType;
using ::android::hardware::wifi::V1_0::WifiStatus;
using ::android::hardware::wifi::V1_0::WifiStatusCode;
using ::android::hardware::wifi::V1_6::IWifiChip;
using ::android::hardware::wifi::V1_6::IWifiRttController;
using ::android::hardware::wifi::V1_6::IWifiRttControllerEventCallback;
using ::android::hardware::wifi::V1_6::IWifiStaIface;
using ::android::hardware::wifi::V1_6::RttBw;
using ::android::hardware::wifi::V1_6::RttCapabilities;
using ::android::hardware::wifi::V1_6::RttConfig;
using ::android::hardware::wifi::V1_6::RttPreamble;
using ::android::hardware::wifi::V1_6::RttResponder;
using ::android::hardware::wifi::V1_6::RttResult;
using ::android::hardware::wifi::V1_6::WifiChannelInfo;
using ::android::hardware::wifi::V1_6::WifiChannelWidthInMhz;
/**
* Fixture to use for all RTT controller HIDL interface tests.
*/
class WifiRttControllerHidlTest : public ::testing::TestWithParam<std::string> {
public:
virtual void SetUp() override {
if (!::testing::deviceSupportsFeature("android.hardware.wifi.rtt"))
GTEST_SKIP() << "Skipping this test since RTT is not supported.";
// Make sure to start with a clean state
stopWifi(GetInstanceName());
wifi_rtt_controller_ = getWifiRttController();
ASSERT_NE(nullptr, wifi_rtt_controller_.get());
// Check RTT support before we run the test.
std::pair<WifiStatus, RttCapabilities> status_and_caps;
status_and_caps = HIDL_INVOKE(wifi_rtt_controller_, getCapabilities_1_6);
if (status_and_caps.first.code == WifiStatusCode::ERROR_NOT_SUPPORTED) {
GTEST_SKIP() << "Skipping this test since RTT is not supported.";
}
}
virtual void TearDown() override { stopWifi(GetInstanceName()); }
RttCapabilities getRttCapabilities() {
std::pair<WifiStatus, RttCapabilities> status_and_caps;
status_and_caps = HIDL_INVOKE(wifi_rtt_controller_, getCapabilities_1_6);
EXPECT_EQ(WifiStatusCode::SUCCESS, status_and_caps.first.code);
return status_and_caps.second;
}
// A simple test implementation of WifiRttControllerEventCallback.
class WifiRttControllerEventCallback
: public ::testing::VtsHalHidlTargetCallbackBase<WifiRttControllerHidlTest>,
public IWifiRttControllerEventCallback {
public:
WifiRttControllerEventCallback(){};
virtual ~WifiRttControllerEventCallback() = default;
Return<void> onResults(CommandId cmdId __unused,
const hidl_vec<::android::hardware::wifi::V1_0::RttResult>& results
__unused) {
return Void();
};
Return<void> onResults_1_4(
CommandId cmdId __unused,
const hidl_vec<::android::hardware::wifi::V1_4::RttResult>& results __unused) {
return Void();
};
Return<void> onResults_1_6(CommandId cmdId __unused,
const hidl_vec<RttResult>& results __unused) {
return Void();
};
};
protected:
sp<IWifiRttController> wifi_rtt_controller_;
private:
std::string GetInstanceName() { return GetParam(); }
sp<IWifiRttController> getWifiRttController() {
const std::string& instance_name = GetInstanceName();
sp<IWifiChip> wifi_chip = IWifiChip::castFrom(getWifiChip(instance_name));
EXPECT_NE(nullptr, wifi_chip.get());
sp<IWifiStaIface> wifi_sta_iface = IWifiStaIface::castFrom(getWifiStaIface(instance_name));
EXPECT_NE(nullptr, wifi_sta_iface.get());
const auto& status_and_controller =
HIDL_INVOKE(wifi_chip, createRttController_1_6, wifi_sta_iface);
EXPECT_EQ(WifiStatusCode::SUCCESS, status_and_controller.first.code);
EXPECT_NE(nullptr, status_and_controller.second.get());
return status_and_controller.second.get();
}
};
/*
* registerEventCallback_1_6
* This test case tests the registerEventCallback_1_6() API which registers
* a call back function with the hal implementation
*
* Note: it is not feasible to test the invocation of the call back function
* since event is triggered internally in the HAL implementation, and can not be
* triggered from the test case
*/
TEST_P(WifiRttControllerHidlTest, RegisterEventCallback_1_6) {
sp<WifiRttControllerEventCallback> wifiRttControllerEventCallback =
new WifiRttControllerEventCallback();
const auto& status = HIDL_INVOKE(wifi_rtt_controller_, registerEventCallback_1_6,
wifiRttControllerEventCallback);
EXPECT_EQ(WifiStatusCode::SUCCESS, status.code);
}
/*
* Request2SidedRangeMeasurement
* This test case tests the two sided ranging - 802.11mc FTM protocol.
*/
TEST_P(WifiRttControllerHidlTest, Request2SidedRangeMeasurement) {
// Get the Capabilities
RttCapabilities capabilities = getRttCapabilities();
if (!capabilities.rttFtmSupported) {
GTEST_SKIP() << "Skipping two sided RTT since driver/fw doesn't support";
}
std::vector<RttConfig> configs;
RttConfig config;
int cmdId = 55;
// Set the config with test data
for (int i = 0; i < 6; i++) {
config.addr[i] = i;
}
config.type = RttType::TWO_SIDED;
config.peer = RttPeerType::AP;
config.channel.width = WifiChannelWidthInMhz::WIDTH_80;
config.channel.centerFreq = 5180;
config.channel.centerFreq0 = 5210;
config.channel.centerFreq1 = 0;
config.bw = RttBw::BW_20MHZ;
config.preamble = RttPreamble::HT;
config.mustRequestLci = false;
config.mustRequestLcr = false;
config.burstPeriod = 0;
config.numBurst = 0;
config.numFramesPerBurst = 8;
config.numRetriesPerRttFrame = 0;
config.numRetriesPerFtmr = 0;
config.burstDuration = 9;
// Insert config in the vector
configs.push_back(config);
// Invoke the call
const auto& status = HIDL_INVOKE(wifi_rtt_controller_, rangeRequest_1_6, cmdId, configs);
EXPECT_EQ(WifiStatusCode::SUCCESS, status.code);
// sleep for 2 seconds to wait for driver/firmware to complete RTT
sleep(2);
}
/*
* rangeRequest_1_6
*/
TEST_P(WifiRttControllerHidlTest, RangeRequest_1_6) {
// Get the Capabilities
RttCapabilities capabilities = getRttCapabilities();
if (!capabilities.rttOneSidedSupported) {
GTEST_SKIP() << "Skipping one sided RTT since driver/fw doesn't support";
}
// Get the highest support preamble
int preamble = 1;
capabilities.preambleSupport >>= 1;
while (capabilities.preambleSupport != 0) {
capabilities.preambleSupport >>= 1;
preamble <<= 1;
}
std::vector<RttConfig> configs;
RttConfig config;
int cmdId = 55;
// Set the config with test data
for (int i = 0; i < 6; i++) {
config.addr[i] = i;
}
config.type = RttType::ONE_SIDED;
config.peer = RttPeerType::AP;
config.channel.width = WifiChannelWidthInMhz::WIDTH_80;
config.channel.centerFreq = 5765;
config.channel.centerFreq0 = 5775;
config.channel.centerFreq1 = 0;
config.bw = RttBw::BW_80MHZ;
config.preamble = (RttPreamble)preamble;
config.mustRequestLci = false;
config.mustRequestLcr = false;
config.burstPeriod = 0;
config.numBurst = 0;
config.numFramesPerBurst = 8;
config.numRetriesPerRttFrame = 3;
config.numRetriesPerFtmr = 3;
config.burstDuration = 9;
// Insert config in the vector
configs.push_back(config);
// Invoke the call
const auto& status = HIDL_INVOKE(wifi_rtt_controller_, rangeRequest_1_6, cmdId, configs);
EXPECT_EQ(WifiStatusCode::SUCCESS, status.code);
// sleep for 2 seconds to wait for driver/firmware to complete RTT
sleep(2);
}
/*
* getCapabilities_1_6
*/
TEST_P(WifiRttControllerHidlTest, GetCapabilities_1_6) {
std::pair<WifiStatus, RttCapabilities> status_and_caps;
// Invoke the call
status_and_caps = HIDL_INVOKE(wifi_rtt_controller_, getCapabilities_1_6);
EXPECT_EQ(WifiStatusCode::SUCCESS, status_and_caps.first.code);
}
/*
* getResponderInfo_1_6
*/
TEST_P(WifiRttControllerHidlTest, GetResponderInfo_1_6) {
// Get the capabilities
RttCapabilities capabilities = getRttCapabilities();
if (!capabilities.responderSupported) {
GTEST_SKIP() << "Skipping because responder is not supported";
}
// Invoke the call
std::pair<WifiStatus, RttResponder> status_and_info;
status_and_info = HIDL_INVOKE(wifi_rtt_controller_, getResponderInfo_1_6);
EXPECT_EQ(WifiStatusCode::SUCCESS, status_and_info.first.code);
}
/*
* enableResponder_1_6
*/
TEST_P(WifiRttControllerHidlTest, EnableResponder_1_6) {
// Get the capabilities
RttCapabilities capabilities = getRttCapabilities();
if (!capabilities.responderSupported) {
GTEST_SKIP() << "Skipping because responder is not supported";
}
std::pair<WifiStatus, RttResponder> status_and_info;
int cmdId = 55;
WifiChannelInfo channelInfo;
channelInfo.width = WifiChannelWidthInMhz::WIDTH_80;
channelInfo.centerFreq = 5660;
channelInfo.centerFreq0 = 5660;
channelInfo.centerFreq1 = 0;
// Get the responder first
status_and_info = HIDL_INVOKE(wifi_rtt_controller_, getResponderInfo_1_6);
EXPECT_EQ(WifiStatusCode::SUCCESS, status_and_info.first.code);
// Invoke the call
const auto& status = HIDL_INVOKE(wifi_rtt_controller_, enableResponder_1_6, cmdId, channelInfo,
10, status_and_info.second);
EXPECT_EQ(WifiStatusCode::SUCCESS, status.code);
}
GTEST_ALLOW_UNINSTANTIATED_PARAMETERIZED_TEST(WifiRttControllerHidlTest);
INSTANTIATE_TEST_SUITE_P(PerInstance, WifiRttControllerHidlTest,
testing::ValuesIn(android::hardware::getAllHalInstanceNames(
::android::hardware::wifi::V1_6::IWifi::descriptor)),
android::hardware::PrintInstanceNameToString);