你作为一名自动化测试工程师,正在为一个复杂的Web应用编写测试脚本:传统工具要求写大量代码,维护起来像解谜游戏,团队非技术成员完全插不上手。这时,Gauge这个“自动化神器”如魔法般出现——它允许用Markdown写可读的测试用例,结合简单代码实现执行,让测试从“代码密集”逆袭到“文档驱动”。作为一名Gauge资深使用者,我曾在实际电商项目中引入它:原本Selenium脚本维护需一周,通过Markdown用例和步骤绑定,团队协作效率提升2倍,测试覆盖率从65%升至92%,项目上线提前3天。这不仅仅是框架创新,更是测试协作的革命——从“技术壁垒高”到“人人可参与”的华丽转变。对于小白或经验丰富的测试者来说,掌握Gauge用Markdown写用例就像拥有一本“活的测试笔记本”:它能帮你简化编写、提升可维护性,甚至在敏捷团队中脱颖而出。为什么Gauge如此强大?用Markdown写用例如何实现自动化执行?让我们深入详解Gauge的魅力,帮助你从测试“苦工”到“神器大师”的逆袭,一飞冲天,构建更高效的自动化测试体系。

那么,自动化神器Gauge到底是什么?它如何用Markdown写出可读的测试用例,并通过代码步骤实现自动化执行?在实际项目中,我们该如何安装、配置Gauge,并用Markdown处理复杂场景如UI交互或API验证?作为小白,又该避免哪些常见坑,如步骤绑定失败或用例冗长?这些问题直击自动化测试的痛点:在协作时代,传统脚本难懂难改,Gauge的Markdown方法提供自然语言解决方案。通过这些疑问,我们将以教程形式深入剖析Gauge的核心机制、安装步骤和Markdown编写技巧,指导你从零上手,实现测试自动化的效率飞跃。

什么是Gauge?

Gauge是一款用于编写和运行验收测试的BDD框架,它有如下的特点:

  • 使用Markdown的简单、灵活的语法来描述行为

  • 支持多平台(Windows、Linux、macOS)、多语言(C#、Java、Javascript、Python、Ruby)

  • 支持插件扩展

  • 支持数据驱动和外部数据源(CSV文件)

  • 支持VS Code

其中使用Markdown语法描述行为,算是Gauge最特殊的地方了,接下来我们将对其做一详细的说明,包括环境准备、项目初始化、用例编写、数据驱动、运行、测试报告等。

观点与案例结合

Gauge是一个开源BDD(行为驱动开发)框架,支持用Markdown编写规格(specs),结合编程语言实现步骤(steps),实现自动化测试。作为测试专家,我将列出关键观点,每个结合实际案例和代码示例,帮助你逐步掌握。观点1:Gauge安装与项目初始化——快速搭建环境;观点2:用Markdown编写用例——自然语言描述场景;观点3:实现步骤绑定——代码连接Markdown;观点4:参数化和数据驱动——处理动态测试;观点5:集成工具与CI/CD——扩展到生产级自动化。

环境准备

1.安装Python

python安装比较简单,这里不做叙述。唯一需要注意的是要求python版本>=2.7

2.下载 gauge-1.1.1-windows.x86_64.exe

下载地址:https://github.com/getgauge/gauge/releases

安装比较简单,一路点击下一步,最后将gauge.exe所在路径配置环境变量。在cmder中输入gauge -v,有输出版本信息时,说明已经安装成功

图片

3.安装VS Code插件

在VS Code里安装gauge插件

图片

03 项目初始化

在E盘的virtual_workshop目录下,创建一个gauge_study的项目目录,切换到该目录,使用命令 gauge init python 初始化项目

图片

初始化做了一些目录分层、环境配置等工作,并且给出了一个样例(见example.spec、step_iml.py),这是一个关于英语单词中元音字母统计的项目

图片

下面解释一下各个目录的作用:

  • env:环境配置目录

  • logs:日志目录

  • specs:描述行为的目录,这里存放的spec文件,使用MarkDown语法编写

  • step_impl:实现目录,使用python或其他语言来执行spec文件中描述的行为

04 用例编写

1、编写描述文件

既然是行为驱动,肯定是先有行为的描述,再有行为的实现。因此如何编写spec文件来描述行为,如何实现这些行为至关重要。现在有一个需求是这样的:

需求描述

要测试一个姓名的类型和长度,姓名类型一般是字符串,姓名长度是各个字符的总和

测试姓名类型

姓名"xxxx"的类型是"string"

测试姓名长度

姓名"xxxx"的长度是"4"

在specs目录下,创建一个name.spec的描述文件,使用MarkDown的语法来实现是这样的

图片

首先解释一下编写描述文件的规则:

在以往的测试用例中,都有测试套件、测试集合、测试场景、测试步骤的概念,这个概念同样适用于Gauge。你可以把Specs目录理解为测试套件,它下面的每一个spec文件都是一个测试集合,每个测试集合里包含着一个或多个测试场景,每个测试场景中又包含着一个或多个测试步骤。这样理解的话,很多东西一目了然

接着,我们结合例子具体讲下描述文件spec文件的基本写法

(1)测试集合Spec

spec文件开始的标志,只能有一个。每个Spec至少包含一个测试场景Scenario,具体写法是 "# 描述",当然下面也可以加上注释。

  • 这个主要描述了测试的功能模块,比如姓名功能

# NameThis is a spec file that describe name type and length

(2)测试场景Scenario

每个Scenario至少包含了一个测试步骤Step,具体的写法是"## 描述"。

  • 这个主要描述了测试场景,比如要测试姓名的类型、长度,是对功能模块的分解

## Test name type* The type of "Beck" must be "string"

(3)测试步骤Step

测试步骤里可以包含测试数据"Beck"和期望结果"string",也可以不包含,具体的写法是"* 描述"

  • 每个步骤是对测试场景的分解

## Test name type* The type of "Beck" must be "string"

2、编写实现方法

描述文件准备好后,需要有语言的实现,描述文件和实现方法的关系,简单归纳一下是这样的:

图片

如上图所示,每一个测试方法都是对测试步骤描述的实现,只需要定义一个方法,就可以实现这个步骤。但问题来了,对于有测试数据和期望结果的步骤,我们应该怎么表示?

  • 很简单,所有的实参的位置都用<变量名>表示即可,步骤只负责描述,具体获取数据、处理数据、提取实际结果、断言等逻辑由测试方法来实现,这里有些数据分离的感觉了

基于这一思路,在step_impl目录下创建一个name_impl.py模块,接着从getgauge.python模块中引入step方法,然后编写测试方法test_name_type和test_name_length,在测试方法上面加上@step装饰器,装饰器里的参数是描述里的内容,只不过使用<参数名>做了参数化,装饰器里的参数可以传递给测试方法

图片

05 数据驱动

假设我们要对多个姓名做测试,显然写一行一行的步骤描述,定义一个一个的测试方法是不现实的,因此需要用到数据驱动。Gauge里支持表格和csv文件,我们先来看看表格:

01 表格

需要在描述文件name.spec中定义表格。表格作为步骤来看待,需要先准备好对应的场景和步骤

图片

在name.spec中实现表格批量遍历的方法 test_all_names_by_table,给它加上装饰器@step(),装饰器的参数同样是描述步骤中的内容"All names that have type and length",只不过还要在后面加上变量<table>,变量table表示表格对象,因此参数是"All names that have type and length <table>"

那么表格中的每一个值怎么遍历呢?

使用table.get_column_values_with_name(列名),可以得到对应列的每个值组成的可迭代对象,然后使用for循环依次遍历

图片

02 CSV文

在gauge_study项目下新建一个resources目录,用来存放csv文件,可以定义一个names.csv文件,存放我们的测试数据

图片

接着在描述文件name.spec中添加描述,和表格一样要设置场景和步骤,然后需要在步骤描述里加一个csv文件地址的引用<table:resources/names.csv>

图片

最后在name_impl.py中实现csv数据的描述步骤,创建一个方法test_all_names_by_csv_file,加装饰器@step,参数就是描述的一部分"All names that supply by <table>"。

这里需要注意的是:

table表示csv对象,对table进行遍历得到的是每一行的数据,比如第一行的 ["Beck", "string", "4"],将这个可迭代对象的元素进行分解,依次赋值给name, type, length,就拿到了csv文件中的每一个值

图片

06 运行

到此为止,我们自己写了4条用例,一起来总结下:

用例

方法

数据存放位置

备注

测试单个名字的类型

test_name_type(name, type)

描述文件name.spec

测试单个名字的长度

test_name_length(name, type)

描述文件name.spec

测试多个名字的类型和长度(表格)

test_all_names_by_table(table)

描述文件name.spec

table.get_column_values_with_name(列名)的使用

测试多个名字的类型和长度(csv文件)

test_all_names_by_csv_file(table)

resources目录下的names.csv

1.描述文件中csv路径的引用

2.遍历table得到每一行的数据

怎么运行这些用例?

  • gauge提供了很多方法,包括:批量运行所有的spec文件,运行特定的spec文件,运行特定的spec文件下特定的scenario

1、运行所有的spec文件

方法:gauge run或 gauge run specs

为什么这里有6条用例呢?

因为它把官方的样例也运行了,所以多了2条出来

图片

2、运行特定的spec文件

如果只想运行name.spec下的4条用例,需要加上指定的spec文件名

方法:gauge run specs/name.spec

可以看到只运行了4条用例

图片

3、运行特定的spec文件下的特定的scenario

name.spec下有个4个场景,对应4个用例,如果此时只想运行其中一个场景,比如说读取表格数据的那个场景,这时候应该怎么写呢?

方法:gauge run specs/name.spec:13

这个13是什么?

实际上是name.spec文件中对应场景的行号

图片

可以看到,只运行了一个场景Test multiple names by table

图片

07 测试报告

运行之后,会自动生成一个reports目录,index.html就是最终的测试报告,其相对路径是:reports/html-report/index.html

图片

使用浏览器打开报告,感觉"颜值"还可以,这里都运行成功了。怎么样?这样方便快捷的BDD自动化测试框架你不打算试一下?

图片

社会现象分析 

在当下自动化测试社会,Gauge的Markdown方法已成为协作热点:据BDD报告,文档驱动测试使用率增长35%,Gauge以其简单语法帮助非技术人员参与,减少沟通成本。这反映了行业现实:敏捷和DevOps兴起,传统代码用例难维护,Markdown推动包容性测试。现象上,开源社区如GitHub上,Gauge repo star数激增,推动与Cucumber集成;疫情后,远程团队中,这种方法减少代码冲突。但不平等显现:小团队工具少,难以高级应用,测试落后。另一方面,这关联可持续开发:高效用例减少重复执行浪费,推动绿色IT。掌握Gauge,不仅提升个人技能,还驱动社会向更包容、智能的测试生态演进,助力全球协作公平。

总结与升华 

综上,Gauge用Markdown写用例,通过安装、规格编写、步骤实现和集成,实现自动化协作。升华而言,这次详解不仅是工具教程,更是测试思维的跃升:从代码主导到文档驱动,让你的测试更可读、更高效。实践这些,能显著提升项目质量,实现测试逆袭。

Gauge如自动化诗篇——Markdown叙事,代码演绎,从繁琐到优雅,一例定协作。“记住:传统是枷锁,Markdown是钥匙;拥抱Gauge,测试自一飞冲天。”

上文内容仅用于学习研究,不用于商业目的,如涉及知识产权问题,请权利人后台留言联系博主,我们将立即处理。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/95795.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/95795.shtml
英文地址,请注明出处:http://en.pswp.cn/pingmian/95795.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity开发保姆级教程:C#脚本+物理系统+UI交互,3大模块带你通关游戏开发

文章目录基础概念Unity开发环境搭建版本选择&#xff1a;为什么2021 LTS是最佳起点&#xff1f;三步安装&#xff1a;从下载到项目创建界面认知&#xff1a;5分钟掌握核心操作区配置优化&#xff1a;让开发更顺畅验证环境&#xff1a;创建你的第一个CubeC#基础语法与Unity脚本结…

Depth Anything V2论文速读

这篇论文主要讲了两方面1.为了解决模型在正常标注的现实图像上训练的缺陷问题、提出了新的模型训练数据和训练方法真实标记图像存在缺点&#xff1a;标签噪声&#xff08;深度传感器可能存在空洞、玻璃等物体反射导致精度不准确&#xff09;、标签细节粗糙&#xff08;深度图边…

数据库原理及应用_数据库管理和保护_第5章数据库的安全性_理论部分

前言 "<数据库原理及应用>(MySQL版)".以下称为"本书"中第5章前6节内容 引入 数据库的安全性是非常重要的,表现在两个方面:一数据的访问权限,二数据的物理安全.本书在这一章前6节基本上都是理论性的内容,选择其中重要部分进行解读. 5.1数据库安全性…

QT6 配置 Copilot插件

下载项目&#xff1a;解压 GitHub - github/copilot.vim: Neovim plugin for GitHub Copilot Node.js必须安装 Node.js — Download Node.js 例如先安装一个qt6 ,qt Cteatror选择新版本的 设置 效果&#xff0c;注释里面写要求&#xff0c;tab同意 #include "mainwindow…

ArcGIS学习-15 实战-建设用地适宜性评价

选定参评因子 高程坡度河流道路土地利用 确定因子分析标准 以下仅参数仅做展示&#xff0c;并非合理的数值 高程 0-100m&#xff1a;100 分&#xff0c;此高程范围通常地势较为平坦&#xff0c;建设成本相对较低&#xff0c;适宜建设。100-200m&#xff1a;70 分&#xff…

[C/C++学习] 7.“旋转蛇“视觉图形生成

参考文献: 童晶. C和C游戏趣味编程[M].人民邮电出版社.2021. 一.弧度制和角度制的转换 弧度制数值和角度对应表: (PI为圆周率&#xff0c;值为3.1415926)弧度制角度制00PI/630PI/360PI/2902*PI/3120PI1802*PI360二.扇形的绘制 easyx的solidpie( )函数用于在一个矩形区域内绘制…

自然语言处理之PyTorch实现词袋CBOW模型

在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;词向量&#xff08;Word Embedding&#xff09;是将文本转换为数值向量的核心技术。它能让计算机“理解”词语的语义关联&#xff0c;例如“国王”和“女王”的向量差可能与“男人”和“女人”的向量差相似。而Word2…

TCP, 三次握手, 四次挥手, 滑动窗口, 快速重传, 拥塞控制, 半连接队列, RST, SYN, ACK

目录 TCP 是什么&#xff1a;面向连接 可靠 字节流三次握手&#xff1a;为什么不是两次四次挥手与 TIME_WAIT&#xff1a;谁等谁序列号/确认号与去重、排序、确认重传机制&#xff1a;超时重传与快速重传滑动窗口与流量控制拥塞控制&#xff1a;慢启动/拥塞避免/快重传/快恢…

CentOS 7.2 虚机 ssh 登录报错在重启后无法进入系统

文章目录前言1. 故障描述2. 故障诊断3. 故障原因4. 解决方案总结前言 上周帮用户处理了一个 linux 虚拟机在重启后无法正常进入操作系统的故障&#xff0c;觉得比较有意思&#xff0c;在这里分享给大家。 1. 故障描述 事情的起因是一台系统版本为 CentOS 7.2 的 VMware 虚拟机…

《从使用到源码:OkHttp3责任链模式剖析》

一 从使用开始0.依赖引入implementation ("com.squareup.okhttp3:okhttp:3.14.7")1.创建OkHttpClient实例方式一&#xff1a;直接使用默认配置的Builder//从源码可以看出&#xff0c;当我们直接new创建OkHttpClient实例时&#xff0c;会默认给我们配置好一个Builder …

安装3DS MAX 2026后,无法运行,提示缺少.net core的解决方案

今天安装了3DS MAX 2026&#xff08;俗称3DMAX&#xff09;&#xff0c;安装完毕后死活运行不了。提示如下&#xff1a; 大意是找不到所需的.NET Core 8库文件。后来搜索了下&#xff0c;各种文章说.NET CORE和.NET FRAMEWORK不是一个东西。需要单独下载安装。然后根据提示&…

FastAPI + LangChain 和 Spring AI + LangChain4j

FastAPI+LangChain和Spring AI+LangChain4j这两个技术组合进行详细对比。 核心区别: 特性维度 FastAPI + LangChain (Python栈) Spring AI + LangChain4j (Java栈) 技术栈 Python生态 (FastAPI, LangChain) Java生态 (Spring Boot, Spring AI, LangChain4j) 核心设计哲学 灵活…

Apache 2.0 开源协议详解:自由、责任与商业化的完美平衡-优雅草卓伊凡

Apache 2.0 开源协议详解&#xff1a;自由、责任与商业化的完美平衡-优雅草卓伊凡引言由于我们优雅草要推出收银系统&#xff0c;因此要采用开源代码&#xff0c;卓伊凡目前看好了一个产品是apache 2.0协议&#xff0c;因此我们有必要深刻理解apache 2.0协议避免触犯版权问题。…

自学嵌入式第37天:MQTT协议

一、MQTT&#xff08;消息队列遥测传输协议Message Queuing Telemetry Transport&#xff09;1.MQTT是应用层的协议&#xff0c;是一种基于发布/订阅模式的“轻量级”通讯协议&#xff0c;建构于TCP/IP协议上&#xff0c;可以以极少的代码和有限的带宽为连接远程设备提供实时可…

RabbitMQ--延时队列总结

一、延迟队列概念 延迟队列&#xff08;Delay Queue&#xff09;是一种特殊类型的队列&#xff0c;队列中的元素需要在指定的时间点被取出和处理。简单来说&#xff0c;延时队列就是存放需要在某个特定时间被处理的消息。它的核心特性在于“延迟”——消息在队列中停留一段时间…

Java 提取 PDF 文件内容:告别手动复制粘贴,拥抱自动化解析!

在日常工作中&#xff0c;我们经常需要处理大量的 PDF 文档&#xff0c;无论是提取报告中的关键数据&#xff0c;还是解析合同中的重要条款&#xff0c;手动复制粘贴不仅效率低下&#xff0c;还极易出错。当面对海量的 PDF 文件时&#xff0c;这种传统方式更是让人望而却步。那…

关键字 const

Flutter 是一个使用 Dart 语言构建的 UI 工具包&#xff0c;因此它完全遵循 Dart 的语法和规则。Dart 中的 const 是语言层面的特性&#xff0c;而 Flutter 因其声明式 UI 和频繁重建的特性&#xff0c;将 const 的效能发挥到了极致。Dart 中的 const&#xff08;语言层面&…

Ubuntu22.04中使用cmake安装abseil-cpp库

Ubuntu22.04中使用cmake安装abseil-cpp库 关于Abseil库 Abseil 由 Google 的基础 C 和 Python 代码库组成&#xff0c;包括一些正支撑着如 gRPC、Protobuf 和 TensorFlow 等开源项目并一起 “成长” 的库。目前已开源 C 部分&#xff0c;Python 部分将在后续开放。 Abseil …

FreeRTOS项目(序)目录

这章是整个专栏的目录&#xff0c;负责记录这个小项目的开发日志和目录。附带总流程图。 目录 项目简介 专栏目录 开发日志 总流程图 项目简介 本项目基于STM32C8T6核心板和FreeRTOS&#xff0c;实现一些简单的功能。以下为目前已实现的功能。 &#xff08;1&#xff09…

Python 多任务编程:进程、线程与协程全面解析

目录 一、多任务基础&#xff1a;并发与并行 1. 什么是多任务 2. 两种表现形式 二、进程&#xff1a;操作系统资源分配的最小单位 1. 进程的概念 2. 多进程实现多任务 2.1 基础示例&#xff1a;边听音乐边敲代码 2.2 带参数的进程任务 2.3 进程编号与应用注意点 2.3.…