我的软件测试面试经历,7轮高强度面试顺利入职

我的软件测试面试经历,7轮高强度面试顺利入职今年的大环境非常差 互联网企业裁员的现象比往年更严重了 可今年刚好是我的第一个 五年计划 截止的时间点 说什么也不能够耽搁了 所以早早准备的跳槽也在疫情好转之后开始进行了

大家好,欢迎来到IT知识分享网。

前言

今年的大环境非常差,互联网企业裁员的现象比往年更严重了,可今年刚好是我的第一个“五年计划”截止的时间点,说什么也不能够耽搁了,所以早早准备的跳槽也在疫情好转之后开始进行了。但是,不得不说,这次阿里面试真的太难为我了,可以说是和面试官大战了7个回合,不过好在最后给了offer。

我个人情况是5年软件测试经验,阿里定级P7的样子,下面是我的面试经历分享,希望能带来一些不一样的启发和帮助。

我与阿里面试官“大战”7回合,胜

第一轮:

技术面试:主要考察候选人的基本技术功底,包括编程语言、数据结构、算法等方面。

  • 请简述一下你对测试的理解和你认为一个好的测试工程师应该具备哪些能力。
  • 说一下你在项目中如何设计测试用例?
  • 简述一下测试计划的制定过程以及其中涉及到的内容。
  • 在压力测试中,你会关注哪些指标,并举例说明如何进行压力测试。
  • 当你在进行接口测试时,如果发现返回结果与期望不符,你会怎么做?请谈一下你的思考过程。
  • 如果有一个从未测试过的产品版本,让你来负责测试,你会如何规划测试流程?
  • 请介绍一下你在自动化测试方面的经验和技能。
  • 你认为测试流程对于软件开发的重要性是什么?并分享一下你在测试流程上的实践经验
第二轮:

项目经验面试:主要考察候选人在测试领域的实际工作经验和项目管理能力。

  • 你在阿里项目中负责的测试工作是什么?具体包括哪些方面?
  • 请描述一下你在阿里项目中遇到的最大的测试挑战是什么?你是如何克服这个挑战的?
  • 阿里的系统很大,您如何确定测试的重点?
  • 您如何为阿里项目编写测试计划和测试用例?
  • 阿里项目中有没有使用过自动化测试?如果有,您是如何实现自动化测试的?
  • 在阿里项目中,您如何进行性能测试和安全测试?您采取了哪些措施来确保系统的高性能和安全性?
  • 阿里项目中您遇到过哪些问题?您是如何解决这些问题的?
  • 在阿里项目中,您如何与开发人员、产品经理和其他团队成员协同工作,以确保测试工作的顺利进行?
  • 在阿里项目中,您如何跟踪和记录缺陷?您采用了哪些工具来管理缺陷?
  • 您认为在阿里项目中最重要的测试技能是什么?为什么?
第三轮:

测试理论面试:主要考察候选人对测试理论的掌握程度,包括测试方法、测试流程、测试策略等方面。

什么是软件测试?请描述一下您的理解。

请简述测试用例的概念,并提供一个测试用例的例子。

请解释一下静态测试和动态测试的区别。

什么是黑盒测试?请举一个例子并描述其优缺点。

请解释一下白盒测试?请举一个例子并描述其优缺点。

请描述一下自动化测试的概念,并提供一些适合自动化测试的场景。

请简述负载测试的概念,并提供一个负载测试的例子。

请描述一下安全测试,并提供一个安全测试的例子。

请解释一下回归测试的概念,并提供一个回归测试的例子。

请描述一下性能测试,包括如何设置性能指标、如何设计性能测试用例和如何进行性能测试分析。

第四轮:

测试工具面试:主要考察候选人对各种测试工具的熟练程度,包括性能测试工具、自动化测试工具、安全测试工具等方面。

  • 你熟悉哪些阿里巴巴常用的测试工具?
  • JMeter有哪些特点?它可以模拟哪些协议?
  • Selenium可以用来进行什么类型的测试?请描述一下Selenium的架构。
  • TestNG和JUnit相比有哪些优势?如何在TestNG中进行参数化测试?
  • Appium可以用来测试哪些移动应用程序?请简述Appium的原理。
  • Lighthouse主要用于评估Web应用程序的哪些方面的质量和性能?
  • 如果要对一个分布式实时计算系统进行性能测试,你会选择使用哪些测试工具?
  • TDDL是什么?它的主要作用是什么?
第五轮:

团队协作面试:主要考察候选人的团队合作意识和沟通能力。

  • 你如何跟进和管理一个测试项目?请描述一下。
  • 在测试过程中,如果发现一个严重的缺陷,你会怎么做?在通知开发人员之前,你需要完成什么工作?
  • 如何与开发团队建立良好的合作关系?请分享一下你的经验。
  • 如果你发现开发人员没有及时修复缺陷,你会采取哪些措施来促进缺陷的修复?
  • 当多个团队同时参与到一个大型软件项目中时,你如何保证不同团队之间的有效沟通?请分享一下你的策略。
  • 如果你在测试过程中遇到了一个难以重现的问题,你会怎么处理?
第六轮:

算法题面试:主要考察候选人的逻辑思维能力和解决问题的能力。

  • 请实现一个函数,用于计算两个整数的和,不能使用加减乘除等算术运算符。
  • 给定一个字符串,找到其中第一个不重复出现的字符,并返回其索引。如果不存在,则返回-1。
  • 实现一个函数,用于合并两个有序数组为一个有序数组。
  • 在一个长度为n的数组中查找第k大的元素。例如,当k=2时,结果应该是数组中第二大的元素。
  • 给定一组区间,将它们合并成尽可能少的区间。例如,输入[[1,3],[2,6],[8,10],[15,18]],输出[[1,6],[8,10],[15,18]]。
第七轮:

HR面试:主要考察候选人的个人素质和职业规划。

  • 请简单介绍一下自己的教育背景和工作经历。
  • 除了软件测试,你还具备哪些其他技能或者兴趣爱好?
  • 你在工作中遇到过最大的挑战是什么,你是如何应对的?
  • 你认为软件测试岗位需要具备哪些技能和品质?你自己具备其中哪些?
  • 你对未来三年的职业规划是什么?你希望从阿里巴巴这个公司获得什么?

我的面试题经验分享(含答案和解析):

由于要控制文章篇幅,所以只是给大家挑取少量的面试题参考。关于完整版面试手册,若是感兴趣想学习的朋友点击文末名片扫码免费领取

  制定初步的项目计划。

  测试准备:组织测试团队、培训、建立测试和管理环境等。

  测试设计:按照测试要求进行每个测试项的测试设计,包括测试用例的设计和测试脚本的开发等。

  测试实施:按照测试计划实施测试。

  测试评估:根据测试的结果,出具测试评估报告。

  CMMI:Capability Maturity Model Integration能力成熟度模型集成 CMMI融入了大部分最新的软件管理实践,同时弥补了SW-CMM模型中的缺陷。

  RUP:rational unified process是软件工程话过程。

  XP:extreme program,即极限编程的意思,适用于小型团队的软件开发,像上面第三个问题就可以结合原型法采用这样的开发流程。要明白测试对于xp开发的重要性,强调测试(重点是单元测试)先行的理念。编程可以明显提高代码的质量,持续集成对于快速定位问题有好处。

  PSP,TSP分别是个体软件过程和群体软件过程。大家都知道,CMM只是告诉你做什么但并没有告诉你如何做,所以PSP/TSP就是告诉你企业在实施CMM的过程中如何做,PSP强调建立个人技能(如何制定计划、控制质量及如何与其他人相互协作等等)。而TSP着重于生产并交付高质量的软件产品(如何有效的规划和管理所面临的项目开发任务等等)。总之,实施CMM,永远不能真正做到能力成熟度的提升,只有将实施CMM与实施PSP和TSP有机结合起来,才能发挥最大的效力。因此,软件过程框架应该是CMM/PSP/TSP的有机集成。

  2-本着找出软件存在的问题的态度进行测试,不要以挑刺的形象出现

  3-可熟练阅读需求规格说明书等文档

  4-以用户的观点看问题

  5-有强烈的质量意识

  6-细心和责任心

  7-良好的有效的沟通方式(与开发人员及客户)

  8-具有以往的测试经验能够及时准确的判断出高危险区在何处

  2-测试人员必须熟悉系统功能和业务

  3-测试要有计划,而且测试方案要和整个项目计划协调好

  4-必须实现编写测试用例,测试执行阶段必须根据测试用例进行

  5-易用性,功能,分支,边界,性能等功能行和非功能性需求都要进行测试

  6-对于复杂的流程一定要进行流程分支,组合条件分析,再进行等价类划分准备相关测试数据

  7-测试设计的一个重要内容是要准备好具体的测试数据,清楚这个测试数据是测试那个场景或分支的。

  8-个人任务平均每三个测试用例至少应该发现一个BUG,否则只能说明测试用例质量不好

  9-除了每天构建的重复测试可以考虑测试自动化外,其他暂时都不要考虑去自动话

  2-善于怀疑,实际上没有绝对正确的,总有错误的地方,具有叛逆心理,别人认为不可能发生的事情,我却认为可能发生,别人认为是对的,我却认为不是对的。

  3-打破沙锅问到底的精神,对于只出现过一次的BUG一定要找出原因,不解决誓不罢休。

  4-保持一个良好的心情,否则可能无法把测试做好。不要把生活中的不愉快的情绪带到工作中来。

  5-做测试时要细心,不是所有的BUG都能很容易找出,一定要细心才能找到这些BUG。

  6-灵活一些,聪明一点,多造一些容易产生BUG的例子。

  7-在有条件的情况下,多和客户沟通,他们身上有你所需要的。

  8-设身处地为客户着想,从他们的角度去测试系统。

  9-不要让程序员,以“这种情况不可能发生”这句话说服你,相反,你应该去说服他,告诉他在客户心理,并不是这样的

  10-考虑问题要全面,结合客户的需求,业务流程和系统的架构等多方面考虑问题。

  11-提出问题不要复杂化,这点和前面矛盾,如果你是一个新手,暂时不要管这点,因为最终将有你的小组成员讨论解决。

  12-追求完美,对于新测试员来说,努力追求完美,这对你很好,尽管有些事情无法做到,但你应该尝试。

  13-幽默感,能和开发小组很好的沟通是关键,试着给你的开发小组找一个BUG杀手,或对他们说“我简直不敢相信,你写的程序居然到现在没有找到BUG”。

  功能测试在测试工作中占有比例最大,功能测试也叫黑盒测试。

  性能测试是通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。负载测试和压力测试都属于性能测试,两者可以结合进行。

  界面测试,界面是软件与用户交互的最直接的层,界面的好坏决定用户对软件的第一印象。

  区别在于,功能测试关注产品的所有功能,要考虑到每个细节功能,每个可能存在的功能问题。性能测试主要关注产品整体的多用户并发下的稳定性和健壮性。界面测试则关注与用户体验相关内容,用户使用该产品的时候是否已用,是否易懂,是否规范(用户无意输入无效的数据,当然考虑到体验性,不能太粗鲁的弹出警告)。做某个性能测试的时候,首先它可能是个功能点,首先要保证她的功能是没有问题的,然后再考虑性能的问题。

  1-是否有不正确或遗漏的功能

  2-在接口上,输入是否能正确的接受?能否输出正确的结果。

  3-是否有数据结构错误或外部信息(例如数据文件)访问错误

  4-性能上是否能够满足要求

  5-是否有初始化或终止性错误

  软件的白盒测试是对软件的过程性细节做细致的检查。这种方法是把测试对象看作一个打开的盒子,它允许测试人员利用程序内部的逻辑结构和有关信息,设计或者选择测试用例,对程序所有逻辑路径进行测试。通过在不同点检查程序状态,确定实际状态是否与预期的状态一直。因此白盒测试又称为结合测试或逻辑驱动测试。白盒测试主要是想对程序模块进行如下检查:

  1-对程序模块的所有独立的执行路径至少测试一遍。

  2-对所有的逻辑判定,取“真”与取“假”的两种情况都能至少测一遍。

  3-在循环的边界和运行的界限内执行循环体。

  4-测试内部数据结构的有效性,等等。

  2-集成测试(也叫组装测试、联合测试)是单元测试的逻辑扩展。它最简单的形式是:两个已经经过测试的单元组合成一个组件,并且测试它们之间的接口。从这一层上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合成程序的更大部分。方法是测试片段的组合,并最终扩展进程,将您的模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。

  3-系统测试是将经过测试的子系统装配成一个完整系统来测试。它是检验系统是否确实能提供系统方案说明书中制定功能的有效方法。(常见的联调测试)。系统测试的目的是对最终软件系统进行全面的测试,确保最终软件系统满足产品需求而遵循系统设计。

  4-验收测试是部署软件之前的最后一个测试操作。验收测试的目的是确保软件准备就绪,并且可以让用户将其执行软件的既定功能和任务。验收测试是向未来的用户表明系统能够像预订要求那样工作。经集成测试后,已经按照设计把所有的模块组装成一个完整的软件系统,接口错误也已经基本排除了,接着就应该进一步验证软件的有效性,这就是验收测试的任务,即软件的功能和性能如同用户所合理期待的那样。

  测试计划和测试详细规格、测试用例之间是战略和战术的关系,测试计划主要从宏观上规划测试活动的范围、方法和资源配置,而测试详细规格、测试用例是完成测试任务的具体战术。所以其中最重要的是测试策略和测试方法(最好能先评审)。

  编写软件测试计划的重要目的就是使测试过程能够发现更多的软件缺陷,因此软件测试计划的价值取决于它对帮助管理测试项目,并且找出软件潜在的缺陷。因此,软件测试计划中的测试范围必须高度覆盖功能需求,测试方法必须切实可行,测试工具并且具有较高的实用性,便于使用,生成的测试结果准确

  2-坚持“5W”规则,明确内容与过程

  “5W”规则指的是“WHAT(做什么)”、“WHY(为什么做)”、”WHEN(何时做)”、”WHERE(在哪里)”、”HOW(如何做)”。利用“5W”规则创建软件测试计划,可以帮助测试团队理解测试的目的(WHY),明确测试的范围和内容(WHAT),确定测试的开始和结束日期(WHEN),指出测试的方法和工具(HOW),给出测试文档和软件存放的位置(WHERE)。

  3-采用评审和更新机制,保证测试计划满足实际需求

  测试计划完成后,如果没有经过评审,直接发送给测试团队,测试计划内容的可能不准确或遗漏测试内容,或者软件需求变更引起测试范围的增减,而测试计划的内容没有及时更新,误导测试执行人员。

  4-分别创建测试计划与测试详细规格、测试用例

  应把详细的测试技术指标包含到独立创建的测试详细规格文档,把用于指导测试小组执行过程的测试用例放到独立创建的测试用例文档或测试用例管理数据库中。测试计划和测试详细规格、测试用例之间是战略和战术的关系,测试计划主要从宏观上规划测试活动的范围、方法和资源配置,而测试详细规格、测试用例是完成测试任务的具体战术。

  严格的从技术角度讲,所有的系统都会有瓶颈,因为大多数系统的资源配置不是协调的,例如CPU使用率刚好达到100%时,内存也正好耗尽的系统不是很多见。因此我们讨论系统瓶颈要从应用的角度讨论:关键是看系统能否满足用户需求。在用户极限使用系统的情况下,系统的响应仍然正常,我们可以认为改系统没有瓶颈或者瓶颈不会影响用户工作。

  因此我们测试系统瓶颈主要是实现下面两个目的:

  -发现“表面”的瓶颈。主要是模拟用户的操作,找出用户极限使用系统时的瓶颈,然后解决瓶颈,这是性能测试的基本目标。

  -发现潜在的瓶颈并解决,保证系统的长期稳定性。主要是考虑用户在将来扩展系统或者业务发生变化时,系统能够适应变化。满足用户目前需求的系统不是最好的,我们设计系统的目标是在保证系统整个软件生命周期能够不断适应用户的变化,或者通过简单扩展系统就可以适应新的变化。

  文档的完整性:主要是测试文档内容的全面性与完整性,从总体上把握文档的质量。例如用户手册应该包括软件的所有功能模块。

  描述与软件实际情况的一致性:主要测试软件文档与软件实际的一致程度。例如用户手册基本完整后,我们还要注意用户手册与实际功能描述是否一致。因为文档往往跟不上软件版本的更新速度。

  易理解性:主要是检查文档对关键、重要的操作有无图文说明,文字、图表是否易于理解。对于关键、重要的操作仅仅只有文字说明肯定是不够的,应该附有图表使说明更为直观和明了。

  文档中提供操作的实例:这项检查内容主要针对用户手册。对主要功能和关键操作提供的应用实例是否丰富,提供的实例描述是否详细。只有简单的图文说明,而无实例的用户手册看起来就像是软件界面的简单拷贝,对于用户来说,实际上没有什么帮助。

  印刷与包装质量:主要是检查软件文档的商品化程度。有些用户手册是简单打印、装订而成,过于粗糙,不易于用户保存。优秀的文档例如用户手册和技术白皮书,应提供商品化包装,并且印刷精美。

  另外一种观点就是主张写的粗些,类似于编写测试大纲。主张这种观点的人是因为软件开发需求管理不规范,变动十分频繁,因而不能按照欧美的高标准来编写测试用例。这样的测试用例容易维护,可以让测试执行人员有更大的发挥空间。

  实际上,软件测试用例的详细程度首先要以覆盖到测试点为基本要求。举个例子:“用户登陆系统”的测试用例可以不写出具体的执行数据,但是至少要写出五种以上情况(),如果只用一句话覆盖了这个功能是不合格的测试用例。覆盖功能点不是指列出功能点,而是要写出功能点的各个方面(如果组合情况较多时可以采用等价划分)。

  另一个影响测试用例的就是组织的开发能力和测试对象特点。如果开发力量比较落后,编写较详细的测试用例是不现实的,因为根本没有那么大的资源投入,当然这种情况很随着团队的发展而逐渐有所改善。测试对象特点重点是指测试对象在进度、成本等方面的要求,如果进度较紧张的情况下,是根本没有时间写出高质量的测试用例的,甚至有些时候测试工作只是一种辅助工作,因而不编写测试用例。

  因此,测试用例的编写要根据测试对象特点、团队的执行能力等各个方面综合起来决定编写策略。最后要注意的是测试人员一定不能抱怨,力争在不断提高测试用例编写水平的同时,不断地提高自身能力。

  配置测试的核心内容就是使用各种硬件来测试软件的运行情况,一般包括:

  (1)软件在不同的主机上的运行情况,例如Dell和Apple;

  (2)软件在不同的组件上的运行情况,例如开发的拨号程序要测试在不同厂商生产的Modem上的运行情况;

  (3)不同的外设;

  (4)不同的接口;

  (5)不同的可选项,例如不同的内存大小;

  兼容性测试的核心内容:

  (1)测试软件是否能在不同的操作系统平台上兼容;

  (2)测试软件是否能在同一操作系统平台的不同版本上兼容;

  (3)软件本身能否向前或者向后兼容;

  (4)测试软件能否与其它相关的软件兼容;

  (5)数据兼容性测试,主要是指数据能否共享;

  配置和兼容性测试通称对开发系统类软件比较重要,例如驱动程序、操作系统、数据库管理系统等。具体进行时仍然按照测试用例来执行。

  -包装文字和图形;

  -市场宣传材料、广告以及其它插页;

  -授权、注册登记表;

  -最终用户许可协议;

  -安装和设置向导;

  -用户手册;

  -联机帮助;

  -样例、示范例子和模板;

  -……

  文档测试的目的是提高易用性和可靠性,降低支持费用,因为用户通过文档就可以自己解决问题。因文档测试的检查内容主要如下:

  -读者对象——主要是文档的内容是否能让该级别的读者理解;

  -术语——主要是检查术语是否适合读者;

  -内容和主题——检查主题是否合适、是否丢失、格式是否规范等;

  -图标和屏幕抓图——检查图表的准确度和精确度;

  -样例和示例——是否与软件功能一致;

  -拼写和语法;

  -文档的关联性——是否与其它相关文档的内容一致,例如与广告信息是否一致;

  文档测试是相当重要的一项测试工作,不但要给予充分的重视,更要要认真的完成,象做功能测试一样来对待文档测试。

  在这种做法基本上把软件当成了产品说明书,测试过程中要和开发人员不断的进行交流。尤其在作项目的时候,进度压力比较大,可以作为加急测试方案。最大的风险是不知道有些特性是否被遗漏。

  为了克服这种现象,测试人员需要不断编写新的测试程序或者测试用例,对程序的不同部分进行测试,以发现更多的缺陷。也可以引用新人来测试软件,刚刚进来的新手往往能发现一些意想不到的问题。

  需要注意的是,配置问题可以在一大类配置中出现。例如,拨号程序可能在所有的外置Modem中都存在问题,而内置的Modem不会有任何问题。

  -完全测试比较耗时,时间上不允许;

  -完全测试通常意味着较多资源投入,这在现实中往往是行不通的;

  -输入量太大,不能一一进行测试;

  -输出结果太多,只能分类进行验证;

  -软件实现途径太多;

  -软件产品说明书没有客观标准,从不同的角度看,软件缺陷的标准不同;

  因此测试的程度要根据实际情况确定。

  因此,我们要尽可能的选择最合适的测试量,把风险降低到最小。

  -代码复用、拷贝代码导致程序员容易犯相同的错误。类的继承导致所有的子类会包含基类的错误,反复拷贝同一代码意味可能也复制了缺陷。

  -程序员比较劳累是可以导致某些连续编写的功能缺陷较多。程序员加班是一种司空见惯的现象,因此体力不只时容易编写一些缺陷较多的程序。而这些连续潜伏缺陷恰恰时测试工程师大显身手的地方。

  “缺陷一个连着一个”不是一个客观规律,只是一个常见的现象。如果软件编写的比较好,这种现象就不常见了。测试人员只要严肃认真的测试程序就可以了。

  -没有足够的时间资源。在任何一个项目中,通常情况下开发人员和测试人员都是不够用的,而且在项目中没有预算足够的回归测试时间,再加上修改缺陷可能引入新的缺陷,因此在交付期限的强大压力下,必须放弃某些缺陷的修改。

  -有些缺陷只是特殊情况下出现,这种缺陷处于商业利益考虑,可以在以后升级中进行修复。

  -不是缺陷的缺陷。我们经常会碰到某些功能方面的问题被当成缺陷来处理,这类问题可以以后有时间时考虑再处理。

  最后要说的是,缺陷是否修改要由软件测试人员、项目经理、程序员共同讨论来决定是否修复,不同角色的人员从不同的角度来思考,以做出正确的决定。

  软件测试和质量是相辅相成的关系,都是为了提高软件质量而工作。

  -加强部门内员工之间的互相学习,互相学习是建立学习型组织的基本要求,是知识互相转移的过程。在此基础上,可以把个人拥有的技术以知识的形式沉积下来,也就完成了隐性知识到显性知识的转化。

  -通常情况下,企业能为员工提供足够大的发展空间时,如果不是待遇特别低,员工都不会主动离开企业。因此我们要想留住员工,管理者就应该把员工的个人成长和企业的发展联系起来,为员工设定合理发展规划并付诸实现。不过这项要求做起来比较,要有比较好的企业文化为依托。

  -质量要求不同。通常产品的质量要高一些,修复发布后产品的缺陷成本较高,甚至会带来很多负面的影响。而做项目通常面向某一用户,虽然质量越高越好,但是一般只要满足用户要求就可以了。

  -测试资源投入多少不同。做软件产品通常是研发中心来开发,进度压力要小些。同时由于质量要求高,因此会投入较多的人力、物力资源。

  -项目最后要和用户共同验收测试,这是产品测试不具有的特点。

  此外,测试产品与测试项目在缺陷管理方面、测试策略制定都会有很大不同,测试管理者应该结合具体的环境,恰如其分的完成工作。

  实际上用户现场测试更趋于是一种演示。在不欺骗用户的前提下,我们向用户展示我们软件的优点,最后让“上帝”满意并欣然掏出“银子”才是我们的目标。因此用户测试要注意下面的事项:

  (1)用户现场测试不可能测试全部功能,因此要测试核心功能。这需要提前做好准备,这些核心功能一定要预先经过测试,证明没有问题才可以和用户共同进行测试。测试核心模块的目的是建立用户对软件的信心。当然如果这些模块如果问题较多,不应该进行演示。

  (2)如果某些模块确实有问题,我们可以演示其它重要的业务功能模块,必要时要向用户做成合理的解释。争得时间后,及时修改缺陷来弥补。

  (3)永远不能欺骗用户,蒙混过关。道理很简单,因为软件是要给用户用的,问题早晚会暴露出来,除非你可以马上修改。

  和用户进行测试还要注意各种交流技巧,争取不但短期利益得到了满足,还要为后面得合作打好基础。

  测试报告一般分为内部测试报告和外部测试报告。内部报告是我们在测试工作中的项目文档,反映了测试工作的实施情况,这里不过多讨论,读者可以参考相关教材。这里主要讨论一下外部测试报告的写法,一般外部测试报告要满足下面几个要求:

  -根据内部测试报告进行编写,一般可以摘录;

  -不可以向客户报告严重缺陷,即使是已经修改的缺陷,开发中的缺陷也没有必要让客户知道;

  -报告上可以列出一些缺陷,但必须是中级的缺陷,而且这些缺陷必须是修复的;

  -报告上面的内容尽量要真实可靠;

  -整个测试报告要仔细审阅,力争不给项目带来负面作用,尤其是性能测试报告。

  总之,外部测试报告要小心谨慎的编写。

  对于自动测试技术,应当依据软件的不同情况来分别对待,一般自动技术会应用在引起大量重复性工作的地方、系统的压力点、以及任何适合使用程序解决大批量输入数据的地方。然后再寻找合适的自动测试工具,或者自己开发测试程序。一定不要为了使用测试工具而使用。

  常见的软件测试面试题划分等价类: 等价类是指某个输入域的子集合.在该子集合中,各个输入数据对于揭露程序中的错误都是等效的.并合理地假定:测试某等价类的代表值就等于对这一类其它值的测试.因此,可以把全部输入数据合理划分为若干等价类,在每一个等价类中取一个数据作为测试的输入条件,就可以用少量代表性的测试数据.取得较好的测试结果.等价类划分可有两种不同的情况:有效等价类和无效等价类.

  2-边界值分析法

  边界值分析方法是对等价类划分方法的补充。测试工作经验告诉我,大量的错误是发生在输入或输出范围的边界上,而不是发生在输入输出范围的内部.因此针对各种边界情况设计测试用例,可以查出更多的错误.

  使用边界值分析方法设计测试用例,首先应确定边界情况.通常输入和输出等价类的边界,就是应着重测试的边界情况.应当选取正好等于,刚刚大于或刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值作为测试数据.

  3-错误推测法

  基于经验和直觉推测程序中所有可能存在的各种错误, 从而有针对性的设计测试用例的方法.

  错误推测方法的基本思想: 列举出程序中所有可能有的错误和容易发生错误的特殊情况,根据他们选择测试用例-例如, 在单元测试时曾列出的许多在模块中常见的错误-以前产品测试中曾经发现的错误等, 这些就是经验的总结。还有, 输入数据和输出数据为0的情况。输入表格为空格或输入表格只有一行-这些都是容易发生错误的情况。可选择这些情况下的例子作为测试用例.

  4-因果图方法

  前面介绍的等价类划分方法和边界值分析方法,都是着重考虑输入条件,但未考虑输入条件之间的联系, 相互组合等-考虑输入条件之间的相互组合,可能会产生一些新的情况-但要检查输入条件的组合不是一件容易的事情, 即使把所有输入条件划分成等价类,他们之间的组合情况也相当多-因此必须考虑采用一种适合于描述对于多种条件的组合,相应产生多个动作的形式来考虑设计测试用例-这就需要利用因果图(逻辑模型)-因果图方法最终生成的就是判定表-它适合于检查程序输入条件的各种组合情况.

  5-正交表分析法

  有时候,可能因为大量的参数的组合而引起测试用例数量上的激增,同时,这些测试用例并没有明显的优先级上的差距,而测试人员又无法完成这么多数量的测试,就可以通过正交表来进行缩减一些用例,从而达到尽量少的用例覆盖尽量大的范围的可能性。

  6-场景分析方法

  指根据用户场景来模拟用户的操作步骤,这个比较类似因果图,但是可能执行的深度和可行性更好。

  黑盒法用例设计的关键同样也是以较少的用例覆盖模块输出和输入接口。不可能做到完全测试,以最少的用例在合理的时间内发现最多的问题

  2-开发人员根据需求文档完成需求分析文档,测试人员进行评审,评审的主要内容包括是否有遗漏或者双方理解不同的地方。测试人员完成测试计划文档,测试计划包括的内容上面有描述。

  3-测试人员根据修改好的需求分析文档开始写测试用例,同时开发人员完成概要设计文档,详细设计文档。此两份文档成为测试人员撰写测试用例的补充材料。

  4-测试用例完成后,测试和开发需要进行评审。

  5-测试人员搭建环境

  6-开发人员提交第一个版本,可能存在未完成功能,需要说明。测试人员进行测试,发现bug后提交给bugzilla。

  7-开发提交第二个版本,包括bug fix以及增加了部分功能,测试人员进行测试。

  8-重复上面的工作,一般是3-4个版本后bug数量减少,达到出货的要求。

  9-如果有客户反馈的问题,需要测试人员协助重现以及回归测试。

  也曾经做过软交换系统的呼叫性能测试,主要是测试软交换系统在有大量呼叫的情况下,响应时间,呼叫成功率,cpu/磁盘/内存等参数是否满足设计要求。

  2-和bug产生对应的软件版本

  3-开发的接口人员

  4-bug的优先级

  5-bug的严重程度

  6-bug可能属于的模块,如果不能确认,可以用开发人员来判断

  7-bug标题,需要清晰的描述现象

  8-bug描述,需要尽量给出重新bug的步骤

  9-bug附件中能给出相关的日志和截图。

  高质量的bug记录就是指很容易理解的bug记录,所以,对于描述的要求高,能提供的信息多且准确,很好的帮助开发人员定位。

  测试软交换系统的时候,使用的prolab来模拟终端并发送呼叫软交换,他完成了同时数百人才能完成的摘机拨号工作,主要工作原理是产生一些符合要求的ip包并发送给软交换系统,同时对软交换系统的回应进行处理,决定下一步动作。

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

我的软件测试面试经历,7轮高强度面试顺利入职

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

我的软件测试面试经历,7轮高强度面试顺利入职

 我的软件测试面试经历,7轮高强度面试顺利入职

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/153089.html

(0)
上一篇 2025-03-05 22:33
下一篇 2025-03-05 22:45

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信