超市管理系统制定测试计划
http://www.cnblogs.com/panguangmei/
超市管理系统测试计划
1. 简介
1. 1目的
超市管理系统“超市管理系统测试计划”文档有助于实现以下目标:
确定超市管理系统的信息和应超市管理系统测试的软件构件。
针对超市管理系统推荐可采用的超市管理系统测试策略,并对这些策略加以说明。
确定所需的资源,并对超市管理系统测试的工作量进行估计。
列出超市管理系统超市管理系统测试项目的可交付元素。
1. 2背景
对超市管理系统(构件、应用程序、系统等)及其目标进行简要说明。需要包括的信息有:主要的功能和性能、超市管理系统的构架以及项目的简史。
1.3范围
描述超市管理系统测试的各个阶段(例如,单元超市管理系统测试、集成超市管理系统测试或系统超市管理系统测试),并说明本计划所针对的超市管理系统测试类型(如功能超市管理系统测试或性能超市管理系统测试)。
简要地列出超市管理系统中将接受超市管理系统测试或将不接受超市管理系统测试的那些性能和功能。
如果在编写此文档的过程中做出的某些假设可能会影响超市管理系统测试设计、开发或实施,则列出所有这些假设。
列出可能会影响超市管理系统测试设计、开发或实施的所有风险或意外事件。
列出可能会影响超市管理系统测试设计、开发或实施的所有约束。
2. 超市管理系统测试参考文档和超市管理系统测试提交文档
2.1超市管理系统测试参考文档
下表列出了制定超市管理系统测试计划时所使用的文档,并标明了各文档的可用性:
文档 (版本/日期) |
已创建或可用 |
可行性分析报告 |
是 |
项目开发计划书 |
是 |
软件概要设计 |
是 |
软件详细设计 |
是 |
超市管理系统测试计划 |
是 |
超市管理系统测试分析报告 |
是 |
项目开发总结报告 |
是 |
代码编写 |
是 |
2.2超市管理系统测试提交文档
下面列出在超市管理系统测试阶段结束后,所有可提交的文档
3.超市管理系统测试进度
超市管理系统测试活动 |
计划开始日期 |
实际开始日期 |
结束日期 |
制定超市管理系统测试计划 |
5月1日 |
5月1日 |
5月2日 |
设计超市管理系统测试 |
5月3日 |
5月3日 |
5月5日 |
集成超市管理系统测试 |
5月6日 |
5月6日 |
5月7日 |
系统超市管理系统测试 |
5月8日 |
5月8日 |
5月11日 |
性能超市管理系统测试 |
5月12日 |
5月12日 |
5月15日 |
安装超市管理系统测试 |
5月16日 |
5月16日 |
5月20日 |
4.超市管理系统测试资源
4.1人力资源
下表列出了在此项目的人员。
角色 |
潘广玫 |
张雪 |
徐伟正 |
孙晶 |
潘广玫:负责编写测试计划,组织测试,对测试过程进行记录,收集、整理测试记录数据,对测试结果进行分析,编写测试总结报告。
孙晶:负责编写、调试客户端测试软件;数据库管理系统的安装
张雪:负责测试用的硬件维护及操作系统安装、CEWMS配置。
徐伟正:必要时可参加测试,并提出具体的测试要求,也可要求暂停测试。
4.2超市管理系统测试环境
下表列出了超市管理系统测试的系统环境
软件环境(相关软件、操作系统等) |
Windows XP |
Visual C++ |
Visual Basic |
硬件环境(网络、设备等) |
4.3超市管理系统测试工具
此项目将列出超市管理系统测试使用的工具:
用途 |
工具 |
生产厂商/自产 |
版本 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
5.系统风险、优先级
测试该系统面临的风险:
系统的程序代码是否存在问题或漏洞;
运行在该系统的数据库是否能正常使用;
测试该系统实现的优先级:
首先,对系统的代码进行精细测试;
然后.对系统的数据库进行测试;
6.超市管理系统测试策略
超市管理系统测试策略提供了对超市管理系统进行超市管理系统测试的推荐方法。
对于每种超市管理系统测试,都应提供超市管理系统测试说明,并解释其实施的原因。
制定超市管理系统测试策略时所考虑的主要事项有:将要使用的技术以及判断超市管理系统测试何时完成的标准。
下面列出了在进行每项超市管理系统测试时需考虑的事项,除此之外,超市管理系统测试还只应在安全的环境中使用已知的、有控制的数据库来执行。
注意:不实施某种超市管理系统测试,则应该用一句话加以说明,并陈述这样的理由。例如,“将不实施该超市管理系统测试。该超市管理系统测试本项目不适用”。
6.1超市管理系统数据和数据库完整性测试
要超市管理系统中,数据库和数据库进程应作为一个子系统来进行超市管理系统测试。在超市管理系统测试这些子系统时,不应将超市管理系统的用户界面用作数据的接口。对于数据库管理系统(DBMS),还需要进行深入的研究,以确定可以支持以下超市管理系统测试的工具和技术。
超市管理系统测试目标: |
确保数据库访问方法和进程正常运行,数据不会遭到损坏
|
技术: |
调用各个数据库访问方法和进程,并在其中填充有效的和无效的数据(或对数据的请求)。 检查数据库,确保数据已按预期的方式填充,并且所有的数据库事件已正常发生;或者检查所返回的数据,确保正当的理由检索到了正确的数据 |
完成标准: |
所有的数据库访问方法和进程都按照设计的方式运行,数据没有遭到损坏。 |
需考虑的特殊事项: |
超市管理系统测试可能需要DBMS开发环境或驱动程序在数据库中直接输入或修改数据。 进程应该以手工方式调用。 应使用小型或最小的数据库(记录的数量有限)来使所有无法接受的事件具有更大的可视度。 |
6.2超市管理系统接口测试
超市管理系统测试目标 |
确保接口调用的正确性
|
超市管理系统测试范围: |
所有软件、硬件接口,记录输入输出数据
|
需考虑的特殊事项: |
接口的限制条件
|
6.3超市管理系统集成测试
集成超市管理系统测试―主要目的检测系统是否达到需求对业务流程及数据流的处理是否符合标准,检测系统对业务流处理是否存在逻辑不严谨及错误,检测需求是否存在不合理的标准及要求。此阶段超市管理系统测试基于功能完成的超市管理系统测试。
超市管理系统测试目标 |
检测需求中业务流程,数据流的正确性
|
超市管理系统测试范围: |
需求中明确的业务流程,或组合不同功能模块而形成一个大的功能。 |
技术: |
利用有效的和无效的数据来执行各个用例、用例流或功能,以核实以下内容: 在使用有效数据时得到预期的结果。 在使用无效数据时显示相应的错误消息或警告消息。 各业务规则都得到了正确的应用。
|
开始标准: |
在完成某个集成超市管理系统测试时必须达到标准
|
完成标准: |
所计划的超市管理系统测试已全部执行。 所发现的缺陷已全部解决。
|
超市管理系统测试重点和优先级: |
超市管理系统测试重点指在超市管理系统测试过程中需着重超市管理系统测试的地方,优先级可以根据需求及严重来定
|
需考虑的特殊事项: |
确定或说明那些将对功能超市管理系统测试的实施和执行造成影响的事项或因素(内部的或外部的)
|
6.4超市管理系统功能测试
对超市管理系统的功能超市管理系统测试应侧重于所有可直接追踪到用例或业务功能和业务规则的超市管理系统测试需求。这种超市管理系统测试的目标是核实数据的接受、处理和检索是否正确,以及业务规则的实施是否恰当。此类超市管理系统测试基于黑盒技术,该技术通过图形用户界面(GUI)与应用程序进行交互,并对交互的输出或结果进行分析,以此来核实应用程序及其内部进程。以下为各种应用程序列出了推荐使用的超市管理系统测试概要:
超市管理系统测试目标 |
确保超市管理系统测试的功能正常,其中包括导航,数据输入,处理和检索等功能。
|
技术: |
利用有效的和无效的数据来执行各个用例、用例流或功能,以核实以下内容: 在使用有效数据时得到预期的结果。 在使用无效数据时显示相应的错误消息或警告消息。 各业务规则都得到了正确的应用。
|
需考虑的特殊事项: |
确定或说明那些将对功能超市管理系统测试的实施和执行造成影响的事项或因素(内部的或外部的)
|
6.5超市管理系统用户界面测试
用户界面(UI)超市管理系统测试用于核实用户与软件之间的交互。UI超市管理系统测试的目标是确保用户界面会通过超市管理系统的功能来为用户提供相应的访问或浏览功能。另外,UI超市管理系统测试还可确保UI中的对象按照预期的方式运行,并符合公司或行业的标准。
超市管理系统测试目标 |
核实以下内容: 通过超市管理系统测试进行的浏览可正确反映业务的功能和需求,这种浏览包括窗口与窗口之间、字段与字段之间的浏览,以及各种访问方法(Tab键、鼠标移动、和快捷键)的使用 窗口的对象和特征(例如,菜单、大小、位置、状态和中心)都符合标准。
|
技术: |
为每个窗口创建或修改超市管理系统测试,以核实各个应用程序窗口和对象都可正确地进行浏览,并处于正常的对象状态。
|
完成标准: |
成功地核实出各个窗口都与基准版本保持一致,或符合可接受标准
|
需考虑的特殊事项: |
并不是所有定制或第三方对象的特征都可访问。
|
6.6性能评测
性能评测是一种性能超市管理系统测试,它对响应时间、事务处理速率和其他与时间相关的需求进行评测和评估。性能评测的目标是核实性能需求是否都已满足。实施和执行性能评测的目的是将超市管理系统的性能行为当作条件(例如工作量或硬件配置)的一种函数来进行评测和微调。
注:以下所说的事务是指“逻辑业务事务”。这种事务被定义为将由系统的某个Actor通过使用超市管理系统来执行的特定用例,添加或修改给定的合同。
超市管理系统测试目标 |
核实所指定的事务或业务功能在以下情况下的性能行为: 正常的预期工作量 预期的最繁重工作量
|
技术: |
使用为功能或业务周期超市管理系统测试制定的超市管理系统测试过程。 通过修改数据文件来增加事务数量,或通过修改脚本来增加每项事务的迭代数量。 脚本应该在一台计算机上运行(最好是以单个用户、单个事务为基准),并在多个客户机(虚拟的或实际的客户机,请参见下面的“需要考虑的特殊事项”)上重复。
|
需考虑的特殊事项: |
综合的性能超市管理系统测试还包括在服务器上添加后台工作量。 可采用多种方法来执行此操作,其中包括: 直接将“事务强行分配到”服务器上,这通常以“结构化语言”(SQL)调用的形式来实现。 通过创建“虚拟的”用户负载来模拟许多个(通常为数百个)客户机。此负载可通过“远程终端仿真(Remote Terminal Emulation)工具来实现。此技术还可用于在网络中加载“流量”。 使用多台实际客户机(每台客户机都运行超市管理系统测试脚本)在系统上添加负载。 性能超市管理系统测试应该在专用的计算机上或在专用的机时内执行,以便实现完全的控制和精确的评测。 性能超市管理系统测试所用的数据库应该是实际大小或相同缩放比例的数据库。
|
6.7超市管理系统负载测试
负载超市管理系统测试是一种性能超市管理系统测试。在这种超市管理系统测试中,将使超市管理系统承担不同的工作量,以评测和评估超市管理系统在不同工作量条件下的性能行为,以及持续正常运行的能力。负载超市管理系统测试的目标是确定并确保系统在超出最大预期工作量的情况下仍能正常运行。此外,负载超市管理系统测试还要评估性能特征,例如,响应时间、事务处理速率和其他与时间相关的方面。
注:以下所说的事务是指“逻辑业务事务”。这各事务被定义为将由系统的某个最终用户通过使用应用程序来执行的特定功能,例如,添加或修改给定的合同。
超市管理系统测试目标 |
核实所指定的事务或商业理由在不同的工作量条件下的性能行为时间。
|
技术: |
使用为功能或业务周期超市管理系统测试制定的超市管理系统测试。 通过修改数据文件来增加事务数量,或通过修改脚本来增加每项事务发生的次数。
|
完成标准: |
多个事务或多个用户:在可接受的时间范围内成功地完成超市管理系统测试,没有发生任何故障。
|
需考虑的特殊事项: |
负载超市管理系统测试应该在专用的计算机上或在专用的机时内执行,以便实现完全的控制和精确的评测。 负载超市管理系统测试所用的数据库应该是实际大小或相同缩放比例的数据库。
|
6.8超市管理系统强度测试
强度超市管理系统测试是一种性能超市管理系统测试,实施和执行此类超市管理系统测试的目的是找出因资源不足或资源争用而导致的错误。如果内存或磁盘空间不足,超市管理系统就可能会表现出一些在正常条件下并不明显的缺陷。而其他缺陷则可能由于争用共享资源(如数据库锁或网络带宽)而造成的。强度超市管理系统测试还可用于确定超市管理系统能够处理的最大工作量。
超市管理系统测试目标 |
核实超市管理系统能够在以下强度条件下正常运行,不会出现任何错误: 服务器上几乎没有或根本没有可用的内存(RAM和DASD) 连接或模拟了最大实际(实际允许)数量的客户机 多个用户对相同的数据或帐户执行相同的事务 最繁重的事务量或最差的事务组合(请参见上面的“性能超市管理系统测试”)。 注:强度超市管理系统测试的目标可表述为确定和记录那些使系统无法继续正常运行的情况或条件。
|
技术: |
使用为性能评测或负载超市管理系统测试制定的超市管理系统测试。 要对有限的资源进行超市管理系统测试,就应该在一台计算机上运行超市管理系统测试,而且应该减少或限制服务器上的RAM和DASD。 对于其他强度超市管理系统测试,应该使用多台客户机来运行相同的超市管理系统测试或互补的超市管理系统测试,以产生最繁重的事务量或最差的事务组合。
|
完成标准: |
所计划的超市管理系统测试已全部执行,并且在达到或超出指定的系统限制时没有出现任何软件故障,或者导致系统出现故障条件的并不在指定的条件范围之内。
|
6.9超市管理系统容量测试
容量超市管理系统测试使超市管理系统处理大量的数据,以确定是否达到了将使软件发生故障的极限。容量超市管理系统测试还将确定超市管理系统在给定时间内能够持续处理的最大负载或工作量。例如,如果超市管理系统正在为生成一份报表而处理一组数据库记录,那么容量超市管理系统测试就会使用一个大型的超市管理系统测试数据库。检验该软件是否正常运行并生成了正确的报表。
超市管理系统测试目标 |
核实超市管理系统在以下高容量条件下能否正常运行: 连接或模拟了最大(实际或实际允许)数量的客户机,所有客户机在长时间内执行相同的、且情况(性能)最坏的业务功能。 已达到最大的数据库大小(实际的或按比例缩放的),而且同时执行多个查询或报表事务。
|
技术: |
使用为性能评测或负载超市管理系统测试制定的超市管理系统测试。 应该使用多台客户机来运行相同的超市管理系统测试或互补的超市管理系统测试,以便在长时间内产生最繁重的事务量或最差的事务组合(请参见上面的“强度超市管理系统测试”) 创建最大的数据库大小(实际的、按比例缩放的、或填充了代表性数据的数据库),并使用多台客户机在长时间内同时运行查询和报表事务。
|
完成标准: |
所计划的超市管理系统测试已全部执行,而且达到或超出指定的系统限制时没有出现任何软件故障。
|
6.10超市管理系统安全性和访问控制测试
安全性和访问控制超市管理系统测试侧重于安全性的两个关键方面:
应用程序级别的安全性,包括对数据或业务功能的访问。
系统级别的安全性,包括对系统的登录或远程访问。
应用程序级别的安全性可确保:在预期的安全性情况下,Actor只能访问特定的功能或用例,或者只能访问有限的数据。例如,可能会允许所有人输入数据,创建新帐户,但只有管理员才能删除这些数据或帐户。如果具有数据级别的安全性,超市管理系统测试就可确保“用户类型一”能够看到所有客户消息(包括财务数据),而“用户二”看见同一客户的统计数据。
系统级别的安全性可确保只有具备系统访问权限的用户才能访问应用程序,而且只能通过相应的网关来访问。
超市管理系统测试目标 |
应用程序级别的安全性:核实Actor只能访问其所属用户类型已被授权访问的那些功能或数据。
系统级别的安全性:核实只有具备系统和应用程序访问权限的Actor才能访问系统和应用程序。
|
技术: |
应用程序级别的安全性:确定并列出各用户类型及其被授权访问的功能或数据。 为各用户类型创建超市管理系统测试,并通过创建各用户类型所特有的事务来核实其权限。 修改用户类型并为相同的用户重新运行超市管理系统测试。对于每种用户类型,确保正确地提供或拒绝了这些附加的功能或数据。
|
完成标准: |
各种已知的Actor类型都可访问相应的功能或数据,而且所有事务都按照预期的方式运行,并在先前的应用程序功能超市管理系统测试中运行了所有的事务。
|
6.11超市管理系统故障转移和恢复测试
故障转移和恢复超市管理系统测试可可确保超市管理系统能成功完成转移,并能从导致意外数据损失或数据完整性破坏的各种硬件、软件可网络故障中恢复。
故障转移超市管理系统测试可确保:对于必须持续运行的系统,一旦发生故障,备用系统就将不失时机地“顶替”发生故障的系统,以避免丢失任何数据或事务。
恢复超市管理系统测试是一种对抗性的超市管理系统测试过程。在这种超市管理系统测试中,将把应用程序或系统置于极端的条件下(或者是模拟的极端条件下),以产生故障(例如设备输入/输出(I/O)故障或无效的数据库指针和关键字)。然后调用恢复进程并监测和检查应用程序和系统,核实应用程序或系统和数据已得到了正确的恢复。
超市管理系统测试目标 |
确保恢复进程(手工或自动)将数据库、应用程序和系统正确地恢复到预期的已知状态。 超市管理系统测试中将包括以下各种情况: 客户机断电 服务器断电 通过网络服务器产生的通信中断 DASD和/或DASD控制器被中断、断电或与DASD和/或DASD控制器的通信中断 周期未完成(数据过滤进程被中断,数据同步进程被中断)。 数据库指针或关键字无效 数据库中的数据元素无效或遭到破坏
|
技术: |
应该使用为功能和业务周期超市管理系统测试创建的超市管理系统测试来创建一系列的事务。一旦达到预期的超市管理系统测试起点,就应该分别执行或模拟以下操作: ² 客户机断电:关闭PC机的电源。 ² 服务器断电:模拟或启动服务器的断电过程。 ² 通过网络服务器产生的中断:模拟或启动网络的通信中断(实际断开通信线路的连接或关闭网络服务器或路由器的电源)。 ² DASD和DASD控制器被中断、断电或与DASD和DASD控制器的通信中断:模拟与一个或多个DASD控制器或设备的通信,或实际取消这种通信。 ² 一旦实现了上述情况(或模拟情况),就应该执行其他事务。而且一旦达到第二个超市管理系统测试点状态,就应调用恢复过程。 ² 在超市管理系统测试不完整的周期时,所使用的技术与上述技术相同,只不过应异常终止或提前终止数据库进程本身。 ² 对以下情况的超市管理系统测试需要达到一个已知的数据库状态。当破坏若干个数据库字段、指针和关键字时,应该以手工方式在数据库中(通过数据库工具)直接进行。其他事务应该通过使用“应用程序功能超市管理系统测试”和“业务周期超市管理系统测试”中的超市管理系统测试来执行,并且应执行完整的周期。
|
完成标准: |
在所有上述情况中,应用程序、数据库和系统应该在恢复过程完成时立即返回到一个已知的预期状态。此状态包括仅限于已知损坏的字段、指针或关键字范围内的数据损坏,以及表明进程或事务因中断面未被完成的报表。
|
需考虑的特殊事项: |
² 恢复超市管理系统测试会给其他操作带来许多的麻烦。断开缆线连接的方法(模拟断电或通信中断)可能并不可取或不可行。所以,可能会需要采用其他方法,例如诊断性软件工具。 ² 需要系统(或计算机操作)、数据库和网络组中的资源。 ² 这些超市管理系统测试应该在工作时间之外或在一台独立的计算机上运行。
|
6.12超市管理系统配置测试
配置超市管理系统测试核实超市管理系统在不同的软件和硬件配置中的运行情况。在大多数生产环境中,客户机工作站、网络连接和数据库服务器的具体硬件规格会有所不同。客户机工作站可能会安装不同的软件 例如,应用程序、驱动程序等 而且在任何时候,都可能运行许多不同的软件组合,从而占用不同的资源。
超市管理系统测试目标 |
核实超市管理系统测试可在所需的硬件和软件配置中正常运行。 |
技术: |
² 使用功能超市管理系统测试脚本。 ² 在超市管理系统测试过程中或在超市管理系统测试开始之前,打开各种与非超市管理系统相关的软件(例如Microsoft应用程序:Excel和Word),然后将其关闭。 ² 执行所选的事务,以模拟Actor与超市管理系统软件和非超市管理系统软件之间的交互。 ² 重复上述步骤,尽量减少客户机工作站上的常规可用内存。 |
完成标准: |
对于超市管理系统软件和非超市管理系统软件的各种组合,所有事务都成功完成,没有出现任何故障。
|
需考虑的特殊事项: |
² 需要、可以使用并可以通过桌面访问哪种非超市管理系统软件? ² 通常使用的是哪些应用程序? ² 应用程序正在运行什么数据?例如,在Excel中打开的大型电子表格,或是在Word中打开的100页文档。 ² 作为此超市管理系统测试的一部分,应将整修系统、Netware、网络服务器、数据库等都记录下来。
|
6.13安装超市管理系统测试
安装超市管理系统测试有两个目的。第一个目的是确保该软件在正常情况和异常情况的不同条件下 例如,进行首次安装、升级、完整的或自定义的安装 都能进行安装。异常情况包括磁盘空间不足、缺少目录创建权限等。第二个目的是核实软件在安装后可立即正常运行。这通常是指运行大量为功能超市管理系统测试制定的超市管理系统测试。
超市管理系统测试目标 |
核实在以下情况下,超市管理系统可正确地安装到各种所需的硬件配置中: ² 首次安装。以前从未安装过超市管理系统的新计算机 ² 更新。以前安装过相同版本的超市管理系统的计算机 ² 更新。以前安装过的较早版本的计算机
|
技术: |
² 手工开发脚本或开发自动脚本,以验证目标计算机的状况 首次安装超市管理系统从未安装过;超市管理系统安装过相同或较早的版本。 ² 启动或执行安装。 ² 使用预先确定的功能超市管理系统测试脚本子集来运行事务。
|
完成标准: |
超市管理系统事务成功执行,没有出现任何故障。
|
需考虑的特殊事项: |
应该选择超市管理系统的哪些事务才能准确地超市管理系统测试出超市管理系统应用程序已经成功安装,而且没有遗漏主要的软件构件?。
|
7.总结
和传统管理模式相比较,使用本系统,毫无疑问会大大提高超市的运作效率,辅助提高超市的决策水平,管理水平,为降低经营成本, 提高效益,减少差错,节省人力,减少顾客购物时间,增加客流量,提高顾客满意度,增强超市扩张能力, 提供有效的技术保障。 由于开发者能力有限,加上时间仓促,本系统难免会出现一些不足之处,例如: 本系统只适合小型超市使用,不能适合中大型超市使用;
超市管理系统涉及范围宽,要解决的问题多,功能复杂,实现困难,但由于限于时间,本系统只能做出其中的一部分功能;
对于以上出现的问题,我们深表歉意,如发现还有其它问题,希望老师批评指正。