软件测试基础(经典测试面试题答案)

上传人:nu****n 文档编号:156076331 上传时间:2022-09-25 格式:DOC 页数:41 大小:239.51KB
收藏 版权申诉 举报 下载
软件测试基础(经典测试面试题答案)_第1页
第1页 / 共41页
软件测试基础(经典测试面试题答案)_第2页
第2页 / 共41页
软件测试基础(经典测试面试题答案)_第3页
第3页 / 共41页
资源描述:

《软件测试基础(经典测试面试题答案)》由会员分享,可在线阅读,更多相关《软件测试基础(经典测试面试题答案)(41页珍藏版)》请在装配图网上搜索。

1、软件测试基础教程测试的基本概念测试是软件生存周期中十分重要的一个过程,是产品发布、提交给最终用户前的稳定化阶段。 1、 测试的分类:从测试方法的角度可以分为手工测试和自动化测试。手工测试:不使用任何测试工具,根据事先设计好的测试用例来运行系统,测试各功能模块。自动化测试:利用测试工具,通过编写测试脚本和输入测试数据,自动运行测试程序。目前最常用的自动化测试工具是基于GUI的自动化测试工具,基本原理都是录制、回放技术。从整体的角度可以分为单元测试、集成测试、系统测试、确认测试。单元测试:是针对软件设计的最小单位程序模块,进行正确性检验的测试工作。一般包括逻辑检查、结构检查、接口检查、出错处理、代

2、码注释、输入校验、边界值检查。单元测试的依据是系统的详细设计;一般由项目组开发人员自己完成。集成测试:在单元测试的基础上,将所有模块按照设计要求组装进行测试。一般包括逻辑关系检查、数据关系检查、业务关系检查、模块间接口检查、外部接口检查。系统测试:系统测试是在所有单元、集成测试后,对系统的功能及性能的总体测试。确认测试:模拟用户运行的业务环境,运用黑盒测试方法,验证软件系统是否满足用户需求或软件需求说明书中指明的软件特性(功能、非功能)上的。从测试原理上分为:白盒测试、黑盒测试和灰盒测试。白盒测试:是通过程序的源代码进行测试而不使用用户界面。这种类型的测试需要从代码句法发现内部代码在算法,溢出

3、,路径,条件等等中的缺点或者错误,进而加以修正。黑盒测试:是通过使用整个软件或某种软件功能来严格地测试, 而并没有通过检查程序的源代码或者很清楚地了解该软件的源代码程序具体是怎样设计的。测试人员通过输入他们的数据然后看输出的结果从而了解软件怎样工作。在测试时,把程序看作一个不能打开的黑盆子,在完全不考虑程序内部结构和内部特性的情况下,测试者在程序接口进行测试,它只检查程序功能是否按照需求规格说明书的规定正常使用,程序是否能适当地接收和正确的输出。黑盒测试方法主要有等价类划分、边界值分析、因果图、错误推测法。等价类划分:是把所有可能的输入数据,即程序的输入域划分成若干部分(子集),然后从每一个子

4、集中选取少数具有代表性的数据作为测试用例.该方法是一种重要的,常用的黑盒测试用例设计方法. 1) 划分等价类: 等价类是指某个输入域的子集合.在该子集合中,各个输入数据对于揭露程序中的错误都是等效的.并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试.因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据.取得较好的测试结果.等价类划分可有两种不同的情况:有效等价类和无效等价类.有效等价类:是指对于程序的规格说明来说是合理的,有意义的输入数据构成的集合.利用有效等价类可检验程序是否实现了规格说明中所规定的功能和性能.无

5、效等价类:与有效等价类的定义恰巧相反.设计测试用例时,要同时考虑这两种等价类.因为,软件不仅要能接收合理的数据,也要能经受意外的考验.这样的测试才能确保软件具有更高的可靠性.边界值分析:长期的测试工作经验告诉我们,大量的错误是发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部.因此针对各种边界情况设计测试用例,可以查出更多的错误。错误推测法:基于经验和直觉推测程序中所有可能存在的各种错误, 从而有针对性的设计测试用例的方法.错误推测方法的基本思想: 列举出程序中所有可能有的错误和容易发生错误的特殊情况,根据他们选择测试用例. 例如, 在单元测试时曾列出的许多在模块中常见的错误. 以前

6、产品测试中曾经发现的错误等, 这些就是经验的总结. 还有, 输入数据和输出数据为0的情况. 输入表格为空格或输入表格只有一行. 这些都是容易发生错误的情况. 可选择这些情况下的例子作为测试用例。灰盒测试:灰盒测试就像黑盒测试一样是通过用户界面测试,但是测试人员已经有所了解该软件或某种软件功能的源代码程序具体是怎样设计的。甚至于还读过部分源代码。因此测试人员可以有真对性地进行某种确定的条件/功能的测试。从软件特性上分为功能测试和性能测试。功能测试:是指为了确保软件系统功能实现的正确性,完整性和其他特性而进行的测试。性能测试:是指为了评估软件系统的性能状况,和预测软件系统性能趋势而进行的测试和分析

7、。2、 BUG的定义:BUG:(小错误,缺陷,不足,过失 ) 一个计算机bug指在计算机程序中存在的一个错误(error)、缺陷(flaw)、疏忽(mistake)或者故障(fault),这些bug使程序无法正确的运行。Bug产生于程序的源代码或者程序设计阶段的疏忽或者错误。Defect:(缺陷) 在软件工程(Software Engineering)中,软件与它的需求(requirements)不一致,常常指软件无法正确完成需求所要求的功能,也称之为bug。Fault:(故障)被定义为存在于组件、设备或者子系统中异常的条件或者缺陷,常常会导致系统的失败。Error:(错误) 一个error是

8、指编写错误的代码,通常是无意中造成的。一般有两类主要的错误,一是语法错误(syntax error),该类错误易于检测,因为代码在编译阶段无法解析而不能正常编译通过。另一个是逻辑错误(logical error),因为它与代码的实际执行密切相关所以不易发现。二、 项目测试的规划项目测试内容:将项目测试分为项目开发阶段测试和项目完工验收测试两个部分。开发阶段测试内容主要包括:模块功能测试、集成测试和文档检查。模块功能测试:确保系统各功能模块能够正常运行,数据的IPO符合系统设计的要求。单元和模块功能满足需求定义。集成测试:系统各模块组装后,根据业务流程的要求,能够正确地完成各业务功能,并且数据的

9、处理和输出正确。文档检查:在项目开发阶段,按照项目进度表,根据项目文档测试规范与标准,对提交的项目文档和记录(技术文档和管理文档)进行检查和验证,以符合公司质量体系和项目制度的要求,对于技术类文档的关键要素,验证是否能够达到通过标准。完工验收测试内容主要包括:安装测试、功能验证、性能测试、需求验证、文档测试。完工验收测试实际上是项目在结项前的一个全面的检查和验证。可以作为项目结项的依据和放行条件。需求测试:检查软件产品是否满足该项目的需求说明书中规定的功能需求,检查需求的完整性、一致性、最新性,该项测试重点是需求满足的完整性。安装测试:根据项目提供的安装文档中的安装步骤,搭建系统运行环境,检查

10、系统安装过程是否正确。可能包括数据库服务器的安装与配置、应用服务器、控件注册、客户端的安装与配置、应用软件的安装。功能验证:按照需求说明书和系统概要设计,逐项检查各项功能(功能单元、功能模块)的可运行性和正确性。文档测试:文档测试从项目立项时就开始了,实际上就是文档检查,包括规范性检查和有效性检查。目的是使项目相关的文档和记录既规范又有意义,不是为了应付的无用文件。对于技术文档如:需求说明书、概要设计、详细设计等,在技术评审时也进行了评测。用户文档,如安装手册、用户操作手册,根据文档检查规范进行。性能测试:这部分测试的来源,严格来讲,取决于用户对软件特性的一些特定要求,另外,就是公司的开发部门

11、对产品的一些基本的性能要求。若用户从业务的角度考虑,对软件产品本身有特定的非功能要求,则必须在软件需求说明书中加以说明,使之具有可度量和可测试性。对于一些多用户环境或数据处理能力和负载方面的测试,很难通过手工搭建测试环境来测试,所以可以参考使用一些专门的性能测试工具和手工测试相结合的方式。项目测试的基本流程:1、 项目测试启动:项目立项后,在测试配置库中创建项目。2、 测试计划:系统详细设计后,制定测试计划,准备测试资源。3、 设计测试用例,主要是与业务相关的测试用例。4、实施功能模块测试,搭建运行或开发环境,采用功能模块测试表的方式,开发人员在功能模块测试表中更新进度状态,测试人员在该表中描

12、述测试进度。形成测试错误列表,该表对每个错误都有相应的测试记录与之链接,在测试记录中,详细描述错误的情况。在测试记录中还要包括修正信息和验证信息。5、错误关闭后,测试人员维护测试记录表和更新测试用例库和问题库,作为经验积累。6、项目在结项时,测试人员进行项目完工验收测试,填写项目测试报告。该测试报告可作为用户验收的输入工件。三、 功能测试方法与内容1、数据输入测试:向系统输入数据或输入数据库操作命令时,一般是测试系统对数据库中数据操作的过程。数据类型测试:由于不同的数据库系统对数据类型要求的不同,在定义数据库表时,也规定了数据字段的数据类型。测试步骤和方法:在系统的数据维护功能界面上,录入或修

13、改数据时,特意输入非系统设计的数据类型,检查系统是否可以接受,若不能接受则检查是否满足了系统在这方面的设计要求,如即刻清除非法内容、输入焦点不能到下一输入位置、出现系统自定义的提示信息、不允许出现开发工具的报错信息等。若系统可以接受并保存,则要看数据库表的字段类型设计是否与用户或习惯上不一致,并且要注意其他模块在调取该数据时,是否有特定要求。边界值测试:根据数据取值范围的要求,输入符合取值范围的数据、取值范围的上、下限和超过取值范围的数据。注意,除要测试数据库系统本身数据类型取值范围外,还要根据软件系统设计中的一些特定要求,设计测试用例来测试。数据合法性测试:测试人员除了要测试输入数据是否满足

14、所使用数据库系统本身的数据类型和取值范围的要求外,还应该根据经验和软件系统和需求的特定要求检查输入数据的合法性。比如:日期合法性(出生年月、参保日期、发生时间、根据习惯和业务逻辑顺序对日期合理性的要求等)。工资、比例、率等,都要注意输入的合理、合法性。单引号和双引号:不要忽略输入单引号和双引号可能引起的错误和数据问题。在功能录入界面上,在某字段的输入框输入了包括单引号和双引号的数据,以后在通过Select 语句查询时可能会出问题。特别在基于WEB方式的系统,输入了单引号,在查询数据记录时,肯定会出现页面链接错误(页面无法链接或找不到或链接对象错误)。空值测试:在测试数据录入或修改的功能界面时,

15、若不输入任何东西,系统又没有设计成NOT NULL,则这时,要非常注意其影响。因为数据可以正常保存,但数据表该字段是空值,那么所有与该字段有关的操作,如:查询(AND)、计算(累加、连乘)等,则可能出现数据问题(计算结果为0,无记录返回)。对于测试人员首先要检查系统到底是作为空值,还是作为空串或空字符处理。另外对于允许不输入任何值的字段,在测试过程中,要检查是否在界面显示或打印报表时,这些字段作为了关键要素或标题等情况。空格:在数据维护的功能界面上,输入数据时,要注意是否在输入位置有空格,首先看系统设计时,是怎么考虑的,若系统允许输入空格,则检查条件查询或作为调用参数时的数据返回情况;另外检查

16、程序是否使用了去掉空格的函数。数据校验的不一致:测试时,对于一些编号、编码、代码等主键或作为查询或调用条件的字段,要注意系统对他们的输入合法性检查与查询或调用条件的要求是否是一致的。特别是对于数据结构设计中没有特定约束,而由程序进行校验控制的情况。分析:数据输入测试的主要目的是保证输入到系统中数据的合法、合理性。我觉得,数据输入过程的检查是非常重要的,若在编程过程中,不注重数据的校验功能,虽然看起来加快了开发进度,但给以后会带来一些不可预计的编程或维护工作量。2、目录路径测试:测试系统中规定的路径要求,更改路径,检查系统的是否可以正确运行及系统的排错功能。测试时,根据系统设计说明书(详细设计)

17、或通过对程序源代码的熟悉,找出系统运行过程中指定的路径或在运行过程中,需要使用者选择路径的地方。特意更改路径(选择正确的路径、选择另外的路径、输入不存在的路径)。检查系统是否具有路径上的容错性和灵活性。比如,原则上在程序中,最好不要写绝对路径,另外可以提供配置路径的对话框,若输入了非法路径,系统有无提示等。3、 数据操作测试:包括数据操作测试和用户界面操作的测试。修改、新增数据:对于新增和修改数据,要注重以下几个方面的测试。界面上,新增数据成功后,数据列表是否立即刷新,输入有错误时,是否清空错误的数据,输入焦点是否得以控制。在提示信息上,是否有保存成功的提示,输入有错误时,提示的错误信息是否准

18、确,可读。数据方面,要通过SQL检查数据提交是否正确。删除数据:测试删除记录时,系统是否有确认提示,能否批量删除,根据系统详细设计,检查删除主表记录时,在业务上,其他相关表是否相应更改。事物的提交与回滚:熟悉C/S模式开发或数据库应用系统开发的人都知道,数据库事物的概念。对于一个比较复杂的业务逻辑或业务上有数据一致和完整性要求时,尽量使用事物对数据进行提交,这样一旦由于意外原因引起系统或硬件故障时,可以回滚。根据系统的设计要求在测试时,可人为模拟意外故障,来测试系统的数据完整性和容错能力。4、工具条和快捷键测试:在功能界面测试时,对系统菜单中定义的快捷键和菜单工具条中的工具按钮要测试。主要是有

19、效性和一致性测试。有效性:检查是否有效,界面有无反应。一致性:定义或提示的信息是否与实际完成的功能一致。5、 操作顺序测试按钮顺序测试:在功能界面上,不按照设计上或习惯上的操作顺序点击功能按钮,看系统有什么反应;多次、反复点击某一按钮,看系统有什么反应。主要是测试系统的控制、校验和容错能力。业务逻辑顺序:不按照系统的正常业务逻辑、流程操作,来测试系统是否控制了业务流程的顺序。6、按钮有效性控制测试:主要是测试当不具备条件或无实际意义的情况下,按钮的“Enabled”属性。比如:某一业务未处理,下一环节的功能按钮则应变灰(不可用)。逐条显示数据记录,当游标已经指到了最后一条时,“下一条”和“末记

20、录”按钮则应变灰等。7、同时刻操作测试:对于删除、修改、增加数据和一些业务功能,进行多客户端同时刻操作测试,看系统有什么反应。8、附件压力测试:对于有发送、上传、下载、邮件等功能的系统,选取大的文件,进行测试,来检查系统的界面效果和稳定性,看是否会死机或长时间无任何反应等。9、 数据输出测试:数据处理输出测试:主要测试对数据的排序、条件查询是否按照输入的条件或要求输出了正确的数据。打印输出:测试打印功能是否能够正常打印出报表,打印设置后,是否能按照设置的要求打印。10、WEB测试:基于WEB方式的应用,对于一些提交表单的页面,通过多次点击“back”键,来测试系统的处理情况。对于有保存数据功能

21、的页面,多次点击“保存”,来测试系统的处理情况。软件测试面试题汇总测试技术面试题51、什么是兼容性测试?兼容性测试侧重哪些方面?52、我现在有个程序,发现在Windows上运行得很慢,怎么判别是程序存在问题还是软硬件系统存在问题?53、测试的策略有哪些?54、正交表测试用例设计方法的特点是什么?55、描述使用bugzilla缺陷管理工具对软件缺陷(BUG)跟踪的管理的流程?56、你觉得bugzilla在使用的过程中,有什么问题?57、描述测试用例设计的完整过程?68、单元测试的策略有哪些?69、LoadRunner分哪三部分?610、LoadRunner进行测试的流程?6什么是并发?在lord

22、runner中,如何进行并发的测试?集合点失败了会怎么样?612、使用QTP做功能测试,录制脚本的时候,要验证多个用户的登录情况/查询情况,如何操作?613、QTP中的Action有什么作用?有几种?614、TestDirector有些什么功能,如何对软件测试过程进行管理?715、你所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试)?716、条软件缺陷(或者叫Bug)记录都包含了哪些内容?如何提交高质量的软件缺陷(Bug)记录?817、Beta测试与Alpha测试有什么区别?818、软件的评审一般由哪些人参加?其目的是什么?819、测试活动中,如

23、果发现需求文档不完善或者不准确,怎么处理?820、阶段评审与项目评审有什么区别?821、阐述工作版本的定义?822、什么是桩模块?什么是驱动模块?823、什么是扇入?什么是扇出?824、你认为做好测试计划工作的关键是什么?825、你认为做好测试用例工作的关键是什么?926、简述一下缺陷的生命周期?927、软件的安全性应从哪几个方面去测试?928、软件配置管理工作开展的情况和认识?929、你觉得软件测试通过的标准应该是什么样的?1030、引入测试管理的含义?1031、一套完整的测试应该由哪些阶段组成?1032、单元测试的主要内容?1033、集成测试也叫组装测试或者联合测试,请简述集成测试的主要内

24、容?1034、简述集成测试与系统测试关系?1035、软件测试的文档测试应当贯穿于软件生命周期的全过程,其中用户文档是文档测试的重点。那么软件系统的用户文档包括哪些?1036、软件系统中除用户文档之外,文档测试还应该关注哪些文档?1037、简述软件系统中用户文档的测试要点?1138、单元测试主要内容是什么?1139、如何理解强度测试?1340、如何理解压力、负载、性能测试测试?1341、什么是系统瓶颈?1342、文档测试主要包含什么内容?1343、功能测试用例需要详细到什么程度才是合格的?1444、配置和兼容性测试的区别是什么?1445、软件文档测试主要包含什么?1546、没有产品说明书和需求文

25、档地情况下能够进行黑盒测试吗?1547、测试中的“杀虫剂怪事”是指什么?1548、在配置测试中,如何判断发现的缺陷是普通问题还是特定的配置问题?1549、为什么尽量不要让时间有富裕的员工去做一些测试?1650、完全测试程序是可能的吗?1651、软件测试的风险主要体现在哪里?1652、发现的缺陷越多,说明软件缺陷越多吗?1653、所有的软件缺陷都能修复吗?所有的软件缺陷都要修复吗?1754、软件测试人员就是QA吗?1755、如何减少测试人员跳槽带来的损失?1756、测试产品与测试项目的区别是什么?1757、和用户共同测试(UAT测试)的注意点有哪些?1858、如何编写提交给用户的测试报告?185

26、9、测试工具在测试工作中是什么地位?1860、什么是软件测试,软件测试的目的?1861、简述负载测试与压力测试的区别。1962、写出bug报告流转的步骤,每步的责任人及主要完成的工作。1963、写出bug报告当中一些必备的内容。1964、开发人员老是犯一些低级错误怎么解决?2065、画出软件测试的V模型图。2066、为什么要在一个团队中开展软件测试工作?2067、您在以往的测试工作中都曾经具体从事过哪些工作?其中最擅长哪部分工作?2068、您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试)2069、您认为做好测试用例设计工作的关键是什么?217

27、0、请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。2171、测试计划工作的目的是什么?测试计划工作的内容都包括什么?其中哪些是最重要的?2272、您所熟悉的测试用例设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。2273、请以您以往的实际工作为例,详细的描述一次测试用例设计的完整的过程。2374、您以往是否曾经从事过性能测试工作?如果有,请尽可能的详细描述您以往的性能测试工作的完整过程。2375、你对测试最大的兴趣在哪里?为什么?2376、你以前工作时的测试流程是什么?2477、当开发人员说不是BUG时,你如何应付?2478

28、、软件的构造号与版本号之间的区别?BVT(BuildVerificationTest)2479、您以往的工作中,一条软件缺陷(或者叫Bug)记录都包含了哪些内容?如何提交高质量的软件缺陷(Bug)记录?2580、您以往所从事的软件测试工作中,是否使用了一些工具来进行软件缺陷(Bug)的管理?如果有,请结合该工具描述软件缺陷(Bug)跟踪管理的流程。2581、您认为性能测试工作的目的是什么?做好性能测试工作的关键是什么?2582、单元测试、集成测试、系统测试的侧重点是什么?2583、集成测试通常都有那些策略?2584、一个缺陷测试报告的组成2585、基于WEB信息管理系统测试时应考虑的因素有哪些

29、?2586、软件测试项目从什么时候开始,?为什么?2687、需求测试注意事项有哪些?2688、简述一下缺陷的生命周期2689、你在你所在的公司是怎么开展测试工作的?是如何组织的?2690、你认为理想的测试流程是什么样子?2691、您在从事性能测试工作时,是否使用过一些测试工具?如果有,请试述该工具的工作原理,并以一个具体的工作中的例子描述该工具是如何在实际工作中应用的。2692、软件测试活动的生命周期是什么?2693、请画出软件测试活动的流程图?2694、针对缺陷采取怎样管理措施?2695、什么是测试评估?测试评估的范围是什么?2696、如果能够执行完美的黑盒测试,还需要进行白盒测试吗?为什么

30、?2697、测试结束的标准是什么?2698、软件验收测试除了alpha ,beta测试以外,还有哪一种?2699、做测试多久了?以前做过哪些项目?你们以前测试的流程是怎样的?用过哪些测试工具?27100、请就如何在开发中进行软件质量控制说说你的看法27101、一套完整的测试应该由哪些阶段组成?分别阐述一下各个阶段。27102、软件测试的类型有那些?分别比较这些不同的测试类型的区别与联系。27103、测试用例通常包括那些内容?着重阐述编制测试用例的具体做法27104、在分别测试winform的C/S结构与测试WEB结构的软件是,应该采取什么样的方法分别测试?他们存在什么样的区别与联系?27105

31、、在测试winform的C/S结构软件时,发现这个软件的运行速度很慢,您会认为是什么原因?您会采取哪些方法去检查这个原因?27106、描述使用bugzilla缺陷管理工具对软件缺陷(BUG)跟踪的管理的流程27107、你都用什么测试方法 针对不同的产品或者系统或者模块,有不同的测试方法。总体而言有白盒测试和黑盒测试。27108、怎么编写案例 案例的编写与测试阶段的定义有很大的关系。系统测试和unit测试的案例可能不同。总体而言测试案例根据系统的需求而定。27109、怎么才能够全面的测试到每一个点 测试的全面性主要需要在设计测试计划的时候考虑,从测试策略,产品需求等等多个角度考虑从而定义全部的测

32、试点。27110、谈谈软件测试技术,以及如何提高27111、谈谈软件测试职业发展,以及个人的打算27112、谈谈软件测试在企业的地位,也可以结合软件生命周期来谈27113、一般公司里实际的软件测试流程是什么样的?你们公司又是怎样的?27114、软件工程师要具有那些素质?27115、你会哪些测试工具?怎么操作?27116、你能不能说下你的3到5年的职业计划(规划)27117、你觉得你来应聘有那些优势?27其他问题:(有可能清晰的思路比确切的答案更重要)27开发及环境搭建类面试题281、描述软件产生内存泄露的原因以及检查方式。(可以结合一种开发语言进行描述)282、简述什么是值传递,什么是地址传递

33、,两者区别是什么?283、结构化程序设计和面向对象程序设计各自的特点及优缺点是什么?284、简述什么是存储过程和触发器?285、使用C语言编写一个函数,用于交换两个变量的值(地址传递)。296、请简述DNS、活动目录、域的概念。297、描述TCP/IP协议的层次结构,以及每一层中重要协议。298、简述子网掩码的用途。299、说出4种以上常用的操作系统及其主要的应用范围(微软的操作系统除外)。2910、在Linux系统中,一个文件的访问权限是755,其含义是什么?2911、Windows操作系统中PATH环境变量的作用是什么?3012、Ghost的主要用途和常用方法?3013、在RedHat中,

34、从root用户切到userl用户,一般用什么命令?3014、Linux中,一般怎么隐藏文件?3015、如何将自己的本地磁盘(D)做成FTP供远端主机使用?3016、对RUP.CMM,CMMI,XP,PSP.TSP的认识?3017、DNS是什么,它是如何工作的?3118、防火墙如何保证安全的?主要有哪些?3119、目前流行的操作的系统有哪些?请举例说明安装操作系统的注意事项?3320、简述一下c/s模式或者b/s模式?3321、TCP/UDP有哪些区别?3422、ISO模型?HUB、tch、Router是ISO的第几层设备?3423、内存有哪几种存储组织结构.请分别加以说明?34人力资源面试题3

35、41、你的测试职业发展是什么?你自认为做测试的优势在哪里?342、你为什么想离开目前的职务?343、你对我们公司了解有多少?344、你找工作时,最重要的考虑因素为何?345、为什么我们应该录取你?346、请谈谈你个人的最大特色。347、一个测试工程师应具备那些素质和技能?358、您认为在测试人员同开发人员的沟通过程中,如何提高沟通的效率和改善沟通的效果?维持测试人员同开发团队中其他成员良好的人际关系的关键是什么?359、在您以往的测试工作中,最让您感到不满意或者不堪回首的事情是什么?您是如何来对待这些事情的?3510、在即将完成这次笔试前,您是否愿意谈一些自己在以往的学习和工作中获得的工作经验

36、和心得体会?(可以包括软件测试、过程改进、软件开发或者与此无关的其他方面)3511、为什么选择测试这行?3512、你的工作通常能在时限内完成吗.(我想问一下就是她问这个问题的动机是什么)3513、通常你对于别人批评你会有什么样的反应3514、如果明知这样做不对,你还会依主管的指过去做吗?3515、如果你接到一个客户抱怨的电话,你确知无法解决他的问题,你会怎么处理?3516、请就软件测试人员应该具备什么样的基本素质说说你的看法。3617、你在五年内的个人目标和职业目标分别是什么?3618、你怎样做出自己的职业选择?36测试技术面试题1、什么是兼容性测试?兼容性测试侧重哪些方面?参考答案:兼容测试

37、主要是检查软件在不同的硬件平台、软件平台上是否可以正常的运行,即是通常说的软件的可移植性。兼容的类型,如果细分的话,有平台的兼容,网络兼容,数据库兼容,以及数据格式的兼容。兼容测试的重点是,对兼容环境的分析。通常,是在运行软件的环境不是很确定的情况下,才需要做兼容。根据软件运行的需要,或者根据需求文档,一般都能够得出用户会在什么环境下使用该软件,把这些环境整理成表单,就得出做兼容测试的兼容环境了。兼容和配置测试的区别在于,做配置测试通常不是Clean OS下做测试,而兼容测试多是在Clean OS的环境下做的。2、我现在有个程序,发现在Windows上运行得很慢,怎么判别是程序存在问题还是软硬

38、件系统存在问题?参考答案:1、检查系统是否有中毒的特征;2、检查软件/硬件的配置是否符合软件的推荐标准;3、确认当前的系统是否是独立,即没有对外提供什么消耗CPU资源的服务;4、如果是C/S或者B/S结构的软件,需要检查是不是因为与服务器的连接有问题,或者访问有问题造成的;5、在系统没有任何负载的情况下,查看性能监视器,确认应用程序对CPU/内存的访问情况。3、测试的策略有哪些?参考答案:黑盒/白盒,静态/动态,手工/自动,冒烟测试,回归测试,公测(Beta测试的策略)4、正交表测试用例设计方法的特点是什么?参考答案:用最少的实验覆盖最多的操作,测试用例设计很少,效率高,但是很复杂;对于基本的

39、验证功能,以及二次集成引起的缺陷,一般都能找出来;但是更深的缺陷,更复杂的缺陷,还是无能为力的;具体的环境下,正交表一般都很难做的。大多数,只在系统测试的时候使用此方法。5、描述使用bugzilla缺陷管理工具对软件缺陷(BUG)跟踪的管理的流程?参考答案:就是Bugzilla的状态转换图。6、你觉得bugzilla在使用的过程中,有什么问题?参考答案:界面不稳定;根据需要配置它的不同的部分,过程很烦琐。流程控制上,安全性不好界定,很容易对他人的Bug进行误操作;没有综合的评分指标,不好确认修复的优先级别。7、描述测试用例设计的完整过程?参考答案:需求分析 + 需求变更的维护工作;根据需求 得

40、出测试需求;设计测试方案,评审测试方案;方案评审通过后,设计测试用例,再对测试用例进行评审;8、单元测试的策略有哪些?参考答案:逻辑覆盖、循环覆盖、同行评审、桌前检查、代码走查、代码评审、景泰数据流分析9、LoadRunner分哪三部分?参考答案:用户动作设计;场景设计;测试数据分析;10、LoadRunner进行测试的流程?参考答案:1、 测试测试2、 创建虚拟用户脚本3、 创建运行场景4、 运行测试脚本5、 监视场景6、 分析测试的结果以上,最好是结合一个案例,根据以上流程来介绍。什么是并发?在lordrunner中,如何进行并发的测试?集合点失败了会怎么样?参考答案:在同一时间点,支持多

41、个不同的操作。LoadRunner中提供IP伪装,集合点,配合虚拟用户的设计,以及在多台电脑上设置,可以比较好的模拟真实的并发。集合点,即是多个用户在某个时刻,某个特定的环境下同时进行虚拟用户的操作的。集合点失败,则集合点的才操作就会取消,测试就不能进行。12、使用QTP做功能测试,录制脚本的时候,要验证多个用户的登录情况/查询情况,如何操作?参考答案:分析用户登录的基本情况,得出一组数据,通过性测试/失败性测试的都有(根据TC来设计这些数据),然后录制登录的脚本,将关键的数据参数化,修改脚本,对代码进行加强,调试脚本。13、QTP中的Action有什么作用?有几种?参考答案:Action的作

42、用n 用Action可以对步骤集进行分组n 步骤重组,然后被整体调用n 拥有自己的sheetn 组合有相同需求的步骤,整体操作n 具有独立的对象仓库Action的种类n 可复用Actionn 不可复用Actionn 外部Action 14、TestDirector有些什么功能,如何对软件测试过程进行管理?参考答案: 需求管理n 定义测试范围n 定义需求树n 描述需求树的功能点测试计划n 定义测试目标和测试策略。n 分解应用程序,建立测试计划树。n 确定每个功能点的测试方法。n 将每个功能点连接到需求上,使测试计划覆盖全部的测试需求。n 描述手工测试的测试步骤n 指明需要进行自动测试的功能点测试

43、执行n 定义测试集合。n 为每个测试人员制定测试任务和测试日程安排。n 运行自动测试。缺陷跟踪n 记录缺陷n 查看新增缺陷,并确定哪些是需要修正的n 相关技术人员修改缺陷n 回归测试n 分析缺陷统计图表,分析应用程序的开发质量。15、你所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试)?参考答案:Compatibility Testing(兼容性测试),也称“Configuration testing(配置测试)”,测试软件是否和系统的其它与之交互的元素之间兼容,如:浏览器、操作系统、硬件等。验证测试对象在不同的软件和硬件配置中的运行情况。Fun

44、ctional testing (功能测试),也称为behavioral testing(行为测试),根据产品特征、操作描述和用户方案,测试一个产品的特性和可操作行为以确定它们满足设计需求。本地化软件的功能测试,用于验证应用程序或网站对目标用户能正确工作。使用适当的平台、浏览器和测试脚本,以保证目标用户的体验将足够好,就像应用程序是专门为该市场开发的一样。Performance testing(性能测试),评价一个产品或组件与性能需求是否符合的测试。包括负载测试、强度测试、数据库容量测试、基准测试等类型。16、软件缺陷(或者叫Bug)记录都包含了哪些内容?如何提交高质量的软件缺陷(Bug)记录

45、?参考答案:5C标准17、Beta测试与Alpha测试有什么区别?参考答案:Beta testing(测试),测试是软件的多个用户在一个或多个用户的实际使用环境下进行的测试。开发者通常不在测试现场Alpha testing (测试),是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模拟实际操作环境下进行的受控测试18、软件的评审一般由哪些人参加?其目的是什么?参考答案:在正式的会议上将软件项目的成果(包括各阶段的文档、产生的代码等)提交给用户、客户或有关部门人员对软件产品进行评审和批准。其目的是找出可能影响软件产品质量、开发过程、维护工作的适用性和环境方面的设计缺陷,并采取补救措施

46、,以及找出在性能、安全性和经济方面的可能的改进。 人员:用户、客户或有关部门开发人员,测试人员,需求分析师都可以,就看处于评审那个阶段 19、测试活动中,如果发现需求文档不完善或者不准确,怎么处理?参考答案:测试需求分析 发现需求文档不完善或者不准确,应该立即和相关人员进行协调交流。20、阶段评审与项目评审有什么区别?参考答案:阶段评审 对项目各阶段评审:对阶段成果和工作项目评审 对项目总体评审:对工作和产品21、阐述工作版本的定义?参考答案:构造号: BUILD22、什么是桩模块?什么是驱动模块?参考答案:桩模块:被测模块调用模块驱动模块 调用被测模块23、什么是扇入?什么是扇出?参考答案:

47、扇入:被调次数,扇出:调其它模块数目24、你认为做好测试计划工作的关键是什么?参考答案:软件测试计划就是在软件测试工作正式实施之前明确测试的对象,并且通过对资源、时间、风险、测试范围和预算等方面的综合分析和规划,保证有效的实施软件测试;做好测试计划工作的关键 :目的,管理,规范1. 明确测试的目标,增强测试计划的实用性编写软件测试计划得重要目的就是使测试过程能够发现更多的软件缺陷,因此软件测试计划的价值取决于它对帮助管理测试项目,并且找出软件潜在的缺陷。因此,软件测试计划中的测试范围必须高度覆盖功能需求,测试方法必须切实可行,测试工具并且具有较高的实用性,便于使用,生成的测试结果直观、准确2坚

48、持“5W”规则,明确内容与过程“5W”规则指的是“What(做什么)”、“Why(为什么做)”、“When(何时做)”、“Where(在哪里)”、“How(如何做)”。利用“5W”规则创建软件测试计划,可以帮助测试团队理解测试的目的(Why),明确测试的范围和内容(What),确定测试的开始和结束日期(When),指出测试的方法和工具(How),给出测试文档和软件的存放位置(Where)。3采用评审和更新机制,保证测试计划满足实际需求测试计划写作完成后,如果没有经过评审,直接发送给测试团队,测试计划内容的可能不准确或遗漏测试内容,或者软件需求变更引起测试范围的增减,而测试计划的内容没有及时更新

49、,误导测试执行人员。4. 分别创建测试计划与测试详细规格、测试用例应把详细的测试技术指标包含到独立创建的测试详细规格文档,把用于指导测试小组执行测试过程的测试用例放到独立创建的测试用例文档或测试用例管理数据库中。测试计划和测试详细规格、测试用例之间是战略和战术的关系,测试计划主要从宏观上规划测试活动的范围、方法和资源配置,而测试详细规格、测试用例是完成测试任务的具体战术。 25、你认为做好测试用例工作的关键是什么?参考答案: 需求和设计文档的理解程度,对系统的熟悉程度26、简述一下缺陷的生命周期?参考答案:提交-确认-分配-修复-验证-关闭27、软件的安全性应从哪几个方面去测试?参考答案:(1

50、) 用户认证机制:如数据证书、智能卡、双重认证、安全电子交易协议(2) 加密机制(3) 安全防护策略:如安全日志、入侵检测、隔离防护、漏洞扫描(4) 数据备份与恢复手段:存储设备、存储优化、存储保护、存储管理(5) 防病毒系统28、软件配置管理工作开展的情况和认识?参考答案:软件配置管理贯穿于软件开发、测试活动的始终,覆盖了开发、测试活动的各个环节,它的重要作用之一就是要全面的管理保存各个配置项,监控各配置项的状态,并向项目经理及相关的人员报告,从而实现对软件过程的控制。软件测试配置管理包括4个最基本的活动:配置项标识配置项控制配置项状态报告配置审计软件配置管理通常借助工具来辅助,主要有MS

51、SourceSafe、Rational ClearCase等29、你觉得软件测试通过的标准应该是什么样的?参考答案:缺陷密度值达到客户的要求30、引入测试管理的含义? 参考答案:风险分析,进度控制、角色分配、质量控制31、一套完整的测试应该由哪些阶段组成?参考答案:测试计划、测试设计与开发、测试实施、测试评审与测试结论32、单元测试的主要内容?参考答案:模块接口测试、局部数据结构测试、路径测试、错误处理测试、边界测试33、集成测试也叫组装测试或者联合测试,请简述集成测试的主要内容?参考答案:(1)在把各个模块连接起来的时候,穿越模块接口的数据是否会丢失;(2)一个模块的功能是否会对另一个模块的

52、功能产生不利的影响;(3)各个子功能组合起来,能否达到预期要求的父功能;(4)全局数据结构是否有问题;(5)单个模块的误差累积起来,是否会放大,从而达到不能接受的程度。34、简述集成测试与系统测试关系?参考答案:(1)集成测试的主要依据概要设计说明书,系统测试的主要依据是需求设计说明书;(2)集成测试是系统模块的测试,系统测试是对整个系统的测试,包括相关的软硬件平台、网络以及相关外设的测试。35、软件测试的文档测试应当贯穿于软件生命周期的全过程,其中用户文档是文档测试的重点。那么软件系统的用户文档包括哪些?参考答案:用户手册安装和设置指导联机帮助指南、向导样例、示例和模板授权/注册登记表最终用

53、户许可协议36、软件系统中除用户文档之外,文档测试还应该关注哪些文档?参考答案:开发文档软件需求说明书数据库设计说明书概要设计说明书详细设计说明书可行性研究报告管理文档项目开发计划测试计划测试报告开发进度月报开发总结报告37、简述软件系统中用户文档的测试要点?参考答案:(1)读者群。文档面向的读者定位要明确。对于初级用户、中级用户以及高级用户应该有不同的定位(2)术语。文档中用到的术语要适用与定位的读者群,用法一致,标准定义与业界规范相吻合。(3)正确性。测试中需检查所有信息是否真实正确,查找由于过期产品说明书和销售人员夸大事实而导致的错误。检查所有的目录、索引和章节引用是否已更新,尝试链接是

54、否准确,产品支持电话、地址和邮政编码是否正确。(4)完整性。对照软件界面检查是否有重要的分支没有描述到,甚至是否有整个大模块没有描述到。(5)一致性。按照文档描述的操作执行后,检查软件返回的结果是否与文档描述的相同。(6)易用性。对关键步骤以粗体或背景色给用户以提示,合理的页面布局、适量的图表都可以给用户更高的易用性。需要注意的是文档要有助于用户排除错误。不但描述正确操作,也要描述错误处理办法。文档对于用户看到的错误信息应当有更详细的文档解释。(7)图表与界面截图。检查所有图表与界面截图是否与发行版本相同。(8)样例与示例。像用户一样载入和使用样例。如果是一段程序,就输入数据并执行它。以每一个

55、模块制作文件,确认它们的正确性。(9)语言。不出现错别字,不要出现有二义性的说法。特别要注意的是屏幕截图或绘制图形中的文字。(10)印刷与包装。检查印刷质量;手册厚度与开本是否合适;包装盒的大小是否合适;有没有零碎易丢失的小部件等等。38、单元测试主要内容是什么?参考答案:单元测试大多数由开发人员来完成,测试人员技术背景较好或者开发系统软件时可能会安排测试人员进行单元测试,大多数进行的单元测试都是开发人员调试程序或者开发组系统联合调试的过程。讨论这个问题主要是扩充一下读者的视野。单元测试一般包括五个方面的测试:(1)模块接口测试:模块接口测试是单元测试的基础。只有在数据能正确流入、流出模块的前

56、提下,其他测试才有意义。模块接口测试也是集成测试的重点,这里进行的测试主要是为后面打好基础。测试接口正确与否应该考虑下列因素:-输入的实际参数与形式参数的个数是否相同;-输入的实际参数与形式参数的属性是否匹配;-输入的实际参数与形式参数的量纲是否一致;-调用其他模块时所给实际参数的个数是否与被调模块的形参个数相同;-调用其他模块时所给实际参数的属性是否与被调模块的形参属性匹配;-调用其他模块时所给实际参数的量纲是否与被调模块的形参量纲一致;-调用预定义函数时所用参数的个数、属性和次序是否正确;-是否存在与当前入口点无关的参数引用;-是否修改了只读型参数;-对全程变量的定义各模块是否一致;-是否

57、把某些约束作为参数传递。如果模块功能包括外部输入输出,还应该考虑下列因素:-文件属性是否正确;-OPEN/CLOSE语句是否正确;-格式说明与输入输出语句是否匹配;-缓冲区大小与记录长度是否匹配;-文件使用前是否已经打开;-是否处理了文件尾;-是否处理了输入/输出错误;-输出信息中是否有文字性错误。-局部数据结构测试;-边界条件测试;-模块中所有独立执行通路测试;(2)局部数据结构测试:检查局部数据结构是为了保证临时存储在模块内的数据在程序执行过程中完整、正确,局部功能是整个功能运行的基础。重点是一些函数是否正确执行,内部是否运行正确。局部数据结构往往是错误的根源,应仔细设计测试用例,力求发现

58、下面几类错误:-不合适或不相容的类型说明;-变量无初值;-变量初始化或省缺值有错;-不正确的变量名(拼错或不正确地截断);-出现上溢、下溢和地址异常。(3)边界条件测试:边界条件测试是单元测试中最重要的一项任务。众所周知,软件经常在边界上失效,采用边界值分析技术,针对边界值及其左、右设计测试用例,很有可能发现新的错误。边界条件测试是一项基础测试,也是后面系统测试中的功能测试的重点,边界测试执行的较好,可以大大提高程序健壮性。(4)模块中所有独立路径测试:在模块中应对每一条独立执行路径进行测试,单元测试的基本任务是保证模块中每条语句至少执行一次。测试目的主要是为了发现因错误计算、不正确的比较和不

59、适当的控制流造成的错误。具体做法就是程序员逐条调试语句。常见的错误包括:-误解或用错了算符优先级;-混合类型运算;-变量初值错;-精度不够;-表达式符号错。比较判断与控制流常常紧密相关,测试时注意下列错误:-不同数据类型的对象之间进行比较;-错误地使用逻辑运算符或优先级;-因计算机表示的局限性,期望理论上相等而实际上不相等的两个量相等;-比较运算或变量出错;-循环终止条件或不可能出现;-迭代发散时不能退出;-错误地修改了循环变量。模块的各条错误处理通路测试:程序在遇到异常情况时不应该退出,好的程序应能预见各种出错条件,并预设各种出错处理通路。如果用户不按照正常操作,程序就退出或者停止工作,实际

60、上也是一种缺陷,因此单元测试要测试各种错误处理路径。一般这种测试着重检查下列问题:-输出的出错信息难以理解;-记录的错误与实际遇到的错误不相符;-在程序自定义的出错处理段运行之前,系统已介入;-异常处理不当;-错误陈述中未能提供足够的定位出错信息。39、如何理解强度测试?参考答案:强度测试是为了确定系统在最差工作环境的工作能力,也可能是用于验证在标准工作压力下的各种资源的最下限指标。它和压力测试的目标是不同的,压力测试是在标准工作环境下,不断增加系统负荷,最终测试出该系统能力达到的最大负荷(稳定和峰值),而强度测试则是在非标准工作环境下,甚至不断人为降低系统工作环境所需要的资源,如网络带宽,系

61、统内存,数据锁等等,以测试系统在资源不足的情况下的工作状态,通过强度测试,可以确定本系统正常工作的最差环境.强度测试和压力测试的测试指标相近,大多都是与时间相关的指标,如并发量(吞吐量),延迟(最大最小平均)以及顺序指标等强度测试需要对系统的结构熟悉,针对系统的特征设计强度测试的方法40、如何理解压力、负载、性能测试测试?参考答案:性能测试是一个较大的范围,实际上性能测试本身包含了性能、强度、压力、负载等多方面的测试内容。压力测试是对服务器的稳定性以及负载能力等方面的测试,是一种很平常的测试。增大访问系统的用户数量、或者几个用户进行大数据量操作都是压力测试。而负载测试是压力相对较大的测试,主要

62、是测试系统在一种或者集中极限条件下的相应能力,是性能测试的重要部分。100个用户对系统进行连续半个小时的访问可以看作压力测试,那么连续访问8个小时就可以认为负载测试,1000个用户连续访问系统1个小时也可以看作是负载测试。实际上压力测试和负载测试没有明显的区分。测试人员应该站在关注整体性能的高度上来对系统进行测试。41、什么是系统瓶颈?参考答案:瓶颈主要是指整个软硬件构成的软件系统某一方面或者几个方面能力不能满足用户的特定业务要求,“特定”是指瓶颈会在某些条件下会出现,因为毕竟大多数系统在投入前。严格的从技术角度讲,所有的系统都会有瓶颈,因为大多数系统的资源配置不是协调的,例如CPU使用率刚好达到100

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!