blob: 0896e080ca20aea189796d0ad3a33c90cf5f1aa5 [file] [log] [blame]
// Copyright 2019 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <gtest/gtest.h>
#include "src/connectivity/wlan/drivers/testing/lib/sim-env/sim-env.h"
#include "src/connectivity/wlan/drivers/testing/lib/sim-env/sim-sta-ifc.h"
// Verify that signal strengths are being properly calculated and delivered by the environment
namespace wlan::testing {
constexpr simulation::WlanTxInfo kDefaultTxInfo = {
.channel = {.primary = 9, .cbw = WLAN_CHANNEL_BANDWIDTH__20, .secondary80 = 0}};
constexpr wlan_ssid_t kDefaultSsid = {.len = 15, .ssid = "Fuchsia Fake AP"};
const common::MacAddr kDefaultBssid({0x12, 0x34, 0x56, 0x78, 0x9a, 0xbc});
void checkChannel(const wlan_channel_t& channel) {
EXPECT_EQ(channel.primary, kDefaultTxInfo.channel.primary);
EXPECT_EQ(channel.cbw, kDefaultTxInfo.channel.cbw);
EXPECT_EQ(channel.secondary80, kDefaultTxInfo.channel.secondary80);
}
void checkSsid(const wlan_ssid_t& ssid) {
EXPECT_EQ(ssid.len, kDefaultSsid.len);
EXPECT_EQ(memcmp(ssid.ssid, kDefaultSsid.ssid, WLAN_MAX_SSID_LEN), 0);
}
class SimStation : public wlan::simulation::StationIfc {
public:
SimStation() {
std::memset(mac_addr_.byte, 0, common::kMacAddrLen - 1);
mac_addr_.byte[common::kMacAddrLen - 1] = instance_count++;
}
// StationIfc methods
void Rx(const simulation::SimFrame* frame, simulation::WlanRxInfo& info) override {
checkChannel(info.channel);
switch (frame->FrameType()) {
case simulation::SimFrame::FRAME_TYPE_MGMT: {
auto mgmt_frame = static_cast<const simulation::SimManagementFrame*>(frame);
RxMgmtFrame(mgmt_frame, info);
break;
}
default:
break;
}
}
void RxMgmtFrame(const simulation::SimManagementFrame* mgmt_frame, simulation::WlanRxInfo& info) {
switch (mgmt_frame->MgmtFrameType()) {
case simulation::SimManagementFrame::FRAME_TYPE_BEACON: {
auto beacon_frame = static_cast<const simulation::SimBeaconFrame*>(mgmt_frame);
checkSsid(beacon_frame->ssid_);
EXPECT_EQ(beacon_frame->bssid_, kDefaultBssid);
signal_received = true;
signal_strength = info.signal_strength;
break;
}
default:
break;
}
}
void ReceiveNotification(void* payload) override {}
static uint8_t instance_count;
common::MacAddr mac_addr_;
bool signal_received = false;
double signal_strength = 0;
};
uint8_t SimStation::instance_count = 0;
class LocationTest : public ::testing::Test {
public:
LocationTest();
~LocationTest();
simulation::Environment env_;
std::array<SimStation, 3> stations_{};
};
LocationTest::LocationTest() {
for (auto sta = stations_.begin(); sta != stations_.end(); sta++) {
env_.AddStation(sta);
}
}
LocationTest::~LocationTest() {
for (auto sta = stations_.begin(); sta != stations_.end(); sta++) {
env_.RemoveStation(sta);
}
}
// Initially, station 0 is closest to station 1.
// After the second move, station 0 is closer to station 2 than station 1.
TEST_F(LocationTest, BasicSignalStrengthTest) {
env_.MoveStation(&stations_[0], 0, 0);
env_.MoveStation(&stations_[1], 0, 10);
env_.MoveStation(&stations_[2], 20, 0);
simulation::SimBeaconFrame beacon_frame(kDefaultSsid, kDefaultBssid);
env_.Tx(&beacon_frame, kDefaultTxInfo, &stations_[0]);
EXPECT_LT(stations_[1].signal_strength, 0);
EXPECT_LT(stations_[2].signal_strength, 0);
EXPECT_LT(stations_[2].signal_strength, stations_[1].signal_strength);
env_.MoveStation(&stations_[0], 15, 0);
env_.Tx(&beacon_frame, kDefaultTxInfo, &stations_[0]);
EXPECT_LT(stations_[1].signal_strength, 0);
EXPECT_LT(stations_[2].signal_strength, 0);
EXPECT_LT(stations_[1].signal_strength, stations_[2].signal_strength);
}
} // namespace wlan::testing