基于mac80211_hwsim搭建WiFi模拟测试环境(下)-- 环境搭建与测试
基于mac80211_hwsim搭建WiFi模拟测试环境下-- 环境搭建与测试 | DDNotes基于mac80211_hwsim搭建WiFi模拟测试环境下– 环境搭建与测试前言上篇 《基于mac80211_hwsim搭建WiFi模拟测试环境上– 前篇介绍》(https://notes.z-dd.online/2026/04/09/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5https://notes.z-dd.online/2026/04/20/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8B%EF%BC%89--%20%E7%8E%AF%E5%A2%83%E6%90%AD%E5%BB%BA%E4%B8%8E%E6%B5%8B%E8%AF%95/基于mac80211_hwsim搭建WiFi模拟测试环境下– 环境搭建与测试前言上篇 《基于mac80211_hwsim搭建WiFi模拟测试环境上– 前篇介绍》(https://notes.z-dd.online/2026/04/09/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8A%EF%BC%89–%20%E5%89%8D%E7%AF%87%E4%BB%8B%E7%BB%8D/) 主要对其有些概念做了些简单介绍这篇主要讲讲整个测试环境搭建及进行简单测试。准备测试框架获取项目源码BASHgit clone https://git.w1.fi/hostap.git安装必要的依赖包BASHsudo apt-get install -y build-essential git libpcap-dev libsqlite3-dev binutils-dev libnl-3-dev libnl-genl-3-dev libnl-route-3-dev libssl-dev libiberty-dev libdbus-1-dev iw bridge-utils python-crypto tshark其他的报错时按需安装就行。编译测试组件进入tests/hwsim目录可以每个组件单独编译如下BASHcd ../../wpa_supplicantcp ../tests/hwsim/example-wpa_supplicant.config .configmake cleanmakecd ../hostapdcp ../tests/hwsim/example-hostapd.config .configmake cleanmake hostapd hostapd_cli hlr_auc_gwcd ../wlantestmake cleanmake也可以使用目录下现成的编译脚本./build.shwpaspyPython 脚本使用 wpaspy.py 来与 wpa_supplicant 控制接口进行交互但 run-tests.py 测试脚本会将该相对路径添加到环境中因此无需安装 wpaspy.py准备内核主要是启用mac80211_hwsim检查配置CONFIG_MAC80211_HWSIMm其他相关配置配置用户免密:测试过程中的某些部分需要 root 权限。目前测试脚本通过 sudo 来获取这一权限。为了能够运行测试你可能需要配置 sudo 并设置超时时间避免密码验证很快过期。直接允许所有用户免密:BASHsudo visudo#在文件中添加以下行#允许所有用户免密执行所有命令ALL ALL(ALL) NOPASSWD: ALL#或者如果你只想允许特定用户例如 testuser免密可以添加#testuser ALL(ALL) NOPASSWD: ALL运行测试运行完整测试用例集的最简单方法是执行 tests/hwsim 目录下的 run-all.sh 脚本。该脚本会调用 start.sh 来加载 mac80211_hwsim 内核模块并启动 wpa_supplicant、hostapd 以及多种测试工具。随后使用 run-tests.sh 执行所有已定义的测试用例最后通过 stop.sh 停止相关程序并卸载内核模块。run-all.sh 还支持在不同条件下运行同一套测试用例BASH# run normal test cases./run-all.sh# run normal test cases under valgrind./run-all.sh valgrind# run normal test cases with Linux tracing./run-all.sh trace# run normal test cases with multi channel support (see details below)./run-all.sh channelsnum of channels对于手动测试可以使用 ./start.sh 来初始化接口和程序并使用 run-tests.py 来执行一个或多个测试用例。通过命令行参数 -d输出更详细的调试信息和 -q输出更简洁的信息可以控制 run-tests.py 的输出详细程度。使用 -f 模块名指向 test_模块名.py 文件可以指定运行某个文件中的所有测试用例。在命令行最后加上测试名称可以指定运行单个测试用例例如./run-tests.py ap_pmf_required。需要注意的是部分测试要求驱动程序支持多信道并发操作才能运行。如果驱动程序不支持多信道这些测试将被跳过。要启用多信道支持需要通过参数将支持的信道数量传递给 run-all.sh 或 start.sh。测试结果及日志作者: Shell链接: https://notes.z-dd.online/2026/04/20/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8B%EF%BC%89--%20%E7%8E%AF%E5%A2%83%E6%90%AD%E5%BB%BA%E4%B8%8E%E6%B5%8B%E8%AF%95/来源: DDNotes著作权归作者所有。商业转载请联系作者获得授权非商业转载请注明出处。。。。 。。。更多请关注我的博客https://notes.z-dd.online/或我的