如何描述BUG
一、如何描述BUG
1.1 版本信息
1.1.1 必填项
精确到构建版本号(如v2.3.1_build20240615)
- 获取方式:
- 代码版本控制系统(Git提交哈希值)
- 应用内版本信息(App的About页面)
- 持续集成工具生成的版本标识(Jenkins Build ID)
1.1.2 示例模板
[版本信息]
前端版本:OMS-Web v2.3.1(Git提交号:a1b2c3d)
后端服务:order-service v1.4.2
数据库版本:MySQL 8.0.32
发现时间:2024-06-15 14:30
1.2 环境信息
1.2.1 标准环境矩阵
环境类型 | 记录要素 | 工具推荐 |
---|---|---|
硬件环境 | 机型/CPU/内存/存储空间 | CPU-Z/AIDA64 |
软件环境 | OS版本/运行时环境/JDK版本 | systeminfo 命令 |
网络环境 | IP地址/网络类型/代理配置 | Wireshark/Fiddler |
中间件 | 数据库版本/中间件配置 | SELECT version(); |
特定配置 | 实验性功能开关/Feature Flag | 配置中心截图 |
1.2.2 示例模板
[测试环境]
- 操作系统:Windows 11 Pro 22H2
- 浏览器:Chrome 115.0.5790.110(内核版本537.36)
- 网络环境:公司内网(IP:192.168.1.100,网关:192.168.1.1)
- 屏幕分辨率:1920×1080
- 登录账号:test_export / Export@1234
1.3 复现步骤
1.3.1 编写原则(SMART准则)
- Specific:每个步骤独立编号
- Measurable:包含必要的数据参数
- Action-oriented:使用主动语态
- Repeatable:可被任何人复现
- Time-bound:注明特定时间条件
1.3.2 示例模板
[复现步骤]
1.访问订单管理系统:https://oms.example.com
2.输入账号密码登录进入后台
3.导航至【订单管理】→【高级筛选】
4.设置筛选条件:
时间范围:2024-06-01 至 2024-06-15
订单状态:已支付
5.点击右上角【导出Excel】按钮
6.查看下载文件(重复操作3次)
1.4 预期结果
1.4.1 描述标准
- 引用需求文档章节(如:SRS 3.2.1节)
- 用户视角的正常表现
- 符合业务逻辑的量化指标
1.4.2 示例模板
[期望输出]
根据需求文档《OMS系统需求规格说明书v3.2》第15页规定:
- 应导出符合筛选条件的所有订单数据(当前应导出32条记录)
- 文件格式为标准的Excel 2019兼容格式(.xlsx)
- 文件命名规则:订单导出_YYYYMMDDHHmmss.xlsx
1.5 实际结果
1.5.1 证据收集规范
问题类型 | 收集内容 | 工具推荐 |
---|---|---|
UI问题 | 标注缺陷的截图/屏幕录像 | Snipaste/ScreenToGif |
接口异常 | Postman响应截图+日志片段 | Charles/Postman |
崩溃问题 | 完整堆栈日志+设备日志 | Android Studio Logcat |
性能问题 | 性能分析报告+资源监控截图 | JProfiler/Chrome DevTool |
1.5.2 示例模板
[实际输出]
1. 导出的Excel文件仅有表头无数据(空文件)
2. 控制台报错:TypeError: Cannot read properties of null (reading 'map')at ExportService.generateExcel (export.js:45)
3. 服务器返回500错误:POST /api/orders/export → 500 Internal Server ErrorResponse Body: {"error":"Internal server error"}
4.附件证据
1.6 问题分级
1.6.1 缺陷分级标准
严重等级 | 标准说明 | 响应时效要求 | 描述 |
---|---|---|---|
P0 | 导致系统崩溃/数据丢失 | 2小时内 | Blocker(崩溃) |
P1 | 主流程阻断 | 4小时内 | Critical(严重) |
P2 | 功能异常但可绕过 | 1个工作日内 | Major(一般) |
P3 | 界面问题/体验缺陷 | 2个工作日内 | Minor(次要) |
如果出现P0级别错误,测试打回给开发,开发再修改后自己测试一下再继续交给测试人员测试
1.6.2 缺陷类型标记
[Category]
- Type: Functional Error
- Severity: P1 (High)
- Module: Order Management System
1.7 关联信息
1.7.1 必要附加信息
- 相同环境其他模块是否受影响
- 历史版本是否出现相同问题
- 是否特定数据组合触发
1.7.2 示例模板
[关联分析]
- 历史版本:v2.2.0版本相同功能正常
- 数据相关性:仅当筛选时间范围≥15天时出现
- 关联接口:/api/orders/export(可查看Swagger文档)
- 影响范围:所有使用Chrome内核的浏览器
1.8 沟通记录
1.8.1 Bug生命周期
1.8.2 示例模板
[跟踪]
- 2024-06-15 14:35 测试工程师张三提交缺陷
- 2024-06-15 15:00 开发李四确认可复现(标记为"已受理")
- 2024-06-15 17:20 发布修复版本build202406151700
- 2024-06-15 17:40 验证通过(关闭缺陷)
二、Bug报告模板(Markdown版)
## [BUG] 订单导出功能返回空文件**Version**: v2.3.1_build20240615
**Environment**:
- OS: Windows11 22H2
- Browser: Chrome 115.0.5790.110
- Network: Corporate VPN Enabled **Repro Steps**:
1. 登录后台管理系统(账号:export_test)
2. 进入【订单管理】-【高级筛选】
3. 设置筛选条件:日期范围=最近30天
4. 点击【导出Excel】按钮 **Expected**:
根据PRD 3.2节应导出包含筛选结果的Excel文件(预期数据量:152条) **Actual**:
1. 下载的Excel文件大小为0KB(空文件)
2. 控制台报错截图:[Console_Error.png]
3. 网络请求响应:500 Internal Server Error **Classification**:
- Type: Functional Error
- Severity: P1
- Module: Order/Export **Additional Info**:
- 仅当选择"最近30天"时出现
- 关联接口:/api/order/export
- 日志片段: `ERROR [2024-06-15 14:05:32] ExportService - NullPointerException at line 45`
三、优秀Bug报告的特点
- 可复现性:其他成员无需追问即可复现问题
- 完整性:包含问题定位所需的所有上下文
- 可追溯:与需求文档/用户故事建立明确关联
- 客观性:避免主观判断(如"开发人员应该…")
- 标准化:使用团队约定的模板和术语
通过这种结构化的缺陷描述,可使平均缺陷解决时间缩短40%(根据ISTQB调研数据),同时减少开发测试之间的沟通成本。
四、
相关文章:
如何描述BUG
一、如何描述BUG 1.1 版本信息 1.1.1 必填项 精确到构建版本号(如v2.3.1_build20240615) 获取方式: 代码版本控制系统(Git提交哈希值)应用内版本信息(App的About页面)持续集成工具生成的版本…...
Python进阶:如何通过组合模式实现高性能Vector类?
🔍 设计动机:为何抛弃继承选择组合? 在实现多维向量类Vector时,我们刻意采用组合模式而非继承,核心优势在于: 高扩展性:通过array数组存储分量,天然支持高维向量低耦合:…...

谷歌Veo vs Sora:AI视频生成技术的巅峰对决
🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 ——从架构到实践,解析音画同步、物理模拟与长视频生成的破局之战 一、技术架构:双雄对垒,殊途同归? 谷歌…...

基于Spring boot+vue的中医养生系统的设计与实现(源码+论文+部署+安装+调试+售后)
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,我会一一回复,希望帮助更多的人。 系统背景 在健康中国战略持续推进与全民健康意识显著提升的时代背景下,中医养生作为中…...

31.第二阶段x64游戏实战-封包-线程发包
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:30.第二阶段x64游戏实战-认识网络数据包发送流程 代码跳转 ws2_32.send跳转sen…...

Unity数字人开发笔记
开源工程地址:https://github.com/zhangliwei7758/unity-AI-Chat-Toolkit 先致敬zhangliwei7758,开放这个源码 一、建立工程 建立Unity工程(UnityAiChat)拖入Unity-AI-Chat-Toolkit.unitypackage打开chatSample工程,可…...

嵌入式开发--STM32G431无法正常运行程序,BOOT0与CAN冲突
故障现象 今天开发STM32G431时遇到一个问题,板子打样回来后,焊接完成,可以烧程序,可以读FLASH,却死活不能运行,也不能进仿真调试。 故障定位 经过排查,发现将隔离芯片π121M31拆除࿰…...
每天掌握一个Linux命令 - sqlite3
Linux 命令工具 sqlite3 使用指南 一、工具概述 sqlite3 是 SQLite 数据库的命令行工具,用于在 Linux 系统中直接操作 SQLite 数据库(轻量级、无服务器、嵌入式关系型数据库)。 核心特点: 无需安装数据库服务,直接通…...

程序环境与预处理
一、程序的翻译环境和执行环境 翻译环境:将源代码转化为可执行的机器指令 执行环境:执行代码 1、翻译环境 流程: 二、运行环境 程序执行过程: 三、预编译阶段 1、预定义符号 __FILE__ //进行编译的原文件名 __LINE__ //文…...
RT Thread Nano V4.1.1 rtconfig.h 注释 Configuration Wizard 格式
rtcomfig.h 以下是对 [rtconfig.h](file://c:\Users\admin\Downloads\rtthread-nano-master\rt-thread\bsp\stm32f407-msh\RT-Thread\rtconfig.h) 文件中每一个配置项的详细注释说明: 基本配置(Basic Configuration) [RT_THREAD_PRIORITY_MAX](file://c:\Users\admin\Downl…...

《Java 单例模式:从类加载机制到高并发设计的深度技术剖析》
【作者简介】“琢磨先生”--资深系统架构师、985高校计算机硕士,长期从事大中型软件开发和技术研究,每天分享Java硬核知识和主流工程技术,欢迎点赞收藏! 一、单例模式的核心概念与设计目标 在软件开发中,我们经常会遇…...
JSONP跨域原理全解析
JSONP(JSON with Padding)是一种绕过浏览器同源策略限制、实现跨域数据请求的“hack”式方案。其核心原理和流程如下: 同源策略限制 浏览器为了安全,只允许页面从与当前页面相同协议、域名、端口的服务器加载数据。而 <script&…...
【MySQL】第11节|MySQL 8.0 主从复制原理分析与实战(一)
一、MySQL主从复制基础 1. 核心概念 定义: MySQL主从复制是将主库(Source/Master)的数据变更同步到一个或多个从库(Replica/Slave)的机制,默认采用异步复制,支持全库、指定库或表的同步。 角…...

全志F1c200开发笔记——移植根文件系统
1.下载buildroot Index of /downloads/ 使用2018.02.11版本 直链下载 https://buildroot.org/downloads/buildroot-2018.02.11.tar.gz 2.配置 进入buildroot压缩包目录下,使用命令解压并进入工作目录 tar -xf buildroot-2018.02.11.tar.gz cd buildroot-2018.…...

[yolov11改进系列]基于yolov11引入自注意力与卷积混合模块ACmix提高FPS+检测效率python源码+训练源码
[ACmix的框架原理] 1.1 ACMix的基本原理 ACmix是一种混合模型,结合了自注意力机制和卷积运算的优势。它的核心思想是,传统卷积操作和自注意力模块的大部分计算都可以通过1x1的卷积来实现。ACmix首先使用1x1卷积对输入特征图进行投影,生成一组…...

Java NIO编程:构建高性能网络应用
1.Java NIO 核心概念与架构 1. 传统 BIO 与 NIO 的对比 特性 BIO (Blocking I/O) NIO (Non-blocking I/O) I/O 模型 阻塞 非阻塞 / 异步 线程模式 每个连接一个线程 单线程管理多个连接 数据处理单位 字节流 / 字符流 缓冲区 (Buffer) 核心组件 Socket, ServerSoc…...

如何实现高性能超低延迟的RTSP或RTMP播放器
随着直播行业的快速发展,RTSP和RTMP协议成为了广泛使用的流媒体传输协议,尤其是在实时视频直播领域,如何构建一个高性能超低延迟的直播播放器,已经成为了决定直播平台成功与否的关键因素之一。作为音视频直播SDK技术老兵ÿ…...
每天掌握一个Linux命令 - sar
Linux 系统监控工具 sar 使用指南 一、工具概述 sar(System Activity Reporter) 是 Linux 下功能强大的系统活动报告工具,属于 sysstat 软件包的核心组件。它通过采集系统资源(CPU、内存、磁盘、网络、进程等)的使用…...
RabbitMQ 集群与高可用方案设计(三)
五、高可用方案设计与实现 (一)负载均衡与代理 1. HAProxy 配置 HAProxy 是一款广泛应用的开源负载均衡器和代理服务器,它能够实现对 RabbitMQ 集群节点的负载均衡和健康检查,有效提高系统的可用性和性能。以下是使用 HAProxy …...
Linux的读写屏障
在 Linux 中,读写屏障(Read-Write Barriers,简称 RWB)是对内存访问顺序的一种控制机制,用来保证在多核处理器环境下,内存访问的正确顺序,避免因乱序执行导致的数据一致性问题。它是操作系统内核…...
Vue中的 VueComponent
VueComponent 组件的本质 Vue 组件是一个可复用的 Vue 实例。每个组件本质上就是通过 Vue.extend() 创建的构造函数,或者在 Vue 3 中是由函数式 API(Composition API)创建的。 // Vue 2 const MyComponent Vue.extend({template: <div…...

C语言数据结构-单向链表
头文件:link.h #ifndef __LINK_H__ #define __LINK_H__ #include <stdio.h> #include <stdlib.h> typedef int DataType; /*节点数据类型*/ typedef struct node { DataType data; //数据域 struct node *pNext; //指…...

小样本分类新突破:QPT技术详解
问题导向式提示调优(QPT) 这篇论文主要讲了一个针对小样本(数据量少)文本分类问题的新方法,叫问题导向式提示调优(QPT)。 核心思路是让预训练语言模型(比如BERT的升级版RoBERTa)在少量标注数据下,通过设计特定的“提问式模板”和“标签词扩展技术”来提升分类效果。…...

Excel常用公式全解析(1):从基础计算到高级应用
Excel常用公式全解析:从基础计算到高级应用 目录 Excel常用公式全解析:从基础计算到高级应用[toc](目录)一、基础计算类:数据运算的基石1. 求和公式(SUM)2. 平均值公式(AVERAGE)3. 最值与计数公…...
C++ STL 容器:List 深度解析与实践指南
一、List 容器概述 1.1底层结构与特性 数据结构:双向循环链表(带哨兵位头结点),每个节点包含前驱指针、后继指针和数据域。核心优势: 高效插入 / 删除:任意位置操作时间复杂度为 O (1),无需移…...
每天掌握一个Linux命令 - ab(Apache Benchmark)
Linux 命令工具 ab 使用指南 一、工具概述 ab(Apache Benchmark) 是 Apache 官方提供的开源压力测试工具,用于衡量 Web 服务器的性能。它通过模拟多并发请求,测试服务器在高负载下的响应速度、吞吐量和稳定性,常用于…...

与 PyCharm 官方沟通解决开发环境问题记录(进展:官方已推出2个新的修复版本)
主题:有关 PyCharm 中终端和环境激活问题的反馈:PY-81233 前言 目前进展: 官方已有2个修复版本推出测试。 更新方法: 使用JetBrains Toolbox App,如下图所示,从“其他版本”进入查看更新。…...
Python的分布式网络爬虫系统实现
1. 系统架构概述 一个典型的分布式网络爬虫系统通常包含以下几个核心组件: 1.主节点(Master Node): 任务调度:负责将抓取任务分配给各个工作节点。URL 管理:维护待抓取的 URL 队列和已抓取的 URL 集合&a…...
Vue快速上手(业务、技术、报错)
Vue 技术业务报错 技术 业务 Vueelement-ui,实现表格渲染缩略图,鼠标悬浮缩略图放大,点击缩略图播放视频(一) 报错 vue修改配置文件.env.development不生效 vue前端downloadFile报错:Error parsing HT…...

taro + vue3 实现小程序sse长连接实时对话
前言 taro.request是可以实现sse长连接的,但是呢其中有俩大坑,找了许多资料也没解决,后续解决办法也与后端商量改用WebSocket来实现。 代码实现 SSEManager.js: import { getAccessToken } from "../xx/xx"; import { TextDecode…...