ChatGPT生成测试用例的最佳实践(四)

通常情况下还应该进行测试用例外部评审。将已完成的基于百度关键字搜索业务的功能和安全测试用例集的存放位置告知项目团队成员,需要预留出一定的时间,便于项目组研发、产品人员阅读,以免在项目团队测试用例评审会议上占用过多时间熟悉相关测试用例内容。在项目团队测试用例评审会议上,相关人员积极进行测试用例评审,提出如下几点意见。
1) 针对测试用例TC008、TC019和TC023,产品人员对搜索输入框的字符进行了明确,即无论是中文字符还是英文字符,最大输入的字符数就是100个,无论是中文字符、英文字符或者中英文字符混合,都需要前后端做校验,若前端输入超过100个字符,则自动截取前100个字符。
2) 针对测试用例TC016,产品人员对需求进行了明确,即将SQL注入的语句进行过滤处理,将其作为普通文本处理,同时后端研发人员也明确users表存在。
3) 针对测试用例TC023,产品人员对需求进行了明确,即搜索结果数没有限制。
限于篇幅,笔者只罗列几点评审意见,测试团队针对产品人员和研发人员提出的评审意见进行了相关测试用例的问题修正,形成新的基于百度关键字搜索业务的功能和安全测试用例集,如表3-2所示。
表3-2 新的基于百度关键字搜索业务的功能和安全测试用例集
|
测试编号 |
测试目标 |
前置条件 |
测试步骤 |
预期结果 |
|
TC001 |
搜索输入框合法关键字的测试 |
用户打开百度搜索页面 |
1. 在搜索输入框中输入一个有效关键字(例如:"测试") 2. 点击搜索按钮 |
显示搜索结果页面。 |
|
TC002 |
搜索输入框多个合法关键字的测试 |
用户打开百度搜索页面 |
1. 在搜索输入框中输入多个有效关键字(例如:"软件测试 方法") 2. 点击搜索按钮 |
显示搜索结果页面。 |
|
TC003 |
搜索输入框包含特殊字符的测试 |
用户打开百度搜索页面 |
1. 在搜索输入框中输入特殊字符(例如:"#$%^") 2. 点击搜索按钮 |
显示错误消息提示。 |
|
TC004 |
基本关键字搜索 - 无相关结果 |
用户已进入百度搜索页面 |
1. 在搜索框中输入一个关键字,但系统无法找到相关结果(例如:"未知关键字")。 2. 点击搜索按钮。 |
显示相应的通知给用户(例如:"未找到相关结果")。 |
|
TC005 |
基本关键字搜索 - 取消搜索 |
用户已进入百度搜索页面 |
1.在搜索框中输入一个有效关键字(例如:"测试")。 2. 在搜索操作执行前取消搜索操作。 |
搜索操作被取消,用例结束。 |
|
TC006 |
基本关键字搜索 - 多次搜索 |
用户已进入百度搜索页面 |
1.在搜索框中输入一个有效关键字(例如:"测试")。 2. 点击搜索按钮。 3. 重复步骤1和2多次。 |
搜索结果正确显示,搜索历史被保留。 |
|
TC007 |
基本关键字搜索 - 边界值测试 |
用户已进入百度搜索页面 |
1.在搜索框中输入一个极小的关键字(例如:"a")。 2. 点击搜索按钮。 |
显示与关键字相关的搜索结果页面。 |
|
TC008 |
基本关键字搜索 - 边界值测试 |
用户已进入百度搜索页面 |
1.在搜索框中输入一个极长的关键字(超出限制字符数,例如:"a" * 101)。 2. 点击搜索按钮。 |
1.搜索框自动截取前100个字符。2.显示前100个字符的搜索结果页面。 |
|
TC009 |
搜索建议显示测试 |
用户打开百度搜索页面 |
在搜索输入框中输入部分关键字(例如: "测") |
显示搜索建议列表。 |
|
TC010 |
搜索建议多个部分关键字的测试 |
用户打开百度搜索页面 |
在搜索输入框中输入多个部分关键字(例如: "软件测") |
显示搜索建议列表。 |
|
TC011 |
针对搜索结果的验证 |
用户输入合法关键字并点击搜索按钮 |
检查搜索结果页面 |
显示相关的搜索结果。 |
|
TC012 |
下一页按钮测试 |
用户输入合法关键字并点击搜索按钮 |
点击下一页按钮 |
显示下一页的搜索结果。 |
|
TC013 |
上一页按钮测试 |
用户输入合法关键字并点击搜索按钮 |
点击上一页按钮 |
显示上一页的搜索结果。 |
|
TC014 |
按相关性排序测试 |
用户输入合法关键字并点击搜索按钮 |
选择按相关性排序 |
结果按相关性排序。 |
|
TC015 |
按时间排序测试 |
用户输入合法关键字并点击搜索按钮 |
选择按时间排序 |
结果按时间排序。 |
|
TC016 |
SQL注入攻击测试 |
用户在搜索输入框中输入恶意SQL查询(例如: "'; DROP TABLE Users --") |
检查搜索结果或页面行为 |
过滤并显示普通文本。 |
|
TC017 |
XSS攻击测试 |
用户在搜索输入框中输入包含XSS脚本的关键字(例如: "<script>alert('XSS Attack')</script>") |
检查搜索结果或页面行为 |
过滤并显示普通文本。 |
|
TC018 |
搜索输入框的最小边界值测试 |
用户打开百度搜索页面 |
在搜索输入框中输入一个空格 |
显示搜索建议或搜索历史。 |
|
TC019 |
搜索输入框的最大边界值测试 |
用户打开百度搜索页面 |
在搜索输入框中输入一个长字符串,超出限制字符数(例如:101个字符、汉字或两者混合字符串) |
显示前100个字符的搜索结果页面。 |
|
TC020 |
搜索建议的最小边界值测试 |
用户打开百度搜索页面 |
在搜索输入框中输入一个字符(例如:"a") |
显示搜索建议列表。 |
|
TC021 |
搜索建议的最大边界值测试 |
用户打开百度搜索页面 |
在搜索输入框中输入多个字符,但不足以显示搜索建议(例如:"abcde") |
不显示搜索建议列表。 |
|
TC022 |
搜索结果的最小边界值测试 |
用户输入合法关键字并点击搜索按钮 |
检查搜索结果页面 |
显示相关的搜索结果。 |
|
TC023 |
搜索结果的最大边界值测试 |
用户输入合法关键字并点击搜索按钮 |
输入关键字,使得搜索结果数超过限制(例如:超过1000个结果) |
显示搜索结果页面。 |
测试用例的评审和改进是一个持续的过程,随着项目的发展、需求变更和新功能的加入,测试用例必须不断地进行更新和优化。这不仅要求测试团队具有高度的敏捷性和适应性,还需要他们对业务和技术有深入的理解。
ChatGPT生成测试用例的最佳实践(四)的更多相关文章
- nodejs 实践:express 最佳实践(四) express-session 解析
nodejs 实践:express 最佳实践(四) express-session 解析 nodejs 发展很快,从 npm 上面的包托管数量就可以看出来.不过从另一方面来看,也是反映了 nodejs ...
- Xcode 自己主动生成版本技术最佳实践
在 bloglovin ,我们使用自己主动生成版本来设置Xcode,使当前的版本为在Git活跃的分支上 的提交数. 它一直正常工作着.但我们的技术也不是一帆风顺的. 糟糕的老方法 我们使用的技术是来自 ...
- nodejs 实践:express 最佳实践系列
nodejs 实践:express 最佳实践系列 nodejs 实践:express 最佳实践(一) 项目结构 nodejs 实践:express 最佳实践(二) 中间件 nodejs 实践:expr ...
- <读书笔记>《Web前端开发最佳实践》
P77 P89 CSS Reset P94 给CSS样式定义排序 排序工具:CSScomb P97 什么是CSS的权重?权重是指选择符的优先级 P100 工具:Sass Less P101 框架 ...
- WebSocket原理与实践(四)--生成数据帧
WebSocket原理与实践(四)--生成数据帧 从服务器发往客户端的数据也是同样的数据帧,但是从服务器发送到客户端的数据帧不需要掩码的.我们自己需要去生成数据帧,解析数据帧的时候我们需要分片. 消息 ...
- Windows DHCP最佳实践(四)
这是Windows DHCP最佳实践和技巧的最终指南. 如果您有任何最佳做法或技巧,请在下面的评论中发布它们. 在本指南(四)中,我将分享以下DHCP最佳实践和技巧. 使用DHCP中继代理 防止恶意D ...
- JavaScript基础笔记(十四)最佳实践
最佳实践 一)松散耦合 1.解耦HTML/JavaScript: 1)避免html种使用js 2)避免js种创建html 2.解耦CSS/JS 操作类 3.解耦应用逻辑和事件处理 以下是要牢记的应用和 ...
- Spring Batch在大型企业中的最佳实践
在大型企业中,由于业务复杂.数据量大.数据格式不同.数据交互格式繁杂,并非所有的操作都能通过交互界面进行处理.而有一些操作需要定期读取大批量的数据,然后进行一系列的后续处理.这样的过程就是" ...
- Canvas 最佳实践(性能篇)
Canvas 想必前端同学们都不陌生,它是 HTML5 新增的「画布」元素,允许我们使用 JavaScript 来绘制图形.目前,所有的主流浏览器都支持 Canvas. Canvas 最常见的用途是渲 ...
- 《开源安全运维平台OSSIM最佳实践》
<开源安全运维平台OSSIM最佳实践> 经多年潜心研究开源技术,历时三年创作的<开源安全运维平台OSSIM最佳实践>一书即将出版.该书用80多万字记录了,作者10多年的IT行业 ...
随机推荐
- ZRAM的Swap功能和 SWAP分区有什么区别
ZRAM(压缩内存块设备)和传统的SWAP分区都是Linux系统中用来增加可用内存的方法,但它们的工作原理和实现方式有很大的区别: ZRAM 压缩内存:ZRAM使用压缩算法将数据存储在内存中.这样,当 ...
- linux内核 快速分片,技术|Linux slabtop命令——显示内核片缓存信息
Linux内核需要为临时对象如任务或者设备结构和节点分配内存,缓存分配器管理着这些类型对象的缓存.现代Linux内核部署了该缓存分配器以持有缓存,称之为片.不同类型的片缓存由片分配器维护.本文集中讨论 ...
- iOS中NSBundle使用小结
bundle是一个目录,其中包含了程序会使用到的资源. 这些资源包含了如图像,声音,文本文件,属性列表,语言包,编译好的代码,nib文件(用户也会把bundle称为plug-in). 对应bundle ...
- kotlin类与对象——>扩展
1,扩展概念(OC中早期就有此功能) Kotlin 能够扩展一个类的新功能而无需继承该类或者使用像装饰者这样的设计模式.这通过叫做 扩展 的特殊声明完成.例如,你可以为一个你不能修改的.来自第三方库中 ...
- .NET无侵入式对象池解决方案
Pooling(https://github.com/inversionhourglass/Pooling),编译时对象池组件,在编译时将指定类型的new操作替换为对象池操作,简化编码过程,无需开发人 ...
- 牛客网C++选择题笔记
这是牛客网上的C/C++的选择题的错题,随做随更,有一些题还是有点意思. 当然不是所有都有总结,有明显歧义的不管,过于简单的不管(简不简单因人而异,我先阅读了C++ Primer后再开始做的练习,因此 ...
- Nuxt.js 应用中的 build:manifest 事件钩子详解
title: Nuxt.js 应用中的 build:manifest 事件钩子详解 date: 2024/10/22 updated: 2024/10/22 author: cmdragon exce ...
- Web渗透07_脚本代码注入和OS命令注入( 恐怖级别 )
1 PHP代码注入 1.1 原理成因 网站对用户的输入过滤出现问题,同时网站的脚本编写用到一些危险函数 eval(),assert().如果被攻击者发现漏洞,直接可能造成攻击者完全控制整个web甚至是 ...
- NDT论文翻译
The Normal Distributions Transform: A New Approach to Laser Scan Matching 正态分布变换:激光扫描匹配的新方法 摘要:匹配 2D ...
- 基于Material Design风格开源、免费的WinForms UI控件库
前言 今天大姚给大家分享一个基于 Google 的 Material Design 风格开源.免费的.NET WinForms UI控件库:MaterialSkin. WinForms介绍 WinFo ...