自动化测试框架: 所见即所寻

本文探讨了软件测试中主窗体控件定位的难题,特别是如何处理重复及不可见控件的问题。通过判断控件的可见性,解决了控件定位的复杂性,为后续的测试代码编写奠定了基础。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

经过一段时期的框架准备和测试方案编写,实际的冒烟测试已经开始进行。目前还算比较顺利。当然了,工作忙了一点,所以博客的更新速度也降低了。

在编写的过程中,发现对于独立的子窗体的处理还是比较方便和简单的。这些窗体的普遍特点就是结构简单,功能单一,所以对应的处理过程也比较方便。但是对于主窗体来讲,就非常不一样了。可以说,一个系统中的绝大多数窗体,都包含在主窗体中,那么,对于主窗体上的控件的定位问题,就没有我们刚开始设想得那么简单了。

最大的问题,在于重复的问题。我们一般通过控件的一些特征描述,来描述一个控件。但是,在主窗体中,往往拥有相同特征描述的控件不止一个。这是非常有可能存在的事实。

并且,由于很多控件的重叠特性(有些控件被覆盖住了),导致最初设想的“方位”特性,也有可能出错!这个问题困扰我们很久,不光是难以定位控件,也会让测试代码不易读和维护,且受界面影响的可能性就变得更大了。

在解决这个问题的过程中,我们考虑到作为人,来识别界面上控件的时候,并没有遇到任何障碍,其中最关键的原因,就是人已经屏蔽掉了所有不可见(包括隐藏和被覆盖的控件)的控件。这样,人在识别的过程中,就少了很多干扰,定位也越发的简单直接。

判断控件的可见性是非常简单的。但是对于真正不可见的控件的实现,遇到了很多问题,也曾经考虑过绕过去,但是最终我们还是确定,这是一个非常好的原则,必须坚持下去,它将大大改善编写测试代码的简单性和可读性。

首先遇到的是一种方式,是将控件的位置,设置在远离屏幕的位置,比如说在(-10000, -10000)到(0,0)之间,那么其区域并不在桌面上,最后也必然不可见。

最复杂的是控件的层叠。在Delphi中,针对Controls,存在一个ZOrder的概念。不同的语言有着不同的处理。Delphi中是不可以直接设置ZOrder的,但是提供了BringToFront和SendToBack两个方法来简单改变ZOrder。我们平时看到的控件层叠,都是通过这个方式来实现的。针对这种层叠方式,我们通过判断其是否被ZOrder更高的控件覆盖来判断。

通过对几种常见的可见性方式的判断,我们发现主窗体中的控件定位变得非常简单。这为我们下一步的测试代码编写提供了非常好的基础。

在这过程中,感受最深的就是,好的原则一定要坚持下去。好的设计往往不在于最初的设想,而在于过程中的坚持!

1. 用户与身体信息管理模块 用户信息管理: 注册登录:支持手机号 / 邮箱注册,密码加密存储,提供第三方快捷登录(模拟) 个人资料:记录基本信息(姓名、年龄、性别、身高、体重、职业) 健康目标:用户设置目标(如 “减重 5kg”“增肌”“维持健康”)及期望周期 身体状态跟踪: 体重记录:定期录入体重数据,生成体重变化曲线(折线图) 身体指标:记录 BMI(自动计算)、体脂率(可选)、基础代谢率(根据身高体重估算) 健康状况:用户可填写特殊情况(如糖尿病、过敏食物、素食偏好),系统据此调整推荐 2. 膳食记录与食物数据库模块 食物数据库: 基础信息:包含常见食物(如米饭、鸡蛋、牛肉)的名称、类别(主食 / 肉类 / 蔬菜等)、每份重量 营养成分:记录每 100g 食物的热量(kcal)、蛋白质、脂肪、碳水化合物、维生素、矿物质含量 数据库维护:管理员可添加新食物、更新营养数据,支持按名称 / 类别检索 膳食记录功能: 快速记录:用户选择食物、输入食用量(克 / 份),系统自动计算摄入的营养成分 餐次分类:按早餐 / 午餐 / 晚餐 / 加餐分类记录,支持上传餐食照片(可选) 批量操作:提供常见套餐模板(如 “三明治 + 牛奶”),一键添加到记录 历史记录:按日期查看过往膳食记录,支持编辑 / 删除错误记录 3. 营养分析模块 每日营养摄入分析: 核心指标计算:统计当日摄入的总热量、蛋白质 / 脂肪 / 碳水化合物占比(按每日推荐量对比) 微量营养素分析:检查维生素(如维生素 C、钙、铁)的摄入是否达标 平衡评估:生成 “营养平衡度” 评分(0-100 分),指出摄入过剩或不足的营养素 趋势分析: 周 / 月营养趋势:用折线图展示近 7 天 / 30 天的热量、三大营养素摄入变化 对比分析:将实际摄入与推荐量对比(如 “蛋白质摄入仅达到推荐量的 70%”) 目标达成率:针对健
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值