您的位置:首页 >QFTest 验证 Java HMI 完全关闭方法
发布于2026-02-24 阅读(0)
扫一扫,手机访问

本文介绍在 QFTest 自动化测试中,可靠验证 Java HMI 应用是否真正终止的正确方法,包括避免通信干扰、使用内置终止节点、强制杀进程等实践策略,并指出常见误区与官方推荐方案。
本文介绍在 QFTest 自动化测试中,可靠验证 Java HMI 应用是否真正终止的正确方法,包括避免通信干扰、使用内置终止节点、强制杀进程等实践策略,并指出常见误区与官方推荐方案。
在 QFTest 中验证被测系统(SUT,即 Java HMI 应用)是否“已彻底关闭”,是一个看似简单却极易误判的关键检查点。许多用户(如问题中所述)尝试在 shutdown 阶段持续通过 rc.toSUT() 发送 socket 请求并捕获异常来推断进程死亡——这种做法存在根本性风险:QFTest 的 Java Agent 会维持与 JVM 的连接通道,即使应用逻辑已退出,Agent 仍可能保持部分存活状态,导致网络探测返回假阴性(看似连通)或假阳性(异常非因进程死亡引起)。因此,依赖运行时通信探测并非可靠依据。
✅ 正确做法应遵循“无干扰 + 显式控制”原则:
避免 shutdown 过程中任何 rc.toSUT() 调用
在应用关闭流程执行期间(例如点击“退出”按钮后),禁止调用任何与 SUT 的交互指令(如 rc.toSUT、rc.getComponent、rc.wait 等)。QFTest 的 Java Agent 会在 shutdown 时尝试优雅终止,若此时强行通信,不仅无法反映真实状态,还可能阻塞或干扰 JVM 的正常退出流程。
优先使用 QFTest 内置的终止机制
QFTest 提供了语义明确、行为可控的专用节点:
补充验证:检查进程是否存在(推荐方案)
若需 100% 确认进程已消失,可在 Terminate SUT 节点后添加自定义 Jython 步骤,不连接 SUT,而是查询操作系统级进程状态:
import subprocess
import time
# 假设你的 HMI 进程名包含 "hmi-app"(根据实际调整)
process_name = "hmi-app"
timeout = 30 # 最长等待秒数
check_interval = 1
for _ in range(timeout):
try:
# Windows 示例(使用 tasklist)
result = subprocess.run(["tasklist", "/FI", f"imagename eq {process_name}*"],
capture_output=True, text=True, check=True)
if process_name.lower() not in result.stdout.lower():
rc.setLocal("shutdownConfirmed", True)
break
except:
# Linux/macOS 示例(使用 pgrep)
# result = subprocess.run(["pgrep", "-f", process_name],
# capture_output=True, text=True)
# if result.returncode != 0:
# rc.setLocal("shutdownConfirmed", True)
# break
pass
time.sleep(check_interval)
else:
rc.setLocal("shutdownConfirmed", False) # 超时未退出⚠️ 注意事项:
? 总结:验证 shutdown 成功的核心不是“能否通信”,而是“进程是否消失”。请始终优先使用 QFTest 原生终止节点,并辅以 OS 层进程检测。如遇复杂生命周期管理(如嵌入式 JVM、自定义 shutdown hook),建议参考官方示例 startStop.terminate(位于 <qftest_install_dir>\demo\carconfig\carconfig_en.qft),或直接联系 QF-Test 官方支持团队 获取针对性诊断——此类深度集成问题,社区平台难以提供有效协助。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9