软件测试案例 | 气象探测库存管理系统的集成测试计划

简介: 将经过单元测试的模块按照设计要求连接起来,组成规定的软件系统的过程被称为“集成”。集成测试也被称为组装测试、联合测试、子系统测试或部件测试等,其主要用于检查各个软件单元之间的接口是否正确。集成测试同时也是单元测试的逻辑扩展,即在单元测试基础之上将所有模块按照概要设计的要求组装成为子系统或系统,然后进行测试。但是,不同的集成策略会导致集成测试方法的选择不同。在实际工作中,时常有这样的情况发生: 每个模块都能单独工作,但是这些模块集成在一起后就不能正常工作。其主要原因是模块间相互调用时会引入许多新的问题: 数据经过接口可能丢失; 一个模块对另一个模块可能造成不应有的影响; 单个模块可以接受的误差在

640.jpg


将经过单元测试的模块按照设计要求连接起来,组成规定的软件系统的过程被称为“集成”。集成测试也被称为组装测试、联合测试、子系统测试或部件测试等,其主要用于检查各个软件单元之间的接口是否正确。集成测试同时也是单元测试的逻辑扩展,即在单元测试基础之上将所有模块按照概要设计的要求组装成为子系统或系统,然后进行测试。但是,不同的集成策略会导致集成测试方法的选择不同。在实际工作中,时常有这样的情况发生: 每个模块都能单独工作,但是这些模块集成在一起后就不能正常工作。其主要原因是模块间相互调用时会引入许多新的问题: 数据经过接口可能丢失; 一个模块对另一个模块可能造成不应有的影响; 单个模块可以接受的误差在组装后不断累积,达到了不可接受的程度等。所以,单元测试后必须进行集成测试,发现并排除这些单元在集成后可能发生的问题,最终构成符合要求的软件系统。

集成测试主要关注的问题: 应该测试哪些构件和接口?以什么样的次序进行集成?有哪些集成测试策略?
本节将利用一个实际的集成测试案例———“气象探测库存管理系统”的集成测试计划的制订来介绍集成测试相关内容。
#01、测试前的准备

##1. 目的

气象探测库存管理系统经过编码、单元测试后已形成待集成单元,本集成测试计划主要描述如何进行集成测试活动、如何控制集成测试活动、集成测试活动的流程以及集成测试活动的工作安排等。最终确保程序连接起来也能正常工作,确保程序的完整运行。

##2. 范围

本次测试计划主要是针对软件的集成测试,不含硬件、系统测试以及单元测试(需要已经完成单元测试)。

主要的任务如下。

(1) 测试在把各个模块连接起来的时候,穿越模块接口的数据是否会丢失。

(2) 测试各个子功能组合起来后能否达到父功能的预期要求。

(3) 测试某个模块的功能是否会对另一个模块的功能产生不利的影响。

(4) 测试全局数据结构是否有问题。

(5) 测试单个模块的误差积累起来,是否会放大,从而达到不可接受的程度。

主要测试方法是使用黑盒测试方法测试集成的功能,并且迭代地对之前的集成进行回归测试。

##3. 术语

入库: 气象装备入库是仓储管理业务的第一阶段,是指采购的气象设备进入仓库储存时进行的设备接收、检验检测、搬运、清点数量、检查质量和办理入库手续等一系列活动的总称。气象装备入库管理包括装备接运、装备检验检测、开具合格证和建立装备档案等4方面,其基本要求: 保证入库气象装备数量准确、质量符合要求、包装完整无损、手续完备清楚,入库迅速。

出库: 气象装备出库业务是仓库根据相关业务部门或装备保障部门开出的气象装备出库凭证(提货单、调拨单),按其所列气象装备编号、名称、规格、型号、数量等项目,组织气象装备出库的一系列工作的总称。出库发放的主要任务: 所发放的气象装备必须准确、及时、保质保量地发给收货单位,包装必须完整、牢固、标记正确清楚,核对必须仔细。

盘存: 盘存就是定期或不定期地对在库气象装备进行全部或部分清点,以确实掌握该所属周期内的气象装备应用情况,并对此加以改善,加强管理。掌控气象装备的“进(进货)、销(领货)、存(存货)”,可避免囤积太多气象装备或缺失气象装备的情况发生,其所得数据对计算成本及损失将是不可或缺的。

软件测试: 软件测试是根据软件开发各阶段的规格说明和程序的内部结构而精心设计一批测试用例,并利用这些测试用例运行软件,以发现软件错误的过程。

测试计划: 测试计划是指对软件测试的对象、目标、要求、活动、资源及日程进行整体规划,以确保软件系统的测试能够顺利进行的计划性文档。

测试用例: 测试用例指对一项特定的软件产品进行测试任务的描述,体现具体测试方案、方法、技术和策略的文档。其内容包括测试目标、测试环境、输入数据、测试步骤、预期结果、测试脚本等。

测试对象: 测试对象是指特定环境下运行的软件系统和相关的文档。作为测试对象的软件系统可以是整个业务系统,也可以是业务系统的一个子系统或一个完整的部件。

测试环境: 测试环境指对软件系统进行各类测试所基于的软、硬件设备和配置。一般包括硬件环境、网络环境、操作系统环境、应用服务器平台环境、数据库环境以及各种支撑环境等。



#02、测试策划

本系统的集成测试采用自底向上的集成方式。自底向上的集成方式将从程序模块结构中最底层的模块开始组装和测试。因为模块是自底向上进行组装的,对于一个给定层次的模块,由于它的子模块(包括子模块的所有下属模块)事前已经完成组装并经过测试,所以不再需要编制桩模块(一种能模拟真实模块,给待测模块提供调用接口或数据的测试用软件模块)。选择这种集成方式是因为管理方便,且测试人员能较好地锁定软件故障所在位置。

软件集成顺序采用自底向上的集成方式,先子系统,再顶系统。

子系统集成顺序上,功能集成采用先查找,后增加、删除、修改的顺序。

模块集成采用先入库出库模块,后盘点和管理员界面的顺序。

集成测试的主要步骤如表1所示,主要有以下几步。

(1) 制订集成测试计划。

(2) 设计集成测试。

(3) 实施集成测试。

(4) 执行集成测试。

(5) 评估集成测试。

■ 表1 集成测试的主要步骤


640.png


其中,集成元素包括子系统集成、功能集成、数据集成、函数集成等。

1. 子系统集成

(1) 入库模块。气象装备入库是仓储管理的第一阶段,其包括装备接运、装备检验检测、开具合格证和建立装备档案等4方面。

(2) 出库模块。气象装备出库业务是仓库根据相关业务部门或装备保障部门开出的气象装备出库凭证(提货单、调拨单),按其所列气象装备编号、名称、规格、型号、数量等项目,组织气象装备出库的一系列工作总称。

(3) 盘存模块。盘存就是定期或不定期地对在库气象装备进行全部或部分清点。

2. 功能集成

有关增加、删除、修改、查询各个数据的操作。

3. 数据集成

数据传递是否正确,传入值的控制范围是否一致等。

4. 函数集成

函数是否调用正常。



#03、测试设计与执行

在本项目中,集成测试主要涉及以下几个过程。

##1. 设计集成测试用例

(1) 采用自底向上集成测试的步骤,按照概要设计规格的说明,明确有哪些被测模块。在熟悉被测模块性质的基础上对被测模块进行分层,在同一层次上的测试可以并行进行,然后排出测试活动的先后关系,制订测试进度计划。

(2) 在步骤(1)的基础上,按时间线序关系将软件单元集成为模块,并测试在集成过程中出现的问题。这个步骤可能需要测试人员开发一些驱动模块来驱动集成活动中形成的被测模块。对于比较大的模块而言,可以先将其中的某几个软件单元集成为子模块,然后再集成为一个较大的模块。

(3) 将各软件模块集成为子系统(或分系统)。检测各子系统是否能正常工作。同样,可能需要测试人员开发少量的驱动模块来驱动被测子系统。

(4) 将各子系统集成为最终用户系统,测试各分系统能否在最终用户系统中正常工作。

##2. 实施测试

(1) 测试人员按照测试用例逐项进行测试活动,并且将测试结果填写在测试报告(测试报告必须覆盖所有测试用例)上。

(2) 测试过程中发现Bug,将Bug填写在使用的管理平台上(Bug状态为NEW)发给集成部门经理。

(3) 对应责任人接到管理平台发过来的Bug(Bug状态为ASSIGNED)。

(4) 对明显的并且可以立刻解决的Bug,将其发给开发人员; 对不是Bug的提交,集成部经理通知测试设计人员和测试人员,对相应文档进行修改(Bug状态为RESOLVED,决定设置为INVALID); 对目前无法修改的,将其放到下一轮次进行修改(Bug状态为RESOLVED,决定设置为REMIND)。

##3. 问题反馈与跟踪

(1) 开发人员接到发过来的Bug后应立刻修改(Bug状态为RESOLVED,决定设置为FIXED)。

(2) 测试人员接到管理平台发过来的错误更改信息后应该逐项复测,填写新的测试报告(测试报告必须覆盖上一次测试中所有REOPENED的测试用例)。

##4. 回归测试

(1) 重新测试修复Bug后的系统。重复步骤3,直到本步骤回归测试结果达到系统验收标准。

(2) 如果测试有问题则返回步骤2(Bug状态为REOPENED),否则关闭这项Bug(Bug状态为CLOSED)。

##5. 测试总结报告

完成以上4步后,综合相关资料生成测试报告。

整个集成过程如图1所示。

640.png


■ 图1 气象探测库存管理系统

04、集成测试的验收标准

1. 模块验收标准

接口: 接口提供的功能或者数据正确。

功能点: 验证程序与产品描述、用户文档中的全部功能点相对应。

流程处理: 验证程序与产品描述、用户文档中的全部流程相对应。

外部接口: 验证程序与产品描述、用户文档中的全部外部接口相对应。

2. 集成测试验收标准

集成测试设计用例中所设计的功能测试用例必须全部通过,性能及其他类型测试用例通过90%以上。在未通过的测试用例中,不能含有“系统崩溃”和“严重错误”之类的错误,“一般错误”应小于5%。

达到以上条件后可申请本轮集成测试结束,提交集成部测试经理,集成部测试经理召集本组人员开会讨论,决定下一轮测试工作。

当且仅当某次回归测试后测试结果符合软件质量的要求后,方可结束集成测试。

05、测试总结

记录问题: 利用Bug管理平台记录Bug,并指定到相关责任人。把Bug管理平台和需求设计文档、开发文档、测试文档、测试用例等联系起来,做成一个软件研发工具套件,之后即可通过一个Bug找到对应的文档、代码、测试用例等。

解决问题: 小组会议以及开发人员协调负责人,协调测试开发之间的工作。

测试结束后,形成测试报告。

目录
相关文章
|
2天前
|
敏捷开发 监控 测试技术
探索自动化测试工具Selenium Grid的高效集成策略
【4月更文挑战第30天】在现代Web应用的快速迭代和持续部署中,测试自动化已成为确保产品质量的关键。Selenium Grid作为一款支持多种浏览器和操作系统的测试工具,提供了并行执行测试用例的能力,极大地提升了测试效率。本文将深入探讨如何高效地将Selenium Grid集成到现有的测试框架中,以及实施过程中的最佳实践,帮助团队最大化测试覆盖率,同时降低资源消耗。
|
3天前
|
中间件 测试技术 API
探索自动化测试工具的新边界:Selenium与Appium的集成实践
【4月更文挑战第30天】 随着移动应用和Web应用的不断融合,传统的自动化测试工具需要适应新的测试环境。本文将详细分析Selenium和Appium这两款流行的自动化测试工具的集成实践,探讨如何构建一个能够同时支持Web和移动端应用的自动化测试框架。通过对比两者的技术架构、功能特性以及在实际项目中的集成过程,我们旨在为读者提供一个清晰的指导,帮助他们在复杂的应用环境中实现高效、稳定的自动化测试流程。
|
3天前
|
监控 JavaScript 前端开发
【TypeScript技术专栏】TypeScript的单元测试与集成测试
【4月更文挑战第30天】本文讨论了在TypeScript项目中实施单元测试和集成测试的重要性。单元测试专注于验证单个函数、类或模块的行为,而集成测试关注不同组件的协作。选用合适的测试框架(如Jest、Mocha),配置测试环境,编写测试用例,并利用模拟和存根进行隔离是关键。集成测试则涉及组件间的交互,需定义测试范围,设置测试数据并解决可能出现的集成问题。将这些测试整合到CI/CD流程中,能确保代码质量和快速响应变化。
|
3天前
|
运维 Kubernetes 持续交付
构建高效自动化运维系统:基于容器技术的持续集成与持续部署实践
【4月更文挑战第30天】 在快速发展的云计算时代,传统的运维模式已无法满足敏捷开发和快速迭代的需求。本文将介绍如何利用容器技术搭建一套高效自动化运维系统,实现软件的持续集成(CI)与持续部署(CD)。文章首先探讨了现代运维面临的挑战,接着详细阐述了容器技术的核心组件和工作原理,最后通过实际案例展示了如何整合这些组件来构建一个可靠、可扩展的自动化运维平台。
|
4天前
|
敏捷开发 机器学习/深度学习 Java
Java中的异常处理机制深入理解与实践:持续集成在软件测试中的应用探索自动化测试在敏捷开发中的关键作用
【4月更文挑战第29天】在Java编程中,异常处理是一个重要的概念。它允许开发者在程序执行过程中遇到错误或异常情况时,能够捕获并处理这些异常,从而保证程序的稳定运行。本文将详细介绍Java中的异常处理机制,包括异常的分类、异常的处理方式以及自定义异常等内容。 【4月更文挑战第29天】 随着敏捷开发和DevOps文化的兴起,持续集成(CI)已成为现代软件开发周期中不可或缺的一环。本文将探讨持续集成在软件测试领域内的关键作用、实施策略以及面临的挑战。通过对自动化构建、测试用例管理、及时反馈等核心要素的详细分析,揭示持续集成如何提高软件质量和加速交付过程。 【4月更文挑战第29天】 在当今快速发
|
4天前
|
敏捷开发 监控 jenkins
探索自动化测试在持续集成中的关键角色
【4月更文挑战第29天】 随着敏捷开发和持续集成(CI)实践的不断演进,自动化测试已成为确保软件质量和加快交付速度的核心要素。本文深入探讨了自动化测试在持续集成流程中的作用,分析了其提升效率、降低风险及促进团队协作的多重价值,并提出了有效整合自动化测试与CI的策略。通过案例分析,我们进一步验证了自动化测试在现代软件开发生态中不可替代的地位,同时指出了实施过程中可能遇到的挑战以及相应的解决方案。
|
4天前
|
敏捷开发 监控 Devops
探索自动化测试在持续集成中的关键作用
【4月更文挑战第29天】 在现代软件开发的快节奏环境中,持续集成(CI)已成为确保代码质量和加快交付速度的重要实践。本文将深入探讨自动化测试作为持续集成不可或缺的组成部分,分析其在提高软件交付效率、降低风险和确保质量方面的核心价值。通过实际案例和最佳实践的分享,揭示如何有效地整合自动化测试与持续集成流程,并讨论面临的挑战及应对策略,为软件开发团队提供实用的参考和指导。
6 1
|
4天前
|
机器学习/深度学习 人工智能 自然语言处理
提升软件测试效率:智能化测试用例生成策略
【4月更文挑战第28天】 随着软件开发的复杂性不断增加,传统的软件测试方法面临巨大挑战。为了提高测试覆盖率并确保软件质量,需要投入大量的时间和资源去设计、执行和维护测试用例。本文探讨了一种基于人工智能(AI)技术的智能化测试用例生成策略,该策略能够自动识别关键的测试路径,动态调整测试用例,并优化测试集合。通过引入智能化工具和算法,显著提升了软件测试过程的效率和有效性。
|
5天前
|
敏捷开发 Kubernetes 测试技术
深入理解软件测试中的持续集成与持续部署
【4月更文挑战第27天】 随着敏捷开发实践的普及,持续集成(CI)和持续部署(CD)成为软件开发周期中不可或缺的组成部分。本文旨在探讨CI/CD在软件测试中的应用及其对提高产品质量和加快上市速度的影响。通过对自动化测试、环境管理、版本控制等方面的分析,我们揭示了实施CI/CD的最佳实践,并讨论了如何克服常见挑战。文章的目的是为测试人员提供一个清晰的指南,帮助他们理解和实现一个高效的CI/CD流程。
|
6天前
|
运维 监控 测试技术
【专栏】自动化测试与持续集成/持续交付:加速软件开发的利器
【4月更文挑战第27天】本文探讨了自动化测试、持续集成(CI)和持续交付(CD)如何提升软件开发效率。自动化测试通过特定工具和框架确保软件质量,缩短开发周期,包括单元测试、集成测试等类型,并使用Selenium等框架。持续集成在合并代码前进行自动化测试,保证代码质量,促进团队协作,使用Jenkins等工具。持续交付则实现快速迭代,自动化部署过程,降低部署风险,提高软件质量和运维效率。这三者结合助力企业在竞争中胜出。

热门文章

最新文章