软件测试相关内容第三弹--软件测试基础

news2024/10/1 1:28:36

写在前:在前篇的两篇博客介绍中我们主要学习软件测试的相关概念,对软件测试进行了初步的了解,本篇博客将进一步进行学习。重点内容包括:软件测试的生命周期、如何描述一个bug、如何定义bug的级别、bug的生命周期以及在实际工作中如果产生争执如何办。

目录

1. 软件测试的生命周期

2. 如何描述一个BUG

2.1 发现问题的版本

2.2 问题出现的环境

2.3 错误重现步骤

2.4 预期行为的描述

2.5 错误行为的描述

2.6 其他

2.7 不要把多个bug放到一起

3. bug的级别定义

4. bug的生命周期

5. 人际关系

6. 如何开始第一次测试

6.1 充分理解需求

6.2 确定测试计划

6.3 执行测试

6.4 项目上线+维护

7. 测试的执行和BUG管理

7.1 进行测试

7.2 如何发现更多的bug


1. 软件测试的生命周期

需求分析 - 测试计划 - 测试设计 - 测试开发 - 测试执行 - 测试评估

需求分析:需求是否完整、需求是否正确。

测试计划:确定软件由谁测试、开始和结束时间、测试的模块有哪些。

测试设计:写测试用例(手工测试用例、自动化测试用例),编写测试工具。

测试执行:执行测试用例。

测试评估:测试人员产生测试报告。

2. 如何描述一个BUG

合格的bug描述主要应该包括以下几个部分。

2.1 发现问题的版本

开发人员需要知道出现问题的版本,才能获取对应版本的代码来重现故障,并且版本的标识也有利于统计和分析每个版本的质量。

2.2 问题出现的环境

环境分为硬件环境和软件环境,如果是web项目,需要描述浏览器的版本,客户机操作系统等,如果是app项目,需要描述机型、分辨率、操作系统版本等。详细的环境描述有利于故障的定位。

2.3 错误重现步骤

描述问题重现的最短步骤。

2.4 预期行为的描述

要让开发人员指导怎么样才是正确的,尤其是要以用户的角度来描述程序的行为是怎样的,如果是依据需求提出的故障,能写明需求的来源是最好的。

2.5 错误行为的描述

描述错误的现象,crash等可以上传log,UI问题可以有截图。

2.6 其他

某些公司会有一些其他的要求,例如故障的分类:功能故障,界面故障,兼容性故障等。有些有优先级的分类,严重影响测试需要开发人员优先修改的,可以设置优先级为最高。

2.7 不要把多个bug放到一起

在无法确认是同一段代码造成的故障时,不要将bug放在一起提交。

3. bug的级别定义

级别描述举例
Blocker(崩溃)阻碍开发或测试工作的问题,造成系统崩溃,死机、死循环,导致数据库丢失,与数据库连接错误,主要功能丧失,基本模块缺失等问题。代码错误、死循环、数据库发生死锁、重要的一级菜单功能不能使用等。
Critical(严重)系统主要功能部分丧失、数据库保存调用错误、用户数据丢失,一级功能菜单不能使用但是不影响其他功能的测试。功能与设计需求严重不符,模块无法启动,程序重启、自动退出、关联程序间调用冲突、安全问题、稳定性等。软件中数据保存后数据库中的显示错误,用户所要求的功能缺失,程序接口错误,数值计算统计错误等。
Major(一般)功能没有完全实现但是不影响使用,功能菜单存在缺陷但不会影响系统的我呢定性。操作时间长、拆线呢时间长、格式错误、边界条件错误、删除没有确认框、数据库表中字段过多等。
Minor(次要)界面、性能缺陷,建议类问题,不影响操作功能的执行,可以优化性能的方案等。错别字、界面格式不规范、页面显示重叠、不该显示的要隐藏、描述不清楚、提示语丢失、文字排列不整齐,光标位置不正确、用户体验感受不好,可以优化性能的方案等。

4. bug的生命周期

每个公司,每一个工具对bug的生命周期定义都是不一致的,测试人员应该跟踪一个Bug的整个生命周期,从Open到Closed的所有状态。

5. 人际关系

确保操作没有问题,确保自己对需求理解没有问题,站在客户的角度考虑问题,不仅发现问题,还要提出解决问题的方案,最后还可以进行第三方会议(开会之前需要明确问题产生的原因,问题是什么,解决方案是什么;开会之后需要明确问题是否需要解决,谁什么时候解决)。

6. 如何开始第一次测试

6.1 充分理解需求

文档(产品文档+技术文档),项目功能问题问产品,模块底层如何实现问开发。

6.2 确定测试计划

6.3 执行测试

BUG开发修复之后一定要验收。

6.4 项目上线+维护

7. 测试的执行和BUG管理

7.1 进行测试

打开待测试的系统;打开测试管理工具用例模块,开始执行用例;发现bug,进行复现并确认bug复现步骤;记录bug;沟通bug;验证以前提交的bug;确认本次测试完成;编写测试报告。

执行测试时处理要做到测试用例和需求的覆盖外,还有临时发挥的能力,根据经验对测试的感悟以及随机测试可以发现很多根据测试用例无法发现的缺陷。

7.2 如何发现更多的bug

(1)软件测试同样存在二八原则,80%的故障集中于20%的模块,如果某部分问题较多,加强测试广度和深度。

(2)开发人员也存在二八原则。80%的故障集中于20%的开发,如果某些开发人员的bug较多,加强她开发模块的测试广度和深度。

(3)多进行逆向思维和发散性思维

依赖于测试人员的经验,对于初学者而言,只能多写测试用例,多看别人的测试用例。

(4)不要局限于用例和需求文档。

(5)尽早介入项目,不要等到开发差不多再介入。

QA:测试

RD:开发

PM:产品

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言:ctype和string库中的部分常用函数的应用和实现

在编程过程中,我们经常要处理字符和字符串,C语言标准库中就提供了一系列的库函数,便于我们操作库函数。 字符分类函数 C语⾔中有⼀系列的函数是专⻔做字符分类的,也就是⼀个字符是属于什么类型的字符的。这些函数的使⽤都需要包含…

蓝桥杯递推与递归法|斐波那契数列|数字三角形|42点问题|数的计算|数的划分(C++)

递归是用来做dfs,是搜索算法的基础 递推是用来做dp部分,及部分其他算法,复杂度较低,不会出现爆栈问题递推法: 递推法是一种在数学和其他领域广泛应用的重要方法,它在计算机科学中被用作一种关键的数值求解…

【深度学习笔记】6_10 双向循环神经网络bi-rnn

注:本文为《动手学深度学习》开源内容,部分标注了个人理解,仅为个人学习记录,无抄袭搬运意图 6.10 双向循环神经网络 之前介绍的循环神经网络模型都是假设当前时间步是由前面的较早时间步的序列决定的,因此它们都将信…

Java宝典-抽象类和接口

目录 1. 抽象类1.1 抽象类的概念1.2 抽象类的语法1.3 抽象类的特点 2. 接口2.1 接口的概念2.2 接口的语法2.3 接口的特点2.4 实现多个接口2.5 接口的继承 3. 接口使用案例 铁汁们好,今天我们学习抽象类和接口~ 1. 抽象类 1.1 抽象类的概念 什么是抽象类?在面向对象中,如果一…

cmaketool插件的自动扫描工作空间设置

点击左下角的齿轮,进入设置。 搜索cmake:config 将不需要的取消打钩即可

CCF-A推荐会议 安全界顶会ACM CCS‘24 4月29日第二轮投稿!共建更安全的数字世界!

会议之眼 快讯 第31届ACM CCS (ACM Conference on Computer and Communications Security)即计算机和通信安全会议将于 2024 年 10月14日-18日在美国盐湖城举行!CCS是美国计算机协会(ACM)安全、审计与控制特别兴趣小组(SIGSAC)主办的一年一度的重要会议。是SIGSAC的…

Redisson学习

简介 Redisson 是一个在 Redis 的基础上实现的 Java 驻留内存数据网格(In-Memory Data Grid)。它提供了许多分布式 Java 对象和服务,包括分布式锁、分布式集合、分布式执行服务、分布式调度任务等。 使用 依赖 相关依赖,注意版…

【Attribute】Inspector视图可视不可编辑字段特性

简介 在Unity开发中,有时候我们存在这种需求,需要在Inspector视图中可以查看字段信息但是无法对字段进行赋值,那么我们也可以像Unity内置的[SerializeField]、[Tooltip]等特性那样自定义一个特性,用于满足这个需求。 代码示例(C#…

【备战蓝桥杯系列】蓝桥杯国二选手笔记二:算法模版笔记(Java)

感谢大家的点赞,关注,评论。准备蓝桥杯的同学可以关注一下本专栏哦,不定期更新蓝桥杯笔记以及经验分享。本人多次参加过蓝桥杯,并获得过蓝桥杯国二的成绩。 算法模版笔记(Java) 这篇文章给大家分享我的蓝桥…

【C++】二叉树进阶之二叉搜索树

> 作者简介:დ旧言~,目前大二,现在学习Java,c,c,Python等 > 座右铭:松树千年终是朽,槿花一日自为荣。 > 目标:熟练掌握二叉搜索树,能自己模拟实现二…

每日一题-合成两个有序链表

🌈个人主页: 会编辑的果子君 💫个人格言:“成为自己未来的主人~” 以上是题目信息: 下面是解答过程 /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ typedef struct Lis…

【C#语言入门】17. 事件详解(上)

【C#语言入门】17. 事件详解(上) 一、初步了解事件 定义:单词Event,译为“事件” 通顺的解释就是**“能够发生的什么事情”**,例如,“苹果”不能发生,但是“公司上市”这件事能发生。在C#中事…

Android 完整SDK项目中添加对应的JNI与底层通信

安卓应用发消息给底层 近日需要写一个安卓app和底层发消息,这就涉及到java如何到c层的一个逻辑,app已经写好,就差发个消息了。至于如何对接底层,得和写底层的人进一步沟通,本文笔者只写从java层通信到cpp,…

RabbitMQ - 05 - Direct交换机

部署demo项目 通过消息队列demo项目进行练习 相关配置看此贴 http://t.csdnimg.cn/hPk2T 注意 生产者消费者的yml文件也要配置好 什么是Direct交换机 Direct 交换机是 AMQP(高级消息队列协议)中的一种交换机类型,它根据消息的路由键&am…

【微服务】SpringBoot整合Resilience4j使用详解

目录 一、前言 二、熔断器出现背景 2.1 几个核心概念 2.1.1 熔断 2.1.2 限流 2.1.3 降级 2.2 为什么会出现熔断器 2.3 断路器介绍 2.3.1 断路器原理 三、Resilience4j介绍 3.1 Resilience4j概述 3.1.1 Resilience4j是什么 3.1.2 Resilience4j功能特性 3.2 Resilie…

巨型犰狳优化算法(Giant Armadillo Optimization,GAO)的无人机三维路径规划(MATLAB)

一、无人机路径规划模型介绍 无人机三维路径规划是指在三维空间中为无人机规划一条合理的飞行路径,使其能够安全、高效地完成任务。路径规划是无人机自主飞行的关键技术之一,它可以通过算法和模型来确定无人机的航迹,以避开障碍物、优化飞行时间和节省能量消耗。 二、算法介…

javase day01笔记

第一天课堂笔记 Java第三代高级语言中的面向对象的语言 b/s 浏览器/服务器c/s 客户端/服务端 1991年詹姆斯高斯林在sun公司开发的Java 常用的dos命令 磁盘操作系统:dos win + r -》 cmd dos命令 切换盘符:直接输入对应盘符目录操作&#x…

【R包开发:入门】 简介+ 包的结构

简介 本书的目的是教你如何开发包,以便你可以写出自己的包,而不只是使用别人的包。 为什么要写一个包? 一个令人信服的理由是,你想要与他人分享代码。把你的代码打成一个包,可以方便他人使用,因为他们像你…

vue中性能优化

目录 1. 编码优化 2. 源码优化 3. 打包优化 4. 利用 Vue Devtools 总结 Vue.js 作为一个强大的前端框架,提供了丰富的功能和工具来帮助开发者构建高效的 Web 应用。然而,在开发过程中,性能优化仍然是一个需要关注的问题。以下是对 Vue.j…

高级IO【select、poll、epoll】

高山仰止,景行行止 文章目录 五种IO模型阻塞I/O非阻塞I/OI/O复用信号驱动I/O异步I/O 同步通信与异步通信同步通信异步通信 非阻塞IO基于fcntl实现setNonblock函数注意事项 IO多路转接—select文件描述符集合timeval结构调用过程返回值缺点和局限性 IO多路转接—poll…