字节跳动2022年软件测试自动化测试面试题-面经4-1

目录

前言:

【文章末尾给大家留下了大量的福利】

1、问:你在测试中发现了一个 bug,但是开发经理认为这

2、问:给你一个网站,你如何测试?

3、在搜索引擎中输入汉字就可以解析到对应的域名,请问

4、问:一台客户端有三百个客户与三百个客户端有三百个

5、试述软件的概念和特点?软件复用的含义?构件包括哪些?

6、软件生存周期及其模型是什么?

7、什么是软件测试?软件测试的目的与原则

扫描二维码关注公众号,回复: 14300375 查看本文章

8、软件配置管理的作用?软件配置包括什么?

9、什么是软件质量?

10、目前主要的测试用例设计方法是什么?

11、软件的安全性应从哪几个方面去测试?

12、什么是测试用例 什么是测试脚本 两者的关系是什么?

13、简述什么是静态测试、动态测试、黑盒测试、白盒测试、α测试 β测试

14、软件质量保证体系是什么 国家标准中与质量保证管理相关的几个标准是什

么?他们的编号和全称是什么?

15、软件产品质量特性是什么?

16、软件测试的策略是什么?

17、软件测试分为几个阶段 各阶段的测试策略和要求是什么?

18、软件测试各个阶段通常完成什么工作?各个阶段的结果文件是什么?包括

什么内容?

19、测试人员在软件开发过程中的任务是什么?


前言:

适合人群

1、测试行业从业者,想要薪资翻倍

2、想要转行软件测试者,迅速转行

3、测试行业从业者,短时间内系统地提升技能

【文章末尾给大家留下了大量的福利】

1、问:你在测试中发现了一个 bug,但是开发经理认为这

不是一个 bug,你应该怎样解决?

首先,将问题提交到缺陷管理库里面进行备案。

然后,要获取判断的依据和标准:

根据需求说明书、产品说明、设计文档等,确认实际结果是否与计划有不一致

的地方,提供缺陷是否确认的直接依据;

如果没有文档依据,可以根据类似软件的一般特性来说明是否存在不一致的地

方,来确认是否是缺陷;

根据用户的一般使用习惯,来确认是否是缺陷;

与设计人员、开发人员和客户代表等相关人员探讨,确认是否是缺陷;

合理的论述,向测试经理说明自己的判断的理由,注意客观、严谨,不参杂个

人情绪。

等待测试经理做出最终决定,如果仍然存在争议,可以通过公司政策所提供的

渠道,向上级反映,并有上级做出决定。

2、问:给你一个网站,你如何测试?

首先,查找需求说明、网站设计等相关文档,分析测试需求。

制定测试计划,确定测试范围和测试策略,一般包括以下几个部分:功能性测

试;界面测试;性能测试;数据库测试;安全性测试;兼容性测试

设计测试用例:

功能性测试可以包括,但不限于以下几个方面:

链接测试。链接是否正确跳转,是否存在空页面和无效页面,是否有不正确的

出错信息返回。

提交功能的测试。

多媒体元素是否可以正确加载和显示。

多语言支持是否能够正确显示选择的语言等。

界面测试可以包括但不限于一下几个方面:

页面是否风格统一,美观

页面布局是否合理,重点内容和热点内容是否突出

控件是否正常使用

对于必须但未安装的控件,是否提供自动下载并安装的功能

文字检查

性能测试一般从以下两个方面考虑:

压力测试;负载测试;强度测试

数据库测试要具体决定是否需要开展。数据库一般需要考虑连结性,对数据的

存取操作,数据内容的验证等方面。

安全性测试:

基本的登录功能的检查

是否存在溢出错误,导致系统崩溃或者权限泄露

相关开发语言的常见安全性问题检查,例如 SQL 注入等

如果需要高级的安全性测试,确定获得专业安全公司的帮助,外包测试,或者

获取支持

兼容性测试,根据需求说明的内容,确定支持的平台组合:

浏览器的兼容性;

操作系统的兼容性;

软件平台的兼容性;

数据库的兼容性

开展测试,并记录缺陷。合理的安排调整测试进度,提前获取测试所需的资源,

建立管理体系(例如,需求变更、风险、配置、测试文档、缺陷报告、人力资

源等内容)。

定期评审,对测试进行评估和总结,调整测试的内容。

3、在搜索引擎中输入汉字就可以解析到对应的域名,请问

如何用 LoadRunner 进行测试。

建立测试计划,确定测试标准和测试范围

设计典型场景的测试用例,覆盖常用业务流程和不常用的业务流程等

根据测试用例,开发自动测试脚本和场景:

录制测试脚本:新建一个脚本(Web/HTML 协议);点击录制按钮,在弹出

的对话框的 URL 中输入”about:blank”;在打开的浏览器中进行正常操作流

程后,结束录制;调试脚本并保存,可能要注意到字符集的关联。

设置测试场景:针对性能设置测试场景,主要判断在正常情况下,系统的平均

事务响应时间是否达标;针对压力负载设置测试场景,主要判断在长时间处于

满负荷或者超出系统承载能力的条件下,系统是否会崩溃;执行测试,获取测

试结果,分析测试结果

4、问:一台客户端有三百个客户与三百个客户端有三百个

客户对服务器施压,有什么区别?

300 个用户在一个客户端上,会占用客户机更多的资源,而影响测试的结果。

线程之间可能发生干扰,而产生一些异常。

300 个用户在一个客户端上,需要更大的带宽。

IP 地址的问题,可能需要使用 IP Spoof 来绕过服务器对于单一 IP 地址最大连

接数的限制。

所有用户在一个客户端上,不必考虑分布式管理的问题;而用户分布在不同的

客户端上,需要考虑使用控制器来整体调配不同客户机上的用户。同时,还需

要给予相应的权限配置和防火墙设置。

5、试述软件的概念和特点?软件复用的含义?构件包括哪些?

软件是计算机系统中与硬件相互依存的另一部分,与系统操作有关的计

算机、规程、规则,以及可能有的文件、文档及。

软件复用(SoftWare Reuse)是将已有软件的各种有关知识用于建立新的软件,

以缩减软件开发和维护的花费。软件复用是提高软件生产力和质量的一种重要

技术。早期的软件复用主要是代码级复用,被复用的知识专指程序,后来扩大

到包括领域知识、开发经验、设计决定、、需求、设计、代码和文档

等一切有关方面。

可以被复用的软件成分一般称作可复用构件

6、软件生存周期及其模型是什么?

软件生存周期(Software life cycle)又称为软件生命期,生存期。是指从形

成开发软件概念起,所开发的软件使用以后,知道失去使用价值消亡为止的整

个过程。一般来说,整个生存周期包括计划(定义)、开发、运行(维护)三

个时期,每个时期又划分为若干个阶段。每个阶段有明确的任务。

周期模型(典型的几种):

瀑布模型

快速原型模型:快速原型模型允许在阶段对软件的需求进行初步而非

完全的分析和定义,快速设计开发出的原型,该原型向用户展示待开

发软件的全部或部分功能和性能;用户对该原型进行测试评定,给出具体改进

意见以丰富细化;开发人员据此对软件进行修改完善,直至用户满意

认可之后,进行软件的完整实现及测试、维护。

迭代模型:迭代包括产生产品发布(稳定、可执行的产品版本)的全部开发活

动和要使用该发布必需的所有其他外围元素。在某种程度上,开发迭代是一次

完整地经过所有工作流程的过程:需求分析、设计、实施和测试工作流程。实

质上,它类似小型的瀑布式项目。RUP 认为,所有的阶段都可以细分为迭代。

每一次 的迭代都会产生一个可以发布的产品,这个产品是最终产品的一个子

集。

生命周期阶段:

软件计划与可行性分析

需求分析

软件设计

编码

软件测试

运行与维护

7、什么是软件测试?软件测试的目的与原则

在规定的条件下对程序进行操作,以发现程序错误,衡量软件质量,并对其是

否能满足设计要求进行评估的过程。

软件测试的目的:

测试是程序的执行过程,目的在于发现错误

一个成功的测试用例在于发现至今未发现的错误

一个成功的测试是发现了至今未发现的错误的测试

确保产品完成了它所承诺或公布的功能,并且用户可以访问到的功能都有明确

的书面说明。

确保产品满足性能和效率的要求

确保产品是健壮的和适应用户环境的

软件测试的原则:

测试用例中一个必须部分是对预期输出或接过进行定义

程序员应避免测试自己编写的程序

编写软件的组织不应当测试自己编写的软件

应当彻底检查每个测试的执行结果

测试用例的编写不仅应当根据有效和预料到的输入情况,而且也应当根据无效

和未预料到的输入情况

检擦程序是否“未做其应该做的”仅是测试的一半,测试的另一半是检查程序

是否“做了其不应该做的”

应避免测试用例用后即弃,除非软件本身就是个一次性的软件

计划测试工作时不应默许假定不会发现错误

程序某部分存在更多错误的可能性,与该部分已经发现错误的数量成正比

软件测试是一项极富创造性,极具智力的挑战性的工作

8、软件配置管理的作用?软件配置包括什么?

配置管理(Software Configuration Management,SCM)是一种标识、

组织和控制修改的技术。管理应用于整个。在软件建立

时变更是不可避免的,而变更加剧了项目中者之间的混乱。SCM 活

动的目标就是为了标识变更、控制变更、确保变更正确实现并向其他有关人员

变更。从某种角度讲,SCM 是一种标识、组织和控制修改的技术,目的

是使错误降为最小并最有效地提高。

软件配置包括如下内容:配置项识别、工作空间管理、版本控制、变更控制、

状态报告、配置审计

9、什么是软件质量?

概括地说,软件质量就是“软件与明确的和隐含的定义的需求相一致的程度”。

具体地说,软件质量是软件符合明确叙述的功能和性能需求、文档中明确描述

的开发标准、以及所有专业开发的软件都应具有的隐含特征的程度。 影响软

件质量的主要因素,这些因素是从管理角度对软件质量的度量。可划分为三组,

分别反应用户在使用软件产品时的三种观点。正确性、、效率、完整性、

可用性、风险(产品运行);可理解性、可维修性、灵活性、(产品

修改);可移植性、可再用性、互运行性(产品转移)。

10、目前主要的测试用例设计方法是什么?

白盒测试:逻辑覆盖、循环覆盖、基本路径覆盖

黑盒测试:边界值分析法、等价类划分、错误猜测法、因果图法、状态图法、

测试大纲法、随机测试、场景法

11、软件的安全性应从哪几个方面去测试?

软件安全性测试包括程序、数据库安全性测试。根据系统安全指标不同测试策

略也不同。

用户认证安全的测试要考虑问题: 明确区分系统中不同用户权限 、系统中会

不会出现用户冲突 、系统会不会因用户的权限的改变造成混乱 、用户登陆密

码是否是可见、可复制 、是否可以通过绝对途径登陆系统(拷贝用户登陆后

的链接直接进入系统)、用户退出系统后是否删除了所有鉴权标记,是否可以

使用后退键而不通过输入口令进入 系统 、系统网络安全的测试要考虑问题 、

测试采取的防护措施是否正确装配好,有关系统的补丁是否打上 、模拟非授

权攻击,看防护系统是否坚固 、采用成熟的网络漏洞检查工具检查系统相关

漏洞(即用最专业的黑客攻击工具攻击试一下,现在最常用的是 NBSI 系列

和 IPhacker IP ) 、采用各种木马检查工具检查系统木马情况 、采用各种

防外挂工具检查系统各组程序的外挂漏洞

数据库安全考虑问题: 系统数据是否机密(比如对银行系统,这一点就特别

重要,一般的网站就没有太高要求)、系统数据的完整性(我刚刚结束的企业

实名核查服务系统中就曾存在数据 的不完整,对于这个系统的功能实现有了

障碍) 、系统数据可管理性 、系统数据的独立性 、系统数据可备份和恢复

能力(数据备份是否完整,可否恢复,恢复是否可以完整)

12、什么是测试用例 什么是测试脚本 两者的关系是什么?

为实施测试而向被测试系统提供的输入数据、操作或各种环境设置以及期望结

果的一个特定的集合。

测试脚本是为了进行自动化测试而编写的脚本。

测试脚本的编写必须对应相应的测试用例

13、简述什么是静态测试、动态测试、黑盒测试、白盒测试、α测试 β测试

静态测试是不运行程序本身而寻找程序代码中可能存在的错误或评估程序代

码的过程。

动态测试是实际运行被测程序,输入相应的测试实例,检查运行结果与预期结

果的差异,判定执行结果是否符合要求,从而检验程序的正确性、可靠性和有

效性,并分析系统运行效率和健壮性等性能。

黑盒测试一般用来确认软件功能的正确性和可操作性,目的是检测软件的各个

功能是否能得以实现,把被测试的程序当作一个黑盒,不考虑其内部结构,在知道

该程序的输入和输出之间的关系或程序功能的情况下,依靠软件规格说明书来

确定测试用例和推断测试结果的正确性。

白盒测试根据软件内部的逻辑结构分析来进行测试,是基于代码的测试,测试

人员通过阅读程序代码或者通过使用开发工具中的单步调试来判断软件的质

量,一般黑盒测试由项目经理在程序员开发中来实现。

α测试是由一个用户在开发环境下进行的测试,也可以是公司内部的用户在模

拟实际操作环境下进行的受控测试,Alpha 测试不能由程序员或测试员完成。

β测试是软件的多个用户在一个或多个用户的实际使用环境下进行的测试。开

发者通常不在测试现场,Beta 测试不能由程序员或测试员完成。

14、软件质量保证体系是什么 国家标准中与质量保证管理相关的几个标准是什

么?他们的编号和全称是什么?

SQA 由一套软件工程过程和方法组成,以保证(软件的)质量。SQA 贯穿整

个软件开发过程,(它)应包括需求文档评审、代码控制、代码评审、变更管理、

配置管理、版本管理和软件测试。

保证(SQA-Software Quality Assurance)是建立一套有计划,有

系统的方法,来向管理层保证拟定出的标准、步骤、实践和方法能够正确地被

所有项目所采用。软件质量保证的目的是使对于管理人员来说是可见

的。它通过对软件产品和活动进行评审和审计来验证软件是合乎标准的。软件

质量保证组在项目开始时就一起参与建立计划、标准和过程。这些将使软件项

目满足机构方针的要求。

15、软件产品质量特性是什么?

功能性:适应性、准确性、互操作性、依从性、安全性。

可靠性:成熟性、容错性、易恢复性。

可使用性:易理解性、易学习性、易操作性。

效率:时间特性、资源特性。

可维护性:易分析性、易变更性、稳定性、易测试性。

可移植性: 适应性、易安装性、遵循性、易替换性

16、软件测试的策略是什么?

软件测试策略:在一定的软件测试标准、测试规范的指导下,依据测试项目的

特定环境约束而规定的软件测试的原则、方式、方法的集合。

17、软件测试分为几个阶段 各阶段的测试策略和要求是什么?

和开发过程相对应,测试过程会依次经历单元测试、集成测试、系统测试、验

收测试四个主要阶段:

单元测试:单元测试是针对软件设计的最小单位––程序模块甚至代码段进行正

确性检验的测试工作,通常由开发人员进行。

集成测试:集成测试是将模块按照设计要求组装起来进行测试,主要目的是发

现与接口有关的问题。由于在产品提交到测试部门前,产品开发小组都要进行

联合调试,因此在大部分企业中集成测试是由开发人员来完成的。

系统测试:系统测试是在集成测试通过后进行的,目的是充分运行系统,验证

各子系统是否都能正常工作并完成设计的要求。它主要由测试部门进行,是测

试部门最大最重要的一个测试,对产品的质量有重大的影响。

验收测试:验收测试以需求阶段的《需求规格说明书》为验收标准,测试时要

求模拟实际用户的运行环境。对于实际项目可以和客户共同进行,对于产品来

说就是最后一次的系统测试。测试内容为对功能模块的全面测试,尤其要进行

文档测试。

单元测试测试策略:

自顶向下的单元测试策略:比孤立单元测试的成本高很多,不是单元测试的一

个好的选择。

自底向上的单元测试策略:比较合理的单元测试策略,但测试周期较长。

孤立单元测试策略:最好的单元测试策略。

集成测试的测试策略:

大爆炸集成:适应于一个维护型项目或被测试系统较小

自顶向下集成:适应于产品控制结构比较清晰和稳定;高层接口变化较小;底

层接口未定义或经常可能被修改;产口控制组件具有较大的技术风险,需要尽

早被验证;希望尽早能看到产品的系统功能行为。

自底向上集成:适应于底层接口比较稳定;高层接口变化比较频繁;底层组件

较早被完成。

基于进度的集成

优点:具有较高的并行度;能够有效缩短项目的开发进度。

缺点:桩和驱动工作量较大;有些接口测试不充分;有些测试重复和浪费。

系统测试的测试策略:

数据和数据库完整性测试;功能测试;用户界面测试;性能评测;负载测试;

强度测试;容量测试;安全性和访问控制测试;故障转移和恢复测试;配置测

试;安装测试;加密测试;可用性测试;版本验证测试;文档测试

18、软件测试各个阶段通常完成什么工作?各个阶段的结果文件是什么?包括

什么内容?

单元测试阶段:各独立单元模块在与系统地其他部分相隔离的情况下进行测

试,单元测试针对每一个程序模块进行正确性校验,检查各个程序模块是否正

确地实现了规定的功能。生成单元测试报告,提交缺陷报告。

集成测试阶段:集成测试是在单元测试的基础上,测试在将所有的软件单元按

照概要设计规格说明的要求组装成模块、子系统或系统的过程中各部分工作是

否达到或实现相应技术指标及要求的活动。该阶段生成集成测试报告,提交缺

陷报告。

系统测试阶段:将通过确认测试的软件,作为整个给予计算机系统的一个元素,

与计算机硬件、外设、某些支持软件、数据和人员等其他系统元素结合在一起,

在实际运行环境下,对计算机系统进行全面的功能覆盖。该阶段需要提交测试

总结和缺陷报告。

19、测试人员在软件开发过程中的任务是什么?

1、尽可能早的找出系统中的 Bug;

2、避免软件开发过程中缺陷的出现;

3、衡量软件的品质,保证系统的质量;

4、关注用户的需求,并保证系统符合用户需求。

总的目标是:确保软件的质量。

20、在您以往的工作中,一条软件缺陷(或者叫 Bug)记录都包含了哪些内容?

如何提交高质量的软件缺陷(Bug)记录?

一条 Bug 记录最基本应包含:

bug 编号;

bug 严重级别,优先级;

bug 产生的模块;

首先要有 bug 摘要,阐述 bug 大体的内容;

bug 对应的版本;

bug 详细现象描述,包括一些截图、录像....等等;

bug 出现时的测试环境,产生的条件即对应操作步骤;

高质量的 Bug 记录:

1) 通用 UI 要统一、准确

缺陷报告的 UI 要与测试的软件 UI 保持一致,便于查找定位。

2) 尽量使用业界惯用的表达术语和表达方法

使用业界惯用的表达术语和表达方法,保证表达准确,体现专业化。

3) 每条缺陷报告只包括一个缺陷

每条缺陷报告只包括一个缺陷,可以使缺陷修正者迅速定位一个缺陷,集中精

力每次只修正一个缺陷。校验者每次只校验一个缺陷是否已经正确修正。

4) 不可重现的缺陷也要报告

首先缺陷报告必须展示重现缺陷的能力。不可重现的缺陷要尽力重现,若尽力

之后仍不能重现,仍然要报告此缺陷,但在报告中要注明无法再现,缺陷出现

的频率。

5) 明确指明缺陷类型

根据缺陷的现象,总结判断缺陷的类型。例如,即功能缺陷、界面缺陷、数据

缺陷,合理化建议这是最常见的缺陷或缺陷类型,其他形式的缺陷或缺陷也从

属于其中某种形式。

6) 明确指明缺陷严重等级和优先等级

时刻明确严重等级和优先等级之间的差别。高严重问题可能不值得解决,小装

饰性问题可能被当作高优先级。

7) 描述 (Description) ,简洁、准确,完整,揭示缺陷实质,记录缺陷或缺

陷出现的位置

描述要准确反映缺陷的本质内容,简短明了。为了便于在软件缺陷管理数据库

中寻找制定的测试缺陷,包含缺陷发生时的用户界面(UI)是个良好的习惯。

例如记录对话框的标题、菜单、按钮等控件的名称。

8) 短行之间使用自动数字序号,使用相同的字体、字号、行间距

短行之间使用自动数字序号,使用相同的字体、字号、行间距,可以保证各条

记录格式一致,做到规范专业。

9) 每一个步骤尽量只记录一个操作

保证简洁、条理井然,容易重复操作步骤。

10) 确认步骤完整,准确,简短

保证快速准确的重复缺陷,“完整”即没有缺漏,“准确”即步骤正确,“简

短”即没有多余的步骤。

11) 根据缺陷,可选择是否进行图象捕捉

为了直观的观察缺陷或缺陷现象,通常需要附加缺陷或缺陷出现的界面,以图

片的形式作为附件附着在记录的“附件”部分。为了节省空间,又能真实反映

缺陷或缺陷本质,可以捕捉缺陷或缺陷产生时的全屏幕,活动窗口和局部区域。

为了迅速定位、修正缺陷或缺陷位置,通常要求附加中文对照图。

附加必要的特殊文档和个人建议和注解

如果打开某个特殊的文档而产生的缺陷或缺陷,则必须附加该文档,从而可以

迅速再现缺陷或缺陷。有时,为了使缺陷或缺陷修正者进一步明确缺陷或缺陷

的表现,可以附加个人的修改建议或注解。

12) 检查拼写和语法缺陷

在提交每条缺陷或缺陷之前,检查拼写和语法,确保内容正确,正确的描述缺

陷。

13) 尽量使用短语和短句,避免复杂句型句式

软件缺陷管理数据库的目的是便于定位缺陷,因此,要求客观的描述操作步骤,

不需要修饰性的词汇和复杂的句型,增强可读性。

以上概括了报告测试缺陷的规范要求,随着软件的测试要求不同,测试者经过

长期测试,积累了相应的测试经验,将会逐渐养成良好的专业习惯,不断补充

新的规范书写要求。此外,经常阅读、学习其他测试工程师的测试缺陷报告,

结合自己以前的测试缺陷报告进行对比和思考,可以不断提高技巧。

14) 缺陷描述内容

缺陷描述的内容可以包含缺陷操作步骤,实际结果和期望结果。操作步骤可以

方便开发人员再现缺陷进行修正,有些开发的再现缺陷能力很差,虽然他明白

你所指的缺陷,但就是无法再现特别是对系统不熟悉的新加入开发人员,介绍

步骤可以方便他们再现。实际结果可以让开发明白错误是什么,期望结果可以

让开发了解正确的结果应该是如何。

 重点:学习资料学习当然离不开资料,这里当然也给你们准备了600G的学习资料

需要的私我关键字【000】免费获取哦 注意关键字是:000

全套软件测试自动化测试教学视频

300G教程资料下载【视频教程+PPT+项目源码】

全套软件测试自动化测试大厂面经

python自动化测试++全套模板+性能测试

听说关注我并三连的铁汁都已经升职加薪暴富了哦!!!!

猜你喜欢

转载自blog.csdn.net/csdnchengxi/article/details/125100825
今日推荐