1、I. 测试类型功能指的是系统能做什么。 系统子系统或组件要实现的功能可以在工作产品中,如需求规格说明书,用户用例或功能规格说明书予以描述,不过也可能没有相应的文档。功能测试基于功能和特征以及专门的系统之间的交互,系统的功能来设计测试条件和测试用例。1 专门的系统之间的交互,我们又叫做功能交互2 可以采用基于规格说明书的技术(有正式的需求或设计规格说明书时)3 也可以基于测试人员对功能和特征的理解(如果没有相应文档时)4 功能测试主要是考虑软件的外部表现行为(黑盒测试) 5 功能测试可以在个级别的测试中进行(例如组件测试、集成测试和系统测试等级别都有基于设计或需求规格说明书的功能测试)1. 功能
2、测试举例1 安全性测试也是功能测试的一种,它会对安全性相关的功能(比如防火墙)进行测试,从而检测系统和数据是否能抵御外部恶意的威胁,比如病毒等。2 互操作性测试是另一种功能性测试,评估软件产品与其他一个或多个组件或系统交互的能力。2. 非功能测试非功能性测试就是测试系统工作的怎样非功能测试包括但不限于:性能测试、负载测试、压力测试、可用性测试、可维护性测试、可靠性测试和可移植性测试非功能测试可以在任何测试级别上执行3. 非功能测试举例负载测试:一种通过增加负载来测量组件或系统的测试方法。例如:通过并发用户数和事务数量来测量组件或系统能够承受的负载。压力测试:在规定的或超过规定的需求条件下测试组
3、件系统,以对其进行评估。健壮性测试:判定软件产品健壮性(在出现无效输入或压力环境条件下,组件、系统能够正常工作的程度,参见 fault-tolerance)的测试。性能测试:判定软件产品性能(组件、系统在给定的处理周期和吞吐率(throughputrate)等约束下,完成指定功能的程度)的测试过程。参见efficiencytesting.4. 与变更相关的测试与变更相关的测试:当软件被修改、缺陷被修复、新增了功能、软件运行环境发生变化等,需要开展与变更有关的测试。根据经验,修改一个现存的程序,比编写一个新程序更容易产生错误(依每写一行代码的错误数量计)再测试:重新执行上次失败的测试用例,以验证
4、纠错的正确性。参见确认测试(confirmationtesting)回归测试:测试先前测试过并修改过的程序,确保更改没有给软件其他未改变的部分带来退化缺陷(regressionbung ).软件修改后或使用环境变更后要执行回归测试。回归测试策略:回归测试的规模可以根据在已运行的软件中发现新的缺陷的风险大小来决定,比如可以只重新运行所有发现缺陷的用例(即只进行确认测试)、测试所有经过修改的功能、测试所有新增功能、对整个系统进行完美的回归测试等,对变更进行影响分析(impactanalysis)有助于确定回归测试的深度。将回归测试自动化是很好的选择。回归测试可以在所有的测试级别上进行,同时适用于功
5、能测试、非功能测试和结构测试。 5. 维护测试维护测试是在一个现有的运行系统上进行,且一旦对软件或系统进行修改、移植或退役处理时,就需要进行维护测试。除了对已变更的部分进行测试外,维护测试还包括对系统没有发生变更的其他部分进行大范围的回归测试。维护测试的范围取决于变更的风险、现有系统的规模和变更的大小。维护测试根据变更情况的不同,可以在某一或所有的测试级别和测试类型上进行。修改可以是计划中的功能增强(例如:根据版本发布的计划)、纠正和应急变更、环境的变化比如计划中的操作系统或数据库升级,或由于新发现或暴露的软件、操作系统、硬件漏洞而大打的补丁等。为软件移植(如从一个平台移植到另外一个平台)而进
6、行的维护测试应该包括新环境的运行测试(operationaltesting),以及对变更以后的软件的运行测试。为系统退役而进行的维护测试应该包括数据移植或者存档测试,如果需要长时间的数据保存的话。II. 测试方法软件测试方法是指测试软件性能的方法。随着软件测试技术的不断发展,测试方法也越来越多样化,针对性更强;选择合适的软件测试方法可以让用户事半功倍。软件测试方法有系统测试、动态测试、单元测试、集成测试等多种。B 测试,英文名是 Beta testing。又称 Beta 测试用户验收测试( uat)。B 测试是软件的多个用户在一个或多个用户的实际使用环境下进行的测试。当开发和测试要完成所做的测
7、试,而最终的错误和问题需要在最终发行前找到。这种测试一般由最终用户或其他人员完成,不能由程序员或测试员完成。A 测试 -Alpha 测试A 测试,英文名是 Alpha testing。又称 Alpha 测试。Alpha 测试是由用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的受控测试,Alpha 测试不能由该系统的程序员或测试员完成。在系统开发接近完成时对应用系统的测试;测试后仍然会有少量的设计变更。这种测试一般由最终用户或其他人员来完成,不能由程序员或测试员完成。可移植性测试,英文名是 Portability testing。又称兼容性测试。可移植性测试是指测试软
8、件是否可以被成功移植到指点的硬件或软件平台上。1. UI测试用户界面测试,英文名是 User interface testing。又称 UI 测试。用户界面,英文名是 User interface。是指软件中的可见外观及其底层与用户交互的部分(菜单、对话框、窗口和其他控件)。用户界面测试是指测试用户界面的风格是否美观,文字,图片组合是否完美,操作是否友好等等。UI 测试的目标是确保用户界面会通过测试对象的功能来为用户提供相应的访问或浏览功能。确保用户界面符合公司或行业的标准。包括用户友好性、人性化、易操作性测试。用户界面测试用户 分析软件用户界面的设计是否合乎用户期望或要求。它常常包括等菜单,
9、对话框及对话框上所有的按钮,文字,出错提示,帮助信息(Menu 和heipcontent)等方面的测试。比如,测试 Microsoft Excel 中插入符合功能所用的对话框的大小,所有按钮是否对齐,字符串字体大小,出错信息内容和字体大小,工具栏位置、图标等等。2. 冒烟测试冒烟测试,英文名是 Snoke testing。冒烟测试的名称可以理解为该种测试耗时短,仅用一袋烟功夫足够了。也有人认为是形象地类比新电路板基本功能检查。任何新电路板焊好后,先通电检查,如果存在设计缺陷,电路板可能会短路,板子冒烟了。冒烟测试的对象是新编译的每一个需要正式测试的软件版本,目的是确认软件基本功能正常,可以进行
10、后续的正式测试工作。冒烟测试的执行者是版本编译人员。3. 随机测试随机测试,英文名是 Ad hoc testing。随机测试没有书面测试用例、记录期望结果、检查列表、脚本或指令的测试。主要是根据测试者的经验对软件进行功能和性能抽查。随机测试是根据说明书执行用例测试的只要补充手段,是保证测试覆盖完整性的有效方法和过程。随机测试主要是对被测软件的一些重要功能进行复测,也包括测试那些当前的测试样例(TestCase)没有覆盖到的部分。另外,对于软件更新和新增加的功能要重点测试。重点对一些特殊点情况点、特殊的使用环境、并发性、进行检查。尤其对以前测试发现的直达 Bug,进行再次测试,可以结合回归测试(
11、 Regressive testing)一起进行。本地化测试本地化测试,英文是 Localization testing。本地化就是将软件版本语言进行更改,比如将英文的 windows 改成中文的 windows就是本地化。本地化测试的对象是软件的本地化版本。本地化测试的目的是测试特定目标区域设置的软件本地化质量。本地化测试的环境是在本地化的操作系统上安装本地化的软件。从测试方法上可以分为基本功能测试,安装/卸载测试,当地区域的软硬件兼容性测试。测试的内容主要包括软件本地化后的界面布局和软件翻译的语言质量,包含软件、文档和联机帮助等部分。1. 基础化本地化能力测试,英文是 Localizabi
12、lity testing。本地化能力测试是指不需要重新设计或修改代码,将程序的用户界面翻译成任何目标语言的能力。为了降低本地化能力测试的成本,提高测试效率,本地化能力测试通常在软件的伪本地化版本上进行。本地化能力测试中发现的典型错误包括:字符的硬编码(即软件中需要本地化的字符写在了代码内部),对需要本地化的字符长度设置了固定值,在软件运行时以控件位置定位,图标和位图中包含了需要本地化的文本,软件的用户界面与文档术语不一致等。2. 国际化国际化测试,英文是 International testing。又称国际化支持测试。国际化测试的目的是测试软件的国际化支持能力,发现软件的国际化的潜在问题,保证
13、软件在世界不同区域都能正常运行。国际化测试使用每种可能的国际输入类型,针对任何区域性或区域设置检查产品的功能是否正常,软件国际化测试的重点在于执行国际字符串的输入/输出功能。国际化测试数据必须包含 东亚语言、德语、复杂脚本字符和英语(可选)的混合字符。国际化支持测试是指验证软件程序在不同国家或区域的平台上也能够如预期的那样运行,而且还可以按照原设计尊重和支持使用当地常用的日期,字体,文字表示,特殊格式等等。比如,用英文版的 Windows XP 和 Microsoft Word 能否展示阿拉伯字符串?用阿拉伯版的 Windows XP 和 阿拉伯版的 Microsoft Word 能否展示阿拉
14、伯字符串?又比如,日文版的 Microsoft Excel 对话框是否显示正确翻译的日语?一旦来说执行国际化支持测试的测试人员往往需要基本上了解这些国家或地区的语言要求和期望行为是什么。3. 安装测试安装测试,英文是 Installing testing。安装测试是确保软件在正常情况和异常情况下,例如,进行首次安装、升级、完整的或自定义的安装都能进行安装的测试。异常情况包括磁盘空间不足、缺少目录创建权限等场景。核实软件在安装后可立即正常运行。安装测试包括测试安装代码以及安装手册。安装手册提供如何进行安装,安装代码提供安装一些程序能够运行的基础数据。B. 白盒测试白盒测试,英文是 White B
15、ox Testing。又称结构测试或者逻辑驱动测试。白盒测试是把测试对象看作一个打开的盒子。利用白盒测试法进行动态测试时,需要测试软件产品的内部结构和处理过程,不需测试软件产品的功能。白盒测试法的覆盖标准有逻辑覆盖、循环覆盖和基本路径测试。其中逻辑覆盖包括语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、条件组合覆盖和路径覆盖。白盒测试是知道产品内部工作过程,可通过测试来检测产品内部动作是否按照规格说明书的规定正常进行,按照程序内部的结构测试程序,检验程序中的每条通路是否都有能按预定要求正确工作,而不顾它的功能,白盒测试的主要方法有逻辑驱动、基路测试等,主要用于软件验证。白盒测试常用工具有:Jte
16、st 、 VcSmith、Jcontract、C+ Test、CodeWizard、logiscope。C. 黑盒测试黑盒测试,英文是 Black Box Testing。又称功能测试或者数据驱动测试。黑盒测试是根据软件的规格对软件进行的测试,这类测试不考虑软件内部的运作原理,因此软件对用户来说就像一个黑盒子。软件测试人员以用户的角度,通过各种输入和观察软件的各种输出结果来发现软件存在的缺陷,而不关心程序具体如何实现的一种软件测试方法。黑盒测试常用工具有:AutoRunner、winrunnerD. 自动化自动化测试,英文是 Automated Testing。使用自动化测试工具来进行测试,这
17、类测试一般不需要人干预,通常在 GUI、性能等测试和功能测试中用得较多。通过录制测试脚本,然后执行这个测试脚本来实现测试过程的自动化。国内领先的自动化测试服务提供商是泽众软件。自动化测试工具有QTP、Testcomplete、AutoRunner 和 TAR 等。1. 回归测试回归测试,英文是 Regression testing。回归测试是指在发生修改之后重新测试先前的测试以保证修改的正确性。理论上,软件产生新版本,都需要进行回归测试,验证以前发现和修复的错误是否在新软件版本上再次出现。根据修复好了的缺陷再重新进行测试。回归测试的目的在于验证以前出现过但已经修复好的缺陷不再重新出现。一般指对
18、某已知修正的缺陷再次围绕它原来出现时的步骤重新测试。通常确定所需的再测试的范围时是比较困难的,特别当临近产品发布日期时。因为为了修正某缺陷时必需更改源代码,因而就有可能影响这部分源代码所控制的功能。所以在验证修好的缺陷时不仅要服从缺陷原来出现时的步骤重新测试,而且还要测试有可能受影响的所有功能。因此应当鼓励对所有回归测试用例进行自动化测试。2. 验收测试验收测试,英文是 Acceptance testing。验收测试是指系统开发生命周期方法论的一个阶段,这时相关的用户或独立测试人员根据测试计划和结果对系统进行测试和接收。它让系统用户决定是否接收系统。它是一项确定产品是否能够满足合同或用户所规定
19、需求的测试。验收测试一般有三种策略:正式验收、非正式验收或 Alpha 测试、Beta 测试。E. 静态测试静态测试,英文是 Static Testing。静态测试指测试不运行的部分,例如测试产品说明书,对此进行检查和审阅.。静态方法是指不运行被测程序本身,仅通过分析或检查源程序的文法、结构、过程、接口等来检查程序的正确性。静态方法通过程序静态特性的分析,找出欠缺和可疑之处,例如不匹配的参数、不适当的循环嵌套和分支嵌套、不允许的递归、未使用过的变量、空指针的引用和可疑的计算等。静态测试结果可用于进一步的查错,并为测试用例选取提供指导。静态测试常用工具有:Logiscope、PRQA;F. 动态
20、测试动态测试,英文是 Moment Testing。动态测试是指通过运行软件来检验软件的动态行为和运行结果的正确性。根据动态测试在软件开发过程中所处的阶段和作用,动态测试可分为如下几个步骤:1、单元测试2、集成测试3、系统测试4、验收测试5、回归测试G. 单元测试单元测试,英文是 Unit Testing。单元测试是最微小规模的测试;以测试某个功能或代码块。典型地由程序员而非测试员来做,因为它需要知道内部程序设计和编码的细节知识。这个工作不容易做好,除非应用系统有一个设计很好的体系结构; 还可能需要开发测试驱动器模块或测试套具。H. 集成测试集成测试,英文是 Integration Testi
21、ng。集成测试是指一个应用系统的各个部件的联合测试,以决定它们能否在一起共同工作并没有冲突。部件可以是代码块、独立的应用、网络上的客户端或服务器端程序。这种类型的测试尤其与客户服务器和分布式系统有关。一般集成测试以前,单元测试需要完成。集成测试是单元测试的逻辑扩展。它的最简单的形式是:两个已经测试过的单元组合成一个组件,并且测试它们之间的接口。从这一层意义上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合成程序的更大部分。方法是测试片段的组合,并最终扩展进程,将您的模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。此外,如果程序由多个进程组成,应
22、该成对测试它们,而不是同时测试所有进程。集成测试识别组合单元时出现的问题。通过使用要求在组合单元前测试每个单元,并确保每个单元的生存能力的测试计划,可以知道在组合单元时所发现的任何错误很可能与单元之间的接口有关。这种方法将可能发生的情况数量减少到更简单的分析级别I. 系统测试系统测试,英文是 System Testing。系统测试是基于系统整体需求说明书的黑盒类测试,应覆盖系统所有联合的部件。系统测试是针对整个产品系统进行的测试,目的是验证系统是否满足了需求规格的定义,找出与需求规格不相符合或与之矛盾的地方。系统测试的对象不仅仅包括需要测试的产品系统的软件,还要包含软件所依赖的硬件、外设甚至包
23、括某些数据、某些支持软件及其接口等。因此,必须将系统中的软件与各种依赖的资源结合起来,在系统实际运行环境下来进行测试。J. 端到端端到端测试,英文是 End to End Testing。端到端测试类似于系统测试,测试级的“宏大” 的端点,涉及整个应用系统环境在一个现实世界使用时的模拟情形的所有测试。例如与数据库对话,用网络通讯,或与外部硬件、应用系统或适当的系统对话。端到端架构测试包含所有访问点的功能测试及性能测试。端到端架构测试实质上是一种“ 灰盒“ 测试,一种集合了白盒测试 和黑盒测试的优点的测试方法。K. 卸载测试卸载测试,英文是 Uninstall Testing。卸载测试是对软件的
24、全部、部分或升级卸载处理过程的测试。主要是测试软件能否卸载,卸载是否干净,对系统有无更改,在系统中的残留与后来的生成文件如何处理等。还有原来更改的系统值是否修改回去L. 验收测试接受测试,英文是 Accept Testing。接受测试是基于客户或最终用户的规格书的最终测试,或基于用户一段时间的使用后,看软件是否满足客户要求。一般从功能、用户界面、性能、业务关联性进行测试。M. 性能测试性能测试,英文是 Performance Testing。性能测试是在交替进行负荷和强迫测试时常用的术语。理想的“性能测试”( 和其他类型的测试) 应在需求文档或质量保证、 测试计划中定义。性能测试一般包括负载测
25、试和压力测试。通常验证软件的性能在正常环境和系统条件下重复使用是否还能满足性能指标。或者执行同样任务时新版本不比旧版本慢。一般还检查系统记忆容量在运行程序时会不会出现内存泄露(memory leak)。比如,验证程序保存一个巨大的文件新版本不比旧版本慢。1. 健全测试健全测试,英文是 Sanity testing。健全测试是指一个初始化的测试工作,以决定一个新的软件版本测试是否足以执行下一步大的测试能力。例如,如果一个新版软件每 5 分钟与系统冲突,使系统陷于泥潭,说明该软件不够“健全”,不具备进一步测试的条件。2. 衰竭测试衰竭测试,英文是 Failure Testing。衰竭测试是指软件或
26、环境的修复或更正后的“再测试” 。可能很难确定需要多少遍再次测试。尤其在接近开发周期结束时。自动测试工具对这类测试尤其有用。3. 负载测试负载测试,英文是 Load testing。负载测试是测试一个应用在重负荷下的表现。例如测试一个 Web 站点在大量的负荷下,何时系统的响应会退化或失败,以发现设计上的错误或验证系统的负载能力。在这种测试中,将使测试对象承担不同的工作量,以评测和评估测试对象在不同工作量条件下的性能行为,以及持续正常运行的能力。负载测试的目标是确定并确保系统在超出最大预期工作量的情况下仍能正常运行。此外,负载测试还要评估性能特征,例如,响应时间、事务处理速率和其他与时间相关的
27、方面。4. 强迫测试强迫测试,英文是 Force Testing。强迫测试是在交替进行负荷和性能测试时常用的术语。也用于描述对象在异乎寻常的重载下的系统功能测试之类的测试,如某个动作或输入大量的重复,大量数据的输入,对一个数据库系统大量的复杂查询等。5. 压力测试压力测试,英文是 Stress Testing。和负载测试差不多。压力测试是一种基本的质量保证行为,它是每个重要软件测试工作的一部分。压力测试的基本思路很简单:不是在常规条件下运行手动或自动测试,而是在计算机数量较少或系统资源匮乏的条件下运行测试。通常要进行压力测试的资源包括内部内存、CPU 可用性、磁盘空间和网络带宽等。一般用并发来
28、做压力测试。6. 恢复测试恢复测试,英文是 Recovery testing。恢复测试是测试一个系统从如下灾难中能否很好地恢复,如遇到系统崩溃、硬件损坏或其他灾难性问题。恢复测试指通过人为的让软件(或者硬件)出现故障来检测系统是否能正确的恢复,通常关注恢复所需的时间以及恢复的程度。恢复测试主要检查系统的容错能力。当系统出错时,能否在指定时间间隔内修正错误并重新启动系统。恢复测试首先要采用各种办法强迫系统失败,然后验证系统是否能尽快恢复。对于自动恢复需验证重新初始化(reinitialization)、检查点(checkpointing mechanisms)、数据恢复(data recover
29、y)和重新启动 (restart)等机制的正确性;对于人工干预的恢复系统,还需估测平均修复时间,确定其是否在可接受的范围内。N. 安全测试安全测试,英文是 Security Testing。安全测试是测试系统在防止非授权的内部或外部用户的访问或故意破坏等情况时怎么样。这可能需要复杂的测试技术。安全测试检查系统对非法侵入的防范能力。安全测试期间,测试人员假扮非法入侵者,采用各种办法试图突破防线。例如:想方设法截取或破译口令;专门定做软件破坏系统的保护机制;故意导致系统失败,企图趁恢复之机非法进入;试图通过浏览非保密数据,推导所需信息,等等。理论上讲,只要有足够的时间和资源,没有不可进入的系统。因
30、此系统安全设计的准则是,使非法侵入的代价超过被保护信息的价值。此时非法侵入者已无利可图。O. 兼容性兼容测试,英文是 Compatibility Testing。兼容测试是测试软件在一个特定的硬件/软件/ 操作系统/网络等环境下的性能如何。向上兼容向下兼容,软件兼容硬件兼容。软件的兼容性有很多需要考虑的地方。P. 可用性可用性测试,英文是 Practical Usability Testing。可用性测试是对“用户友好性 ”的测试。显然这是主观的,且将取决于目标最终用户或客户。用户面谈、调查、用户对话的录象和其他一些技术都可使用。程序员和测试员通常都不宜作可用性测试员。Q. 比较测试比较测试,
31、英文是 Compare Testing。比较测试是指与竞争伙伴的产品的比较测试,如软件的弱点、优点或实力。来取长补短,以增强产品的竞争力。R. 可接受性可接受性测试,英文是 Acceptability Testing。可接受性测试是在把测试的版本交付测试部门大范围测试以前进行的对最基本功能的简单测试。因为在把测试的版本交付测试部门大范围测试以前应该先验证该版本对于所测试的功能基本上比较稳定。必须满足一些最低要求。比如不会很容易程序就挂起或崩溃。如果一个新版本没通过可测试性的验证,就应该阻拦测试部门花时间在该测试版本上测试。同时还要找到造成该版本不稳定的主要缺陷并督促尽快加以修正S. 边界条件边
32、界条件测试,英文是 Boundary Testing。又称边界值测试。一种黑盒测试方法,适度等价类分析方法的一种补充,由长期的测试工作经验得知,大量的错误是发生在输入或输出的边界上。因此针对各种边界情况设计测试用例,可以查出更多的错误。边界条件测试是环绕边界值的测试。通常意味着测试软件各功能是否能正确处理最大值,最小值或者所设计软件能够处理的最长的字符串等等。T. 强力测试强力测试,英文是 Mightiness Testing。强力测试通常验证软件的性能在各种极端的环境和系统条件下是否还能正常工作。或者说是验证软件的性能在各种极端环境和系统条件下的承受能力。比如,在最低的硬盘驱动器空间或系统记
33、忆容量条件下,验证程序重复执行打开和保存一个巨大的文件 1000 次后也不会崩溃或死机。U. 装配安装装配/安装/配置测试是验证软件程序在不同厂家的硬件上,所支持的不同语言的新旧版本平台上,和不同方式安装的软件都能够如预期的那样正确运行。比如,把英文版的 Microsoft Office 2003 安装在韩文版 的 Windows Me 上,再验证所有功能都正常运行。V. 隐藏数据隐藏数据测试在软件验收和确认阶段是十分必要和重要的一部分。程序的质量不仅仅通过用户界面的可视化数据来验证,而且必须包括遍历系统的所有数据。假设一个应用程序要求用户两条信息-用户名和密码来创建帐户。这个用户输入这两条数
34、据后保存。最后,一个确认窗口将通过数据库中找到这条数据来显示用户名和密码给用户。为了验证所有的数据保存是否正确,一个 QA 测试人员会在这个确认窗口简单的查看下用户名和密码。如果他们成功了?假设数据库记录了第三条信息-创建日期,它可能不会出现在确认窗口,而只在存档中才出现。如果创建日期保留的不正确,而 QA 测试人员只验证屏幕上的数据,那么这个问题就不可能被发现。创建日期可能就是一个 bug,由于一个用户帐户保存了一个错误的日期到数据库中,这个问题也不可能会被引起注意,因为它被用户界面所隐藏。这只是一个简单的例子,但是它却演化出了一点:隐藏数据测试的重要性。W. 等价划分等价划分测试的英文是
35、equivalence partition testing。等价划分测试是根据等价类设计测试用例的一种技术。是黑盒测试的典型方法之一,通过把被测试程序所有可能的输入数据域划分成若干部分。从每一部分中选取少数有代表性的数据作为测试用例,可有效减少测试次数,极大提高软件测试效率,缩短软件开发周期等价类划分测试的目的就是为了在有限的测试资源的情况下,用少量有代表性的数据得到比较好的测试效果。有效等价类和无效等价类。有效等价类中的数据代表的是一组符合需求文档的正确的有意义数据。无效等价类则正相反。X. 判定表判定表的英文是 decision table,是指一个表格,用于显示条件和条件导致动作的集合。
36、定义:判定表是分析和表达多逻辑条件下执行不同操作的情况的工具。判定表的优点:能够将复杂的问题按照各种可能的情况全部列举出来,简明并避免遗漏。因此,利用判定表能够设计出完整的测试用例集合。在一些数据处理问题当中,某些操作的实施依赖于多个逻辑条件的组合,即:针对不同逻辑条件的组合值,分别执行不同的操作。判定表很适合于处理这类问题Y. 深度测试深度测试的英文 Depth test ,是指执行一个产品的一个特性的所有细节,但不测试所有特性。当比较函数返回真的时候才显示出效果来。必须启用“#深度测试”,才能执行测试。不使用的时候需要关闭。Z. 基于设计基于设计的测试的英文是 design-based t
37、esting,是根据软件的构架或详细设计引出测试用例的一种方法。一种基于设计模型的测试方法(Model Based TestIng System,MATIS).该方法利用用户界面自动生成方法,把设计模型中的类属性定义和实现中的控件属性组织在一起, 构建描述界面的逻辑对照表,辅助测试脚本 引擎执行自动测试脚本 .借助设计模型中扩展的类定义,MATIS 方法可以自动生成测试用例和测试数据。AA.文档测试文档测试的英文是 documentation testing,测试关注于文档的正确性。文档测试有三大类分别是开发文件、用户文件、管理文件。1. 开发文件:可行性研究报告、软件需求说明书、数据要求说明
38、书、概要设计说明书、详细设计说明书、数据库设计说明书、模块开发卷宗。2.用户文件:用户手册、操作手册。3.管理文件:项目开发计划、测试计划、测试分析报告、开发进度月报、项目开发总结报告。软件测试中的文档测试主要是对相关的设计报告和用户使用说明进行测试,对于设计报告主要是测试程序与设计报告中的设计思想是否一致;对于用户使用说明进行测试时,主要是测试用户使用说明书中对程序操作方法的描述是否正确,重点是用户使用说明中提到的操作例子要进行测试,保证采用的例子能够在程序中正确完成操作。一般来说,文档是软件的重要组成部分,因此文档测试也是软件测试的主要内容。在软件的整个生命周期中会出现很多文档,通常可以把
39、文档粗略地分为三类:开发文档,管理文档和用户文档。由于文档与代码不同,不能直接运行,对于文档的测试通常只能以文档审查的方式进行。对于管理文档和审查通常归属于管理范畴,而不是软件测试范畴,因为对于管理文档审查的目的不是为了发现和消除用户所看到的软件中的缺陷,而是为了更好地管理软件开发的过程。对于开发文档,由于这些文档本身体现了所在开发阶段的软件实际形态,对于这些文档的测试实际上是早期软件测试的主要活动。用户文档是那些随程序一起交付给用户的文档,它们实际上是交付给用户的软件的重要组成部分。对于这些文档的测试是对最终软件产品测试的一部分。BB. 域测试域测试的英文是 domain testing,定
40、义参考等价划分测试( equivalence partition testing);一般分为单域测试和多域测试,其中单域测试包括设备测试和业务测试,设备测试包括测试某个系统的软交换设备、中继媒体网关设备、信令网关设备、接入媒体网关和 IAD等设备。等价类划分有两种不同的情况:有效等价类和无效等价类。设计时要同时考虑这两种等价类,因为软件不仅要能接收合理的数据,也要能经受意外的考验。一有效等价类:是指对于程序的规格说明来说是合理的、有意义的输入数据构成的集合。利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能。二无效等价类:与有效等价类的定义恰巧相反。CC.接口测试接口测试的英文是
41、interface testing,接口测试测试系统组件间接口的一种测试。接口测试的好处:由于接口测试代码本身就是用 junit(当然接口的类型不同,不一定是 Junit 来实现)来实现的,是属于自动化测试的范畴,因此必定也包含自动化测试所固有的优势。1) 提高测试质量软件开发的过程是一个持续集成和改进的过程,而每一次的改进都可能引进新 bug,因此当软件的一部,或者全部修改时,都需要对软件产品重新进行测试。其目的是要验证修改后的产品是符合需求的,而当没有自动化测试代码时,往往会由于各种各样的原因,回归不充分,导致 bug 遗漏。2) 提高测试效率软件系统的规模越来越大,功能点越来越多,开发人
42、员的自测或者测试人员的人工测试非常耗时和繁琐,势必导致测试效率的低下,而自动化测试正好解决这些耗时繁琐的任务,在对外接口功能不变的情况下,达到了一次编写,永久使用的效果。3) 提高测试覆盖通过手工测试很难测试到一些更深层次的异常和安全的问题,通过一些辅助的一些测试工具,能分析出代码的覆盖率,通过覆盖率的提高来提高测试的深度。4) 更好地重现软件缺陷由于每次执行都是相同的代码,一旦代码出错,必定回归出错5) 更好定位错误由于接口测试是一种自下向上的测试,因此一量出错,非常容易定位出错,不向系统测试那样了,一旦有 Bug,需要几层验证之后才能确定出错位置6) 降低修改 bug 的成本接口测试基本和
43、开发人员的编码平行工作,因此发现问题会比系统测试早很多,因此减少了修改 bug 的成本。7) 增进测试人员和开发人员之间的合作关系,测试工程师 为了更好地开展工作,需要对开发技术有深入的理解和实践,有了与开发工程师更多的交流。8) 降低了项目不能按时发布的风险由于接口测试很早就介入,在提交给系统测试前对项目代码的核心模块已经做了详尽的测试,必定加速系统测试的时间,由此来保证项目的按时发布。9)提升测试人员的技能。做接口测试必须了解开发人员的开发流程和一些开发技能,也需要了解测试工具的一些使用方法和一些测试思想,提升了测试人员的技术附加值,提高了自身的竞争力。10)促使项目开发过程的规范化要进行
44、接口,需要完善的文档进行保障,没有测试文档,接口测试将寸步难行,接口测试将增加开发过程规范化产出,而规范化产出也保证了项目质量。DD.逆向测试逆向测试/反向测试/负面测试的英文是 Negative Testing,测试瞄准于使系统不能工作。负面测试与正面测试的比较:负面测试(Negative testing)是相对于正面测试(Positive testing)而言的。它们也是测试设计时的两个非常重要的划分。简单点说,正面测试就是测试系统是否完成了它应该完成的工作;而负面测试就是测试系统是否不执行它不应该完成的操作。形象一点,正面测试就象一个毕恭毕敬的小学生,老师叫我做什么,我就做什么;而负面测
45、试就象一个调皮捣蛋的孩子,你叫我这样做,我偏不这样做,而且和你对着干。开发人员也是最讨厌修改此类 bug 的。EE. 非功能性非功能性需求测试的英文是 non-functional requirements testing ,是与功能不相关的需求测试,如:性能测试、可用性测试等。为什么非功能性需求很重要?在您设计解决方案的过程中满足功能性需求当然是很重要的。但是,如果没有考虑非功能性需求,您的解决方案则很难取得实效。非功能性需求特点:1.不要脱离实际环境;2.可靠性;3.可用性;4. 有效性;5.可维护性;6.可移植性。FF. 极限测试简介极限测试本质上是为了满足极限测试的思想和流程而设计的一
46、套测试策略和流程,其本身并不局限于使用特定的测试技术和方法。III. 软件测试的基本流程测试需求分析,测试计划编写,测试用例编写,测试,缺陷记录,回归测试,判断测试结束,测试报告提交。测试流程依次如下:1. 需求:阅读需求,一:单元测试、集成测试、系统测试和验收测试(确认测试);理解需求,与客户、开发、架构多方交流,深入了解需求。-testing team2. 测试计划: 根据需求估算测试所需资源(人力、设备等)、所需时间、功能点划分、如何合理分配安排资源等。-testing leader or testing manager3. 用例设计:根据测试计划、任务分配、功能点划分,设计合理的测试用
47、例。-testing leader, senior tester4. 执行测试:根据测试用例的详细步骤,执行测试用例。-every tester(主要是初级测试人员)5. 执行结果记录和 bug记录:对每个 case记录测试的结果,有 bug的在测试管理工具中编写 bug记录。-every tester(主要是初级测试人员)6. defect tracking:追踪 leader分配给你追踪的 bug.直到 bug fixed。-every tester7. 测试报告:通过不断测试、追踪,直到被测软件达到测试需求要求,并没有重大 bug.8.用户体验、软件发布等IV.什么是缺陷一切不满足用户需
48、求的都是缺陷。下面我们对缺陷的概念在详细的介绍一下。1、软件未达到产品说明书标明的功能。2、软件出现了产品说明书中指明不会出现的错误。3、软件功能超出了产品说明书指明的范围。4、软件未达到产品说明书中虽未指出但应达到的目标。5、软件测试员认为软件难以理解、不易使用、运行速度缓慢,或最终用户认为不好。关于这 5 点我们举例来说明一下。第一点,比如说我们开发一个记事本的软件,说明书中明确说了可以输入文字,结果开发的软件不具备输入文本的功能,肯定就是一个 defect 了。第二点,说明书中明确说了在记事本软件中输入“联通” 可以正确的保存并打开浏览,结果我们的记事本软件打开保存了的输入“联通” 的文
49、件出 现了乱码,这也是一个 defect了。第三点,比如说我们的说明书中没有定义记事本会自动的对关键字高亮显示(这个主要是针对编程语言),结果我们的记事本程序自动对关键字高亮显示了,这也是 defect,尽管这样对用户使用会更好,但是他超出了产品说明书中指明的功能范围,所以还是 defect。第四点 不太好说,所以就不用记事本举例了,原谅我,呵呵。比如在我国开发财务管理软件必须要符合财政部的规定,尽管说明书中一般不会指出,但是软件必须要符合这个规定,不然是不能发行使用的啊!第五点就好理解,因为测试员是第一个使用软件的,必须要从客户的角度来对待,尽管这里会有主观感觉,但还是要尽量客观 (就是多参考一些标准,例如定义界面的,检察易用性的标准),比如在 Windows下的程序对话框中“是”按钮都是在左边,“否”按钮在右边,如果发现在 我们的记事本程序中,提示是否保存文件的对话框里“是”按钮在右边了,这就是一个 defect 了,因为它不符合 Windows 下用户的使用习惯。知道了什么是缺陷,我们就再来看看怎么去描述一个缺陷吧,看看缺陷都有哪些属性。二、缺陷的属性(1)、缺陷标识:就是缺陷的编号了,每个缺陷有一个唯一的编号。(2)、缺陷类型:这是一个功能性还是性能的 bug,是文档的还是界面的