news 2026/3/27 14:16:27

Pelco KBD300A 模拟器:19.pytest集成测试(serial + protocol + macro)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Pelco KBD300A 模拟器:19.pytest集成测试(serial + protocol + macro)

第 19 篇:集成测试(serial + protocol + macro)

现在是时候从单元测试逐步过渡到集成测试阶段了。

我们已经完成了核心纯逻辑模块(协议构建/解析、宏语法、模板渲染、日志发射、规则引擎、模拟器状态机等)的单元测试,覆盖率已经相当不错。接下来需要验证这些模块组合在一起时是否能正确协作,尤其是涉及串口 → 协议解析 → 命令分发 → 宏执行 → 协议构建 → 串口输出的完整链路。

以下是针对这个项目的集成测试规划建议(重点放在 serial + protocol + macro 链路),以及逐步实施路线。

集成测试目标(优先级排序)
优先级测试目标涉及模块链路建议测试类型难度
★★★★★1. 串口收发 → 协议解析 → 虚拟设备状态变化serial.worker + protocol + virtual_device模拟器集成
★★★★☆2. 宏命令 → 协议构建 → 串口发送macro.commands + protocol + serial.manager/workerMock串口发送
★★★★☆3. 完整宏脚本执行(包含循环/条件/延时)macro.engine + parser + commands + protocol模拟器 + Mock
★★★☆☆4. 报警规则触发 → 执行宏/动作alarm.rules + macro.engine + commands模拟器触发
★★★☆☆5. 键盘面板 → 宏/PTZ命令 → 协议 → 发送ui.keyboard.panel + serial + protocolUI + Mock串口
★★☆☆☆6. 真实串口收发(可选,后期)全链路 + 真实设备或两台电脑互连端到端很高
推荐的集成测试技术栈与工具
目的推荐工具/方式理由 / 优点
模拟串口pytest-mock+unittest.mockpyfake-serial无需真实硬件,最快、最干净、可控
协议层 Mock直接 mockserial.Serial.write/read验证协议构建与解析是否匹配
虚拟设备注入使用已有的VirtualDevice天然适合作为“下游”被测对象
宏执行环境 MockmockMacroCommands的硬件方法(如ptz_control隔离真实串口,专注宏逻辑
测试异步/线程pytest-asynciopytest-qt+QTimer处理SerialWorker的定时读取、宏引擎的QThread
UI 集成测试(可选后期)pytest-qt+qtbot可模拟按钮点击、摇杆拖动等,但前期可先跳过
逐步实施路线(大概 4~6 周完成核心部分)
第 1 周:搭建集成测试基础框架 + 模拟器闭环测试

目标:验证串口收到数据 → 解析 → VirtualDevice 状态变化 → 返回响应的完整链路

# tests/integration/test_simulator_loop.pyimportpytestfromunittest.mockimportMagicMock,patchfromcore.serial.workerimportSerialWorkerfromcore.simulator.virtual_deviceimportVirtualDevicefromcore.protocolimportget_protocol@pytest.fixturedefvirtual_device():returnVirtualDevice(cam_id=1)@pytest.fixturedefmock_serial():withpatch("serial.Serial")asmock_ser:mock_ser_instance=mock_ser.return_value mock_ser_instance.is_open=Truemock_ser_instance.read.side_effect=lambdasize:b""# 默认空yieldmock_ser_instancedeftest_receive_ptz_command_updates_virtual_device(qtbot,mock_serial,virtual_device):# 准备 Pelco-D 绝对移动命令(示例)cmd=bytes([0xFF,0x01,0x00,0x04,0x20,0x20,0x45])# pan 32, tilt 32# 模拟收到数据worker=SerialWorker(port="COM3",baud=9600,protocol="D")worker._ser=mock_serial worker._buffer=bytearray(cmd)# 注入虚拟设备处理逻辑(实际项目中可通过 dependency injection)protocol=get_protocol(worker,"D")protocol._virtual_device=virtual_device# 假设支持注入# 触发一次读取处理worker._process_buffer()status=virtual_device.get_status_dict()assert"pan"instatusassertabs(float(status["pan"][:-1])-32.0*some_scale_factor)<1.0# 根据实际比例断言
第 2~3 周:宏命令 → 协议构建 → 串口发送 集成

目标:运行简单宏 → 验证是否正确调用serial_mgr.write()并发出正确协议字节

# tests/integration/test_macro_to_serial.pyfromcore.macro.engineimportMacroEnginefromcore.macro.commandsimportMacroCommandsfromunittest.mockimportMagicMock@pytest.fixturedefmock_serial_manager():mgr=MagicMock()mgr.write=MagicMock()mgr.protocol="D"returnmgrdeftest_macro_ptz_move_generates_correct_packet(mock_serial_manager):engine=MacroEngine(mock_serial_manager)commands=MacroCommands(mock_serial_manager)script=""" ptz(1, 50, 30) # 摄像机1,pan 50, tilt 30 delay(100) stop_ptz(1) """engine.set_script(script)engine.run()# 验证是否调用了 write 两次(move + stop)assertmock_serial_manager.write.call_count>=2# 进一步断言发出的字节(Pelco-D 格式)first_call=mock_serial_manager.write.call_args_list[0]packet=first_call[0][0]assertpacket.startswith(b'\xFF')assertlen(packet)==7# ... 校验 checksum、cmd1/cmd2 等
第 4 周:完整宏脚本 + 虚拟设备闭环

目标:运行带循环/延时的宏脚本,验证虚拟设备状态最终是否符合预期

deftest_pattern_run_macro_updates_virtual_state():# 准备带 pattern_run 的脚本script=""" pattern_run(1, 2) delay(5000) pattern_stop(1, 2) """device=VirtualDevice(1)engine=MacroEngine(mock_serial_manager_with_virtual_device)# 注入虚拟设备engine.commands._virtual_device=device engine.set_script(script)engine.run()# 等待宏执行完成(可使用 qtbot.wait + 信号)# 断言 device.pattern_running == False 等状态
第 5 周:报警规则 + 宏联动集成
# tests/integration/test_alarm_macro_linkage.pydeftest_alarm_triggers_macro():rules=load_alarm_rules()# 模拟收到报警码 1002execute_alarm_action(app_window_mock,1002,rules)# 验证是否调用了 MacroEngine.run("emergency_shutdown.macro")
总结建议
  1. 优先级最高:先把模拟器闭环(收 → 解析 → 虚拟设备状态 → 响应)做通,这是最有价值的集成验证点。
  2. 第二优先:宏 → 协议构建 → Mock 串口发送(验证协议正确性)。
  3. 第三阶段:完整宏脚本 + 虚拟设备状态断言(最接近真实使用场景)。
  4. 工具推荐pytest+pytest-mock+pytest-qt(如果涉及 UI) +pytest-timeout(防止死循环)。
  5. 测试数据:准备一套标准化的 Pelco-D/P 命令字节样本(至少 20~30 种常见命令)作为 fixture。

👉上一篇 :按依赖顺序 + 复杂度由低到高逐步推进pytest单元测试

👉总目录:Python开发软键盘全程总览

👉下一篇:搭建pytest集成测试基础框架 + 模拟器闭环测试

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/13 7:14:58

全网热议!2026年签到二维码推荐榜单,助你提升考勤管理效率

在2026年&#xff0c;签到二维码正成为提升考勤管理效率的重要工具。这类二维码不仅便捷&#xff0c;还可以实现快速记录出席信息。通过简单的扫码操作&#xff0c;无论是在学校课堂还是企业会议&#xff0c;参与者都能轻松签到。使用这些二维码&#xff0c;可以避免手动填写带…

作者头像 李华
网站建设 2026/3/23 17:33:42

Wi-Fi 7 走向轻量化应用:智能家居与物联网迎来真正的“可落地时代”

长期以来&#xff0c;Wi-Fi 技术的演进往往围绕高吞吐、高带宽展开&#xff0c;服务对象主要集中在手机、PC、路由器等高性能终端。然而&#xff0c;随着智能家居与物联网设备数量持续增长&#xff0c;这一路径正逐渐暴露出局限性——大量低功耗、小体积设备&#xff0c;并不需…

作者头像 李华
网站建设 2026/3/27 3:52:11

下拉菜单操作流程测试:全面指南

在Web应用开发中&#xff0c;下拉菜单&#xff08;Dropdown Menu&#xff09;是常见的交互元素&#xff0c;用于简化用户选择&#xff08;如筛选选项或导航&#xff09;。作为软件测试从业者&#xff0c;确保其功能正确性至关重要。本文提供一套标准化的测试流程&#xff0c;涵…

作者头像 李华