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

这篇具有很好参考价值的文章主要介绍了要做自动化测试,得了解一下自动化架构是什么。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

架构是什么

软件架构(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。

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

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

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

要做自动化测试,得了解一下自动化架构是什么,自动化,架构,运维,功能测试,程序员,系统架构

在这里还是要推荐下我自己建的软件测试学习Q群:1150305204,群里都是学测试的,如果你想学或者正在学习测试,欢迎你加入,大家都是测试党,不定期分享干货(只有软件测试相关的),包括我自己整理的一份2024最新的Python自动化测试进阶资料和零基础教学,欢迎进阶中和对测试感兴趣的小伙伴加入!文章来源地址https://www.toymoban.com/news/detail-807210.html

到了这里,关于要做自动化测试,得了解一下自动化架构是什么的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 接口自动化测试要做什么?只需要会这8个步骤...

    作者的标题,是问做接口自动化测试的流程吗? 如果是,那先了解下接口测试流程: 1、需求分析 2、Api文档分析与评审 3、测试计划编写 4、用例设计与评审 5、环境搭建(工具) 6、执行用例 7、缺陷管理 8、测试报告 了解了 接口测试的工作流程 ,那\\\"接口自动化测试\\\"怎么弄

    2024年02月05日
    浏览(51)
  • 接口自动化测试要做什么?一文3个步骤带你成功学会!

    先了解下接口测试流程: 1、需求分析 2、Api文档分析与评审 3、测试计划编写 4、用例设计与评审 5、环境搭建(工具) 6、执行用例 7、缺陷管理 8、测试报告 了解了 接口测试的工作流程 ,那\\\"接口自动化测试\\\"怎么弄?只需要在上篇文章的基础上再梳理下就可以。为更好理解

    2024年02月08日
    浏览(45)
  • 接口自动化测试要做什么?8个步骤讲的明明白白(小白也能看懂系列)

    先了解下接口测试流程: 1、需求分析 2、Api文档分析与评审 3、测试计划编写 4、用例设计与评审 5、环境搭建(工具) 6、执行用例 7、缺陷管理 8、测试报告 那\\\"接口自动化测试\\\"怎么弄?只需要在上篇文章的基础上再梳理下就可以。为更好理解\\\"接口自动化\\\"具体操作流程,最

    2024年03月09日
    浏览(51)
  • 什么测试自动化测试?

    什么测试自动化测试? 做测试好几年了,真正学习和实践自动化测试一年,自我感觉这一个年中收获许多。一直想动笔写一篇文章分享自动化测试实践中的一些经验。终于决定花点时间来做这件事儿。 首先理清自动化测试的概念,广义上来讲,自动化包括一切通过工具(程

    2024年02月06日
    浏览(45)
  • 什么是自动化测试?如何开展自动化测试你需要知道这些点

    目录 前言 什么是自动化测? 分层的自动化测试 我为什么要做自动化测试? 什么项目适合做自动化测试? 选择什么工具进行自动化测试 selenium 用前须知 selenium IDE selenium Grid selenium RC selenium 2.0 selenium学习路线 结语 做测试好几年了,真正学习和实践自动化测试一年,自我感觉

    2023年04月17日
    浏览(57)
  • 通过自动化单元测试的形式守护系统架构

    目录 0前言 1 背景 2 为什么选择 Archunit 3 Archunit 是什么 4 引入 Archunit 4.1 开始就是如此简单 4.2 如何组织架构规则 4.3 团队如何规范化 通过自动化单元测试的形式守护系统架构是一种有效的方式,可以确保系统在不断演进和修改的过程中保持稳定和可靠。 自动化单元测试是指通

    2024年02月16日
    浏览(49)
  • API自动化测试是什么?我们该如何做API自动化测试呢?

     API测试已成为日常的测试任务之一,为了提高测试效率,减少重复的手工操作,API自动化测试也逐渐变得愈加重要,本文是自己在API自动化测试方面的一些经验积累和心得、汇总成文,以飨读者 我相信自动化技能已经成为高级测试工程师总体技能的标配。敏捷和持续测试破

    2024年02月01日
    浏览(43)
  • 自动化测试基础知识:什么是自动化测试?需要学习哪些知识与工具!

    1、自动化测试概念 自动化测试是把以人为驱动的测试行为转化为机器执行的一种过程。通常, 在设计了测试用例并通过评审之后,由测 试人员根据测试用例中描述的规程一步步执行测试,得到实际结果与期望结果的比较。简言之,自动化测试就是让被测试的软件自己运行起

    2024年02月04日
    浏览(63)
  • 为什么需要自动化测试

    自动化的优势: 1.自动化可以代替手工大量地重复的工作,测试可以把大量的时间放在用例设计和新功能上边 2.自动化可以大量提升回归测试效率,特别适合敏捷开发 3.自动化可以大量地利用无人值守的时间去执行用例,特别适合非工作是爱你执行测试,工作时间分析测试用

    2024年02月13日
    浏览(62)
  • 自动化测试po模式是什么

    全称:page object model  简称:POM/PO PO模式最核心的思想是分层,实现松耦合!实现脚本重复使用,实现脚本易维护性! 主要分三层: 1.基础层BasePage:封装一些最基础的selenium的原生的api方法,元素定位,框架跳转等。 2.PO层:元素定位、获得元素对象,页面动作 3.测试用例层

    2024年01月19日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包