1、软件测试面试题整理 01. 为什么要在一个团队中开展软件测试工作? 因为没有经过测试的软件很难在发布之前知道该软件的质量,就好比 ISO 质量认证一样,测 试同样也需要质量的保证,这个时候就需要在团队中开展软件测试的工作。在测试的过程发 现软件中存在的问题,及时让开发人员得知并修改问题,在即将发布时,从测试报告中得出 软件的质量情况。 02. 您在以往的测试工作中都曾经具体从事过哪些工作?其中最擅长哪部分工作? 我曾经做过 web 测试,后台测试,客户端软件,其中包括功能测试,性能测试,用户体验测 试。最擅长的是功能测试 03. 您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同 04.
2、的测试类型的区别 与联系(如功能测试、性能测试?) 测试类型有:功能测试,性能测试,界面测试。功能测试在测试工作中占的比例最大,功能测试也叫黑盒测试。是把测试对象看作一个黑盒 子。利用黑盒测试法进行动态测试时,需要测试软件产品的功能,不需 测试软件产品的内部 结构和处理过程。采用黑盒技术设计测试用例的方法有:等价类划分、边界值分析、错误推 测、因果图和综合策略。 性能测试是通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性 能指标进行测试。 负载测试和压力测试都属于性能测试, 两者可以结合进行。 通过负载测试, 确定在各种工作负载下系统的性能,目标是测试当负载逐渐增加时,系
3、统各项性能指标的变 化情况。压力测试是通过确定一个系统的瓶颈或者不能接收的性能点,来获得系统能提供的 最大服务级别的测试。 界面测试,界面是软件与用户交互的最直接的层,界面的好坏决定用户对软件的第一印象。 而且设计良好的界面能够引导用户自己完成相应的操作,起到向导的作用。同 时界面如同人 的面孔,具有吸引用 户的直接优势。设计合理的界面能给用户带来轻松愉悦的感受和成功的 感觉,相反由于界面设计的失败,让用户有挫败感,再 实用强大的功能都可能在用户的畏惧 与放弃中付诸东流。 区别在于,功能测试关注产品的所有功能上,要考虑到每个细节功能,每个可能存在的功能 问题。性能测试主要关注于产品整体的多用户
4、并发下的稳定性和健壮性。界面测试更关注于 用户体验上,用 户使用该产品的时候是否易用,是否易懂,是否规范(快捷键之类的) ,是否 美观(能否吸引用户的注意力) ,是否安全(尽量在前台避免用户无意输入无效的数据,当然 考虑到体验性, 不能太粗鲁的弹出警告) ?做某个性能测试的时候, 首先它可能是个功能点, 首先要保证它的功能是没问题的,然后再考虑该功能点的性能测试04您认为做好测试用例设计工作的关键是什么? 白盒测试用例设计的关键是以较少的用例覆盖尽可能多的内部程序逻辑结果 黑盒法用例设计的关键同样也是以较少的用例覆盖模块输出和输入接口。不可能做到完全测 试,以最少的用例在合理的时间内发现最多的
5、问题 05. 请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区 别与联系。 黑盒 测试:已知产品的功能设计规格,可以进行测试证明每个实现了的功能是否符合要求。白盒测试:已知产品的内部工作过程,可以通过测试证明每种内部操作是否符合设计规格要 求,所有内部成分是否以经过检查。 软件的黑盒测试意味着测试要在软件的接口处进行。 这种方法是把测试对象看做一个黑盒子, 测试人员完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求规格说明书,检查 程序的功能是否符合它的功能说明。因此黑盒测试又叫功能测试或数据驱动测试。黑盒测试 主要是为了发现以下几类错误: 1、是否有不正确或
6、遗漏的功能? 2、在接口上, 输入是否能正确的接受?能否输出正确的结果? 3、是否有数据结构错误或外部信息(例如数据文件)访问错误? 4、性能上是否能够满足要求? 5、是否有初始化或终止性错误? 软件的白盒测试是对软件的过程性细节做细致的检查。这种方法是把测试对象看做一个打开 的盒子,它允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程 序所有逻辑路径进行测试。通 过在不同点检查程序状态,确定实际状态是否与预期的状态一 致。因此白盒测试又称为结构测试或逻辑驱动测试。白盒测试主要是想对程序模块进行如下 检查: 1、对程序模块的所有独立的执行路径至少测试一遍。 2、对所有的逻辑
7、判定,取“真”与取“ 假”的两种情况都能至少测一遍。 3、在循环的边界和运行的界限内执行循环体。 4、测试内部数据结构的有效性,等等。 单元测试(模块测试)是开发者编写的一小段代码,用于 检验被测代码的一个很小的、很明 确的功能是否正确。通常而言,一个 单元测试是用于判断某个特定条件(或者场景)下某个 特定函数的行为。 单元测试是由程蛟弊约豪赐瓿桑 钪帐芤娴囊彩浅绦蛟弊约骸?梢哉饷此担 绦蛟庇性鹑?编写功能代码,同时也就有责任为自己的代码编写单元测试。执行单元测试,就是为了证明 这段代码的行为和我们期望的一致。 集成测试(也叫组装测试,联合测试)是单元测试的逻辑扩展。它的最简单的形式是:两个
8、已经测试过的单元组合成一个组件,并且测试它们之间的接口。从这一层意义上讲, 组件是 指多个单元的集成聚合。在 现实方案中,许多单元组合成组件,而这些组件又聚合成程序的 更大部分。 方法是测试片段的组合, 并最终扩展进程, 将您的模块与其他组的模块一起测试。 最后,将构成进程的所有模块一起测试。 系统测试是将经过测试的子系统装配成一个完整系统来测试。它是检验系统是否确实能提供 系统方案说明书中指定功能的有效方法。 (常见的联调测试) 系统测试的目的是对最终软件系统进行全面的测试,确保最终软件系统满足产品需求并 且遵循系统设计。 验收测试是部署软件之前的最后一个测试操作。验收测试的目的是确保软件准
9、备就绪,并且 可以让最终用户将其用于执行软件的既定功能和任务。 验收测试是向未来的用户表明系统能够像预定要求那样工作。经集成测试后,已经按照设计 把所有的模块组装成一个完整的软件系统,接口错误也已经基本排除了,接着就应该进一步 验证软件的有效性,这就是验收测试的任务,即软件的功能和性能如同用户所合理期待的那 样。 06. 测试计划工作的目的是什么?测试计划工作的内容都包括什么?其中哪些是最重要的? 软件测试计划是指导测试过程的纲领性文件,包含了产品概述、测试策略、 测试方法、测试区域、测试配置、测试周期、测试资源、 测试交流、风险分析等内容。借助软件测试计划, 参与测试的项目成员,尤其是 测试
10、管理人员,可以明确测试任务和测试方法,保持测试实施 过程的顺畅沟通,跟踪和控制测试进度,应对测试过程中的各种变更。测试计划和测试详细规格、测试用例之间是战略和战术的关系,测试计划主要从宏观上规划 测试活动的范围、 方法和资源配置, 而测试详细规格、 测试用例是完成测试任务的具体战术。 所以其中最重要的是测试测试策略和测试方法(最好是能先评审) 07. 您认为做好测试计划工作的关键是什么? 1. 明确测试的目标,增强测试计划的实用性 编写软件测试计划得重要目的就是使测试过程能够发现更多的软件缺陷,因此软件测试计划 的价值取决于它对帮助管理测试项目,并且找出软件潜在的缺陷。因此,软件测试计划中的 测试范围必须高度覆盖功能需求, 测试方法必须切实可行, 测试工具并且具有较高的实用性, 便于使用,生成的测试结果直观、准确 2坚持“5W”规则,明确