软件测试阶段及方法

软件测试阶段

1、单元测试

2、集成测试

3、系统测试

4、验收测试

软件测试阶段的划分:

1、单元测试

•单元测试是针对软件基本组成单元函数内部的语句、条件分支来进行正确性检验的测试工作

•单元测试的目的是检测软件模块对《详细设计说明书》LLD的符合程度

2、集成测试

•集成测试是在单元测试的基础上,将所有模块按照概要设计要求组装成为子系统或系统,验证组装后功能以及模块间接口是否正确的测试工作

•集成测试的目的是检测软件模块对《概要设计说明书》HLD的符合程度

3、系统测试

•系统测试是将已经集成好的软件系统,作为整个基于计算机系统的一个元素,与计算机硬件、外设、某些支持软件、数据和人员等其他系统元素结合在一起,在实际运行(使用)环境下,对计算机系统进行一系列的测试工作

•系统测试的目的在于通过与《需求规格说明书》SRS作比较,发现软件与系统需求定义不符合或与之矛盾的地方

4、验收测试

•单元测试、集成测试、系统测试是软件开发过程中在软件组织内部进行的测试阶段

•对于外包类的项目,在系统测试完成后,软件正式发布前一般都需要进行验收测试。验收测试通常有以下分类:

-α(ALPHA)测试

- β(BETA)测试

- UAT(User Acceptance Test)测试

•在通过了内部系统测试及软件配置审查之后,就可以开始验收测试

•验收测试是以用户为主的测试,验收组应该由项目组成员、用户代表等组成

•验收测试原则上在用户所在地进行,但如经用户同意也可以在公司内模拟用户环境进行

•验收测试根据合同、《需求规格说明书》或《验收测试计划》对成品进行验收测试

•验收测试的结果有两种情况:

-软件功能、性能等质量特性与用户的要求一致,软件可以接受

 软件功能、性能等质量特性与用户的要求有差距,不被用户接受

(1)α测试

•α 测试是由用户在开发环境下进行的测试,也可以是开发机构内部的用户在模拟实际操作环境下进行的测试

• α测试时,软件在一个自然设置状态下使用。开发者坐在用户旁,随时记下错误情况和使用中的问题。这是在受控制的环境下进行的测试

• α测试的目的主要是评价软件产品的FLURPS(即功能、局域化、可用性、可靠性、性能和技术支持

(2)β测试

•β测试是由软件的多个用户在一个或多个用户的实际使用环境下进行的测试

• 与α测试不同的是,β测试时开发者通常不在测试现场。因而,β测试是在开发者无法控制的环境下进行的软件现场应用

(3)UAT测试

UAT测试即用户接受度测试。一般用于商业用户验收系统的可用性。

•一般用于商业用户验证系统的可用性,通常情况由终端用户或利益相关方对被测试对象进行选择性功能验证。

• 也有可能根据法律法规、行业现行标准进行验收测试。

单元、集成、系统测试的比较

 测试方法不同

–  单元测试属于白盒测试范畴

–  集成测试属于灰盒测试范畴

–  系统测试属于黑盒测试范畴

• 测试对象不同

– 单元测试主要测试单元内部的数据结构、逻辑控制、异常处理等

– 集成测试主要测试模块之间的接口和接口数据传递关系,以及模块组合后的整体功能

–  系统测试主要测试整个系统相对于需求的符合度

• 判断标准不同

–  单元测试判断标准是详细设计说明书

–  集成测试的判断标准是概要设计说明书

–  系统测试的判断标准是软件需求规格说明书

软件测试方法

1、黑盒测试

2、白盒测试

3、灰盒测试

4、静态测试

5、动态测试

6、人工测试

7、自动化测试

软件测试的两种极端情况:

任何软件产品都可以使用以下的两种方法之一进行测试:

•已知产品的需求规格,但不知道其内部实现,可以进行测试证明每个需求是否实现。

•已知产品的内部实现过程,可以通过测试证明每种内部操作是否符合设计规格的要求,所有内部成分是否已经过检查。

1、黑盒测试

•黑盒测试把被测对象看成一个黑盒,只考虑其整体特性,不考虑其内部具体实现。

•黑盒测试针对的被测对象可以是一个系统、一个子系统、一个模块、一个子模块、一个函数等。

•黑盒测试又可以被称为基于规格的测试。

黑盒测试的特点:

•对于更大的代码单元来说(子系统甚至系统级)比白盒测试效率要高;

•测试人员不需要了解实现的细节,包括特定的编程语言;

•从用户的视角进行测试,很容易被大家理解和接受;

•有助于暴露任何规格不一致或有歧义的问题;

2、白盒测试

•白盒测试是依据被测软件分析程序内部构造,并根据内部构造设计用例,来对内部控制流程进行测试,可完全不顾程序的整体功能实现情况。

•白盒测试是基于程序结构的逻辑驱动测试。

•白盒测试又可以被称为玻璃盒测试、透明盒测试、开放盒测试、结构化测试、逻辑驱动测试。

为什么进行白盒测试?

    我们只要保证需求得到实现就行了,为什么要花费时间和精力来测试内部的逻辑细节呢?

•白盒测试一般在测试前期进行,通过达到一定的逻辑覆盖率指标,使得软件内部逻辑控制结构上的问题能基本得到消除

•白盒测试能保证内部逻辑结构达到一定的覆盖程度,能够给予软件代码质量更大的保证

•白盒测试发现问题后解决问题的成本较低

3、灰盒测试

•根据利用的被测对象信息的不同,会采用不同的方法进行测试。

•利用被测对象的整体特性信息,采用黑盒测试方法

•利用被测对象的内部具体实现信息,采用白盒测试方法

•如果既利用被测对象的整体特性信息,又利用被测对象的内部具体实现信息,采用的就是灰盒测试方法。两种信息占的比例不同,相应的灰度就不同。完全是整体特性信息,就是黑盒测试,完全是内部具体实现信息,就是白盒测试

典型的灰盒测试比如集成测试和系统测试时借助log信息

4、静态测试

•静态测试:不运行被测试的软件系统,而是采用其他手段和技术对被测试软件进行检测的一种测试技术。例如:代码走读、文档评审、程序分析等都是静态测试的范畴。常用技术有静态分析技术。

-----------------------------静态分析技术----------------------------    

•定义:静态分析是一种不通过执行程序而分析程序执行的技术

•功能:检查软件的表示和描述是否一致,没有冲突或者没有歧义,它瞄准的是纠正软件系统在描述、表示和规格上的错误,因此是任何进一步测试执行的前提。

主要有三种不同的程序测试可能性:

•考虑程序是否满足编码规则,语法上是否具有一致性和完整性;

•考虑文档描述是否规范、准确、便于查阅;

•考虑程序和文档之间的一致性。


5、动态测试

•动态测试: 按照预先设计的数据和步骤去运行被测软件系统,从而对被测软件系统进行检测的一种测试技术。常用技术有动态分析技术。

6、人工评测

•人工测试:测试活动(如评审、测试设计、测试执行等)由人来完成,狭义上是指测试执行由人工完成,这是最基本的测试形式

7、自动化测试

•自动化测试:一般是指通过计算机模拟人的测试行为,替代人的测试活动,狭义上是指测试执行由计算机来完成

----------------------------------------自动化测试的意义---------------------------------------

•对程序新版本运行前一版本执行的测试,提高回归测试效率

•可以运行更多更频繁的测试,比如冒烟测试

•可以执行手工测试困难或不可能做的测试,比如大量的重复操作或者集成测试

•更好地利用资源,比如测试仪器或者被测对象

----------------------------------------自动化测试的限制---------------------------------------

•不能取代手工测试,自动化测试只能提高测试效率,不能提高测试有效性,即不可能发现更多缺陷

•手工测试比自动测试发现的缺陷更多

•对测试设计依赖性极大,测试设计的不好会遗漏问题

•自动化测试对软件开发具有很大的依赖性,开发上出现变更可能导致前面的自动化测试完全失效

•工具本身并不具备想象力,工具不具有智能


软件测试方法的分类:

按照是否关心内部结构分为:黑盒测试、白盒测试、灰盒测试

按照是否运行软件产品分为:静态测试、动态测试

按照测试执行方式分为:手工测试、自动化测试

软件产品的概念:

•软件研发可以看成一个生产过程,在这个过程中会有产品输出,或者叫做工件输出

•输出的产品分成两类:

    最终产品,如编译后的软件、用户手册等

    中间产品,如SRS、HLD、LLD、代码等

•无论是最终产品还是中间产品,都可以分成代码和文档

•文档进一步细分还可以分成:

    开发文档,如SRS、HLD、LLD等

    测试文档,如测试计划、测试方案、测试用例等

•只要是软件产品,都是测试的对象

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容

  • 文章来自:http://blog.csdn.net/mj813/article/details/52451355 ...
    好大一只鹏阅读 9,191评论 2 126
  • 一、 软件测试基本概念 1 bug的概念 bug类型:defect、fault、problem、error… pr...
    三口一个瓜阅读 3,658评论 0 12
  • 1****、问:你在测试中发现了一个bug****,但是开发经理认为这不是一个bug****,你应该怎样解决? 首...
    蛋炒饭_By阅读 5,292评论 1 94
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    Mr希灵阅读 21,956评论 7 278
  • 1.测试与软件模型 软件开发生命周期模型指的是软件开发全过程、活动和任务的结构性框架。软件项目的开发包括:需求、设...
    宇文臭臭阅读 6,723评论 5 100