热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

要做自动化测试,得了解一下自动化架构是什么

自动化测试架构是啥,怎么理解自动化测试架构?这个问题,我们可以从以下几点来慢慢说。软件架构(softwarearchitecture)是一系列相关的抽象模式,用于指导大型软件系统各

自动化测试架构是啥,怎么理解自动化测试架构?这个问题,我们可以从以下几点来慢慢说。

架构是什么

软件架构(software architecture)是一系列相关的抽象模式,用于指导大型软件系统各个方面的设计。

软件架构是一个系统的草图,软件架构描述的对象是直接构成系统的抽象组件,各个组件之间的连接则明确和相对细致地描述组件之间的通讯。

在实现阶段,这些抽象组件被细化为实际的组件,比如具体某个类或者对象。在面向对象领域中,组件之间的连接通常用接口来实现。

官方解释的比较模糊,可能没涉及到架构的大佬,对这部分还是有一些模糊,我直接大白话说一下:软件架构就是软件的基本结构,架构的本质是管理复杂性,由各个组件及其接口、元素构成的一些能够完成特定行为的组合。

扩展一下,架构模式虽然有很多种,但是常用的也就是这几种:

  • 分层架构

  • 事件驱动架构

  • 微核架构(又称插件架构)

  • 微服务架构

  • 云架构

关于这些架构模式的构成及思想,我们就不在这里讨论了,不然就跑题了。

架构的设计思想

高复用性

用一套框架来解决不同产品线的基础服务构建工作,通过引用框架方便公司对不同产品线的自动化实施进行整合。

易维护性

如果对框架的技术进行扩展,则只需要维护这一套框架即可,不需要根据产品线的不同,维护多套框架,节省时间、节省成本。

人员分离,专一性

业务人员只关注业务代码的脚本编写,不需要去专注框架技术上的问题。架构人员只针对框架技术的实现,不需要对业务线的具体业务知识进行学习。

架构师考虑点

1、编码的选择:Java、Python、Ruby等。

2、核心技术的选择:

  • Web:Selenium

  • APP:Appium

3、编码规范:类、方法、变量的命名方式。

4、用例设计规范。

5、代码管理方式:git or svn。

为什么要使用架构

核心:解决脚本录制的常见问题,使得自动化稳定。

同时可以把架构人员、脚本编写人员、用例执行人员分开:

  • 架构大佬:精通代码设计

  • 脚本编写大佬:了解代码

  • 用例执行大佬:可以不懂代码

把UI对象通过自定义变量的方式赋值,增强了脚本的易读性,通过封装WebDriver的API,使其更加健壮。

把常用的业务场景封装成业务方法,便于常用业务的复用,把共通的脚本单独封装,避免了脚本执行人员对测试脚本代码的修改。

生成Debug级别的log,使自动化脚本调试人员方便调试程序。

生成回归级别的测试报告,便于不懂脚本的人员查看测试结果,引用Suite执行多个脚本,进行运行脚本的管理。

类库的设计结构

Web UI 自动化测试结构

config 配置文件:把经常需要修改的信息(例如用户名、密码、环境)保留在配置文件中,以便经常调用。

common 公共方法:提供与WebDriver无关,但与自动化测试相关的API,包括:

  • 读取文件信息

  • 启动浏览器

  • 获取当前系统时间等

report:

  • 测试报告:向项目经理、产品经理和老板汇报

  • 调试日志:便于自动化脚本编写人员调试代码

objectView:保存页面中的元素,当UI变化时修改对应变量即可,将可读性差的UI元素按照统一规则命名

Corelib:封装WebDriver的API,使其更加健壮,形成自动化项目的API。提供断言的相关方法,自动化API提供详细的输出消息,便于调试,自动化API提供向测试报告中写入消息的方法。

businessView:业务方法的封装,根据Corelib中的提供的API,把常用的业务场景封装成方法便于复用。

data:保存输入的数据信息,作为架构与外部文件的接口。

Appium自动化测试结构

其实和Web UI的差不多,因为都是基于Pageobject 设计模式,这里就直接copy我之前写的框架结构就好。

APP:测试包管理:

|--------|-------如xx.apk

(左右滑动查看完整代码)

|-------baseView:一些基本类的封装:

|--------|-------find_element()|--------|--------find_elements()|--------|--------get_window_size()

(左右滑动查看完整代码)

public:公共方法的封装:​​​​​​​

|--------|----------common_fun.py|--------|-------------|--------check_cancel_Btn()|--------|-------------|--------check_ship_Btn()|--------|-------------|--------get_screenSize()|--------|----------desired_caps.py|--------|-------------|--------driver驱动封装|--------|-------------|--------日志配置文件封装|--------|-------------|--------启动APP配置参数|--------|----------myunit.py|--------|-------------|--------测试用例启动、关闭的封装

(左右滑动查看完整代码)

businessView:业务逻辑封装:​​​​​​​

|--------|----------loginView.py|--------|-------------|--------登录相关的操作和方法|--------|----------registerView.py|--------|-------------|--------注册相关操作和方法

(左右滑动查看完整代码)

config:存放配置文件:​​​​​​​

|--------|----------caps.py|--------|-------------|--------capability数据配置|--------|----------log_conf.py|--------|-------------|--------日志配置文件

(左右滑动查看完整代码)

data:存放数据驱动:​​​​​​​

|--------|----------account.csv|--------|-------------|--------用户名、密码

(左右滑动查看完整代码)

log:存放生成日志:

|--------|----------runlog.log

(左右滑动查看完整代码)

report:存放测试报告:

|--------|----------report.html

(左右滑动查看完整代码)

screenshots:存放截图。

test_case:存放测试类的模块:​​​​​​​

|--------|----------test_login.py|--------|-------------|--------登录测试类封装:LoginTest|--------|-------------|--------调用LoginView类的方法来编写用例|--------|----------test_register.py|--------|-------------|--------注册测试类封装:RegisterTest|--------|-------------|-------调用RegisterView类的方法来编写用例

(左右滑动查看完整代码)

test_run:执行测试脚本:​​​​​​​

|--------|----------run.py|--------|-------------|--------自动化测试用例执行入口|--------|-------------|--------生成测试报告

(左右滑动查看完整代码)

使用架构遇到的坑

接下来,我就简单说几个,在项目中出现的遇到的坑。

页面元素变化,那么怎么更新UI的变量呢?

只要更新objectView 即可。

框架已封装的方法,编写脚本大佬不调用,怎么办?

这是我在check脚本的时候发现的,遇到这种问题,就要及时通知、及时提醒、及时修正。这就是不怕一万就怕万一啊!

脚本执行fail,怎么确定是架构API的问题,还是程序本身的缺陷?

这个问题,我问过求职者,回答啥的都有,咱就不说了,直接说从哪里验证吧。

出现问题,无非就两点:

  • 先查看fail的原因,至于怎么查,要看log;

  • 手工验证此功能。

当前架构的API无法满足当前项目的需要,怎么扩展?

  • 直接重写架构的API或者添加API(看无法满足情况,再根据实际情况,一般添加API即可);

  • 写一个新类继承架构中的Corelib,在这个类中完善API。

注:一般情况架构师就搞定了。

当架构需要添加新功能时需要如何接入?

写一些类完成所需功能,然后提供调用接口在架构中使用。

End


学习安排上

最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走

这些资料,对于想进阶【自动化测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。 


推荐阅读
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 20211101CleverTap参与度和分析工具功能平台学习/实践
    1.应用场景主要用于学习CleverTap的使用,该平台主要用于客户保留与参与平台.为客户提供价值.这里接触到的原因,是目前公司用到该平台的服务~2.学习操作 ... [详细]
  • 如何用UE4制作2D游戏文档——计算篇
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了如何用UE4制作2D游戏文档——计算篇相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • 本文介绍了RPC框架Thrift的安装环境变量配置与第一个实例,讲解了RPC的概念以及如何解决跨语言、c++客户端、web服务端、远程调用等需求。Thrift开发方便上手快,性能和稳定性也不错,适合初学者学习和使用。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 【MicroServices】【Arduino】装修甲醛检测,ArduinoDart甲醛、PM2.5、温湿度、光照传感器等,数据记录于SD卡,Python数据显示,UI5前台,微服务后台……
    这篇文章介绍了一个基于Arduino的装修甲醛检测项目,使用了ArduinoDart甲醛、PM2.5、温湿度、光照传感器等硬件,并将数据记录于SD卡,使用Python进行数据显示,使用UI5进行前台设计,使用微服务进行后台开发。该项目还在不断更新中,有兴趣的可以关注作者的博客和GitHub。 ... [详细]
  • 本文介绍了在使用Python中的aiohttp模块模拟服务器时出现的连接失败问题,并提供了相应的解决方法。文章中详细说明了出错的代码以及相关的软件版本和环境信息,同时也提到了相关的警告信息和函数的替代方案。通过阅读本文,读者可以了解到如何解决Python连接服务器失败的问题,并对aiohttp模块有更深入的了解。 ... [详细]
  • web.py开发web 第八章 Formalchemy 服务端验证方法
    本文介绍了在web.py开发中使用Formalchemy进行服务端表单数据验证的方法。以User表单为例,详细说明了对各字段的验证要求,包括必填、长度限制、唯一性等。同时介绍了如何自定义验证方法来实现验证唯一性和两个密码是否相等的功能。该文提供了相关代码示例。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 使用eclipse创建一个Java项目的步骤
    本文介绍了使用eclipse创建一个Java项目的步骤,包括启动eclipse、选择New Project命令、在对话框中输入项目名称等。同时还介绍了Java Settings对话框中的一些选项,以及如何修改Java程序的输出目录。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • 服务网关与流量网关
    一、为什么需要服务网关1、什么是服务网关传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务,如果没有网关& ... [详细]
author-avatar
曾的曾的力
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有