通江网站建设,中国万网网站建设过程,培训班管理系统 免费,关于加强公司 网站建设的通知一、测试理论
3.1 你们原来项目的测试流程是怎么样的?
我们的测试流程主要有三个阶段#xff1a;需求了解分析、测试准备、测试执行。
1、需求了解分析阶段 我们的 SE 会把需求文档给我们自己先去了解一到两天这样#xff0c;之后我们会有一个需求澄清会议#xff0c; …
一、测试理论
3.1 你们原来项目的测试流程是怎么样的?
我们的测试流程主要有三个阶段需求了解分析、测试准备、测试执行。
1、需求了解分析阶段 我们的 SE 会把需求文档给我们自己先去了解一到两天这样之后我们会有一个需求澄清会议 我们会把不明白不理解的需求在会议上说出来包含需求的合理性还有需求的可测性等 产品这边解答目的是让我们测试这边和开发对需求的理解达到一致。
2、测试准备阶段 会议结束之后我们开始准备测试工作我们测试这边会写一个测试计划分配每个人负责的模块 然后我们就根据自己负责的模块用 xmind(思维导图)进行测试需求分析分析测试点 以及编写测试用例之后我们会在自己的组内先进行评审评审修改之后还会在我们的项目组评审 评审完后进行修改测试用例。
3、测试执行阶段 开发人员编写好代码之后我们会把代码包通过 Jelkins 部署到测试环境提测进行 SIT 测试 在正式测试之前我们会先做一个冒烟测试冒烟测试通过之后我们才转测在执行测试的过程中 我们如果发现 bug 就会用 tapd(或者禅道)记录并且提交 bug也会进行 bug 复测以及回归测试 每一轮测试结束之后我们都会写一个测试报告一般情况下测试 4-5 轮之后会达到上线要求 当达到上线的标准后测试报告会认为测试通过上线前我们会做预发布测试预发布通过后 由项目组与产品决定时间上线上线完成一周左右我们会写一个项目总结测试报告 总结我们在上一个版本中遇到的问题以及今后有哪些地方需要改进在产品选代过程中 我们会跑自动化用例来进行回归测试。
3.2 如果需求不明确的话你怎么办?
需求不明确的话我会在需求澄清会议上面提出来问清楚这个需求只有明确需求 才能更好的完成工作后续工作中还是不清楚可以找产品再去确认这个需求。
3.3 有哪些需要评审哪些人在
1、 xmind 思维导图评审主要是测试人员 2、测试用例需要评审测试人员开发人员产品人员 3、需求文档项目组所有的人员都会到场
3.4 有没有写过测试计划具体包括哪些内容?
参考答案 1 测试计划内容 (1)目的和范围 (2)规程 (3)测试方案和方法 (4)测试的准入和准出 (5)测试计划(流程、时间安排、对应人员) (6)测试的环境配置和人员安排 (7)交付件 华测教育专属 华测教育专属 华测教育专属 华测教育专属 华测教育专属 华测教育专属 华测教育专属 华测教育专属 华测教育专属 15 参考答案 2 我们公司之前按照考核要求写过测试计划不过后面老大觉得太耽误工作进度 后面一般都不再写测试计划而是写版本计划这个在版本计划每个人的任务列出来 负责人列出来自己根据自己的情况分配时间然后汇总大家一起开个小会评审就可以了。
3.5 用例包含哪些部分哪些用例设计方法你一般常用哪些方法?
原来我们用例包含 测试项目用例编号、测试标题、优先级、预置条件、操作步骤、测试数据、预期结果 黑盒测试用例设计方法主要是等价类、边界值、错误推测法、判定表、因果图、正交表、 流程分析法、状态迁移法、异常分析法。 常用的等价类、边界值、判定表、流程分析法、错误推测法。 等价类是指某个输入域的子集合在该子集合中 各个输入数据对于揭露程序中的错误都是等效的 并合理地假定测试某等价类的代表值就等于对这一类其它值的测试因此可以把全部 输入数据合理划分为若干等价类在每一个等价类中取一个数据作为测试的输入条件 就可以用少量代表性的测试数据取得较好的测试结果 等价类划分可有两种不同的情况有效等价类和无效等价类。 边界值的话就是对等价类划分方法的补充。测试工作经验告诉我大量的错误往往是发生在输入或输 出范围的边界上而不是发生在输入输出范围的内部因此的话针对各种边界情况来设计测试用例可 以查出更多的错误使用边界值分析方法设计测试用例的话首先应该确定边界情况通常输入和输 出等价类的边界就是应着重测试的边界情况应当选取正好等于刚刚大于或刚刚小于边界的值作为 测试数据而不是选取等价类中的典型值或任意值作为测试数据。 对于错误推断法这个是基于经验和直觉推测程序中所有可能存在的各种错误 从而有针对性的去设计测试用例的方法的主要就是列举出程序中所有可能有的错误和容易发生错误 的特殊情况去根据这些情况来选择测试用例例如在单元测试时曾列出的许多在模块中常见的错误 以前产品测试中曾经发现的错误等这些就是经验的总结。还有输入数据和输出数据为 0 的情况。 输入表格为空格或输入表格只有一行。这些都是容易发生错误的情况可选择这些情况下的例子作为 测试用例。 前面介绍的等价类划分方法和边界值分析方法都是着重考虑输入条件但都没有考虑输入条件之间的 联系相互组合等等的情况。考虑输入条件之间的相互组合可能会产生一些新的情况 但是要检查输入条件的组合并不是一件容易的事情即使把所有输入条件划分成等价类 他们之间的组合情况也相当多因此的话可以考虑采用一种适合于描述对于多种条件的组合相应产生多个动作的形式来考虑设计测试用例这就需要用到因果图(逻辑模型)。 因果图方法最终生成的就是判定表它适合检查程序输入条件的各种组合情况。
3.6 TestLink 工具使用?
(1)创建用户并给新创建的用户指定权限。 (2)创建测试用例对测试用例进行增、删、改、查 (3)把测试用例关联到对应的测试计划中。 (4)把测试用例指派给对应的测试人员。 (5)对应的测试人员查看被指派的测试用例并执行测试用例。
3.7 如何提交一个好的 BUG
对 BUG 有一个清晰明了的描述 详细描述 BUG 重现的步骤 对于产生 BUG 的环境进行描述 提交 BUG 相关的图片和日志; 定位好 BUG 的等级 将预期结果与实际结果进行对比。
3.8 提 bug 需要注意哪些问题?
1) 不要急着提交先跟开发说明 bug 的情况定位分析下 bug。 是前端问题还是后端问题再去提交 bug。 2) 简单明了的概括 bug 标题清晰的描述 bug 重现步骤分析 bug 和预期正确结果附加 bug 的截 图或者日志。描述 bug 的时候。 3) 在不能确认该情况是否为 bug 的时候可以请教其他人。 4) 提交完 bug 以后后面还要跟踪 bug 修复情况。
3.9 bug 怎么管理的bug 的生命周期或者是 bug 的状态
原来 bug 是用禅道来管理的 原来我们公司 bug提交 bug 直接给对应的开发人员对应开发人员修复完成交给测试复测 复测通过关闭 bug不通过打回给对应开发。 提交-开发人员(已激活未确认)-开发进行确认状态变成已激活已确认开发修复完成 标注状态是已修复测试人员复测通过已关闭打回给对应开发已经激活。
3.10 提交 bug 包含哪些内容
所属产品、所属模块、所属项目、影响版本、指派人员 截止日期、严重程度、优先级、bug 类型、bug 环境 Bug 标题、重现步骤、附件
3.11 你提交的 bug开发不认可怎么办?
首先我会再看需求文档是不是我的理解有误如果是我对需求理解错的话我就去关闭 bug。 如果是 bug 再去让其他测试人员看看听下他们的意见然后自己先再三去复测并目保存好截图和日 志确定这是一个 bug 之后我就去跟开发说明白并且给他看 bug 重现的截图以及日志如果开发还 是不认可的话我就跟产品或项目经理说明白情况。
3.12 对应无法重现 bug应该怎么处理?
首先我会多测几次测了好多次都无法重现的话我就先把 bug 挂起并且留意一下看看往后的测 试中如果在后面的测试中重现 bug 就激活如果经过几个版本都还没发现的话就关闭 bug。
3.13 界面中的乱码可以是哪里导致的?
(1)数据库中的编码设置 (2)前端页面编码 (3)后台代码也会编码
3.14 bug 的级别有哪些级别如何判断
1、致命对业务有至关重要的影响业务系统完全丧失业务功能无法再继续进行 或业务系统丢失了业务数据且无法恢复影响公司运营的重要业务数据出错。 2、严重对业务有严重的影响业务系统已经丧失可部分的重要的业务功能或业务系统 丢失了业务数据且可以恢复一般业务数据出错。 3、一般对业务有较小的影响业务系统丧失了较少的业务功能 例如界面错误打印或显示格式错误。 4、提示对业务没有影响不影响业务过程正常进行 例如辅助说明描述不清楚提示不明确的错误提示。
3.15 测试中如何判断是前端的 bug 还是后端的 bug 呢?
通常可以利用抓包工具来进行分析。可以从三个方面进行分析请求接口、传参数、响应。 1请求接口 un 是否正确如果请求的接口 ur 错误为前端的 bug 2传参是否正确如果传参不正确为前端的 bug 3请求接口 u 和传参都正确查看响应是否正确如果响应内容不正确为后端 bug 4也可以在浏览器控制台输入 js 代码调试进行分析
3.16 项目上线后发现 bug测试人员应该怎么办
看严重级别严重还是不严重 严重的紧急变更上线 不严重修复好后跟下个版本一起上线 用户会通过运维反馈到项目组这边项目经理会根据功能模块的负责人分给对应的开发与测试。 测试人员编写对应的测试用例、测试环境中重现 bug、提交 bug、 交给开发进行修复、修复完成 bug、进行 bug 的复测。 如果测试环境无法重现可以导入生产环境的包到测试环境中测试 还是不能复现查看生产环境的日志去定位问题。
3.17 如何保证质量
(1)需求要吃透多问多去了解。 (2)严格按照测试流程去执行多考虑用户测试场景使用测试用例设计方法多评审。 (3)要有良好的测试执行要求用例执行率达到 100%多轮测试进行探索性测试 需要测试之间交叉测试用工具来管理我们的测试工作(禅道 testlink exceltapd) (4)不断的反思与提升。
3.18 产品是怎么上线的?
一般我们会选择晚上上线开发测试还有产品全部到场进行上线测试。 首先开发将代码打包到生产环境的服务器中如果数据表有变化就会运行 sql 文件 对表的一些操作接着我们测试就开始先测试主体业务功能以及新增的功能模块; 测试通过之后我们会在界面上把上线测试的数据删除正常上线。 如果发现 bug开发人员当场修复 bug修复成功之后我们测试再复测通过就可以正常上线 如果发现了 bug 开发人员在上线规定时间之前都还没有修复好的话就看问题的严重性 如果严重就延期上线如果我们是迭代版本的话我们还需要版本回滚。 如果不严重产品跟客户觉得可以上线就正常上线。
二、接口测试
9.1 接口测试怎么测
jmeter 版本 首先开发会给我们一个接口文档我们根据开发给的接口文档进行测试点的分析主要是考虑正常 场景与异常场景正常场景条件的组合参数的格式校验等价边界值;异常场景多一个参数少 个必填参数参数为空;接着编写测试用例用的 Jmeter 工具去运行创建线程组建立 http 请求 输入测试用例请求参数建立察看结果树运行看返回的结果是否跟接口文档里面要求的返回 结果一致其他用例值需要修改里面的参数请求地址这些信息。 举例说明(不要登录跟注册) 比如说原来我们做一个申请借款的接口对接口进行测试分析考虑正常场景与异常场景正常场景 考虑不同参数组合比如说不同借款方式还款期限还款曰期借款的利率等参数组合;也要测 试每个参数格式校验异常场景多一个参数少一个必填参数比如没有借款的利率参数为空 的比如借款标题为空编写测试用例 在 jmeter 中执行填写参数更地址就 ok发送请求 python request 原来我们接口主要是用的 python requests 去运行的 首先开发会给我们一个接口文档拿到接口文档后我们就进行测试点的分析 考虑正确场景条件的组合 异常场景多一个参数少一个参数参数为空的情况 比如原来我们做一个生成订单的接口考虑正常场景异常场景 正常场景就是不同的订单类型订单金额能不能申请订单每个参数的格式类型的校验 异常场景多一个参数少一个必填参数的时候还有参数为空的情况 原来我们是用 python request 去做的接口 首先导入 request 包 建立一个 headers保存请求头的信息因为订单请求方式是 post 类型数据格式是 form 表单格式 我们把数据保存到 data 的字典里面 这个时候我们还需求登录的 cookie 值跟登录后产生的 token 值 我们会去通过动态关联去获取登录的 token 跟 cookies cookies 值的话我们是直接调用登录返回的 cookies、token 值的时候我能是通过导入 re 模块 通过正则表达式去提取 当参数 headers、cookies 输入完成以后我们就发送请求打印返回结果检返回结果是否跟我 们测试用例一致 当运行其他测试用例时我们去修改 data 里面的参数就行在发送请求 有的请求时 htps 协议的时候我们发送请求的时候还会 very false 去忽略掉证书验 证对应多个接口调用 cookies 我们会用到 session 去保存接口发现比较多的问题就是格式校验这 块 比如说我们提交订单订单数据没有显示订单格式也没有显示输入字母汉字都可以 订单类型为空也会生成订单成功 我觉得接口可以发现接口更多的 bug还可以提早进行测试提高测试的质量
9.2 两个接口有关联 jmeter 具体怎么做
另外两种问法上个接口的返回值是下个接口的请求参数这种如何处理?动态关联有没有了解过? 这个涉及到动态关联首先要搞清楚后一个接口需要用到上一个接口的什么数据例外要看数据是在 哪里取的是在 head 还是在 body 里然后如果要取的数据是 json 格式我会在发请求用 json 提取器 去取这个数据如果是其他格式的就用边界提取器或正则表达式去取数据 就拿我当时做的那个下单接口来说吧因为下单接口需要先登录需要用到登录接口的 cookies 来做鉴权首先就是把登录接口调试通过然后在登录接口的 http 请求中添加一 个边界值提取器或者也可以用正则表示式提取器去提取登录接口的响应头中的 cookies 值 然后在下单接口中需要添加一个 http cookies 管理器在 http cookies 管理器中引用登录 接口提取出来的 cookies这样就可以了 如果是不同的线程组的话那在登录接口中还得添加一个 Beanshell 取样器在 Beanshell 取样器中利用函数助手中的 SetProperty()函数把提取出来的 cookies 设置为全局变量 然后在下单接口的 http cookies 管理器中利用函数助手中的 Property()函数引用登录接口中设置的 全局变量这样就可以了。
9.3 接口测试主要目的是什么?
例外两种问法接口测试的价值意义?为什么要做接口测试? 主要就是验证后台服务端的业务逻有没有问题提高测试的效率 ①越底层发现 bug它的修复成本是越低的 ②前端页面修改频繁情况下接口测试不受页面元素改变而影响 ③检查系统的安全性前端传参不可信比如京东购物前端价格不可能传入-1 元但是 通过接口可以传入-1 元 ④如今的系统复杂度不断上升传统的测试方法成本急剧增加且测试效率大幅下降接口自动化测试 可以提高测试效率 ⑤接口测试相对容易实现自动化持续集成且相对 U 自动化也比较稳定可以减少人工回归测试人 力成本与时间缩短测试周期
9.4 接口测试的流程
1首先分析开发给到的接口文档 2接口文档分析完成编写测试用例 3然后借助接口测试工具去测试执行测试用例 4发现 bug 提交 bug并跟进 bug 修复
9.5 接口测试和平常的 Ul 测试有什么区别?
其实这两者测试的侧重点是不同的接口因为没有界面更多考虑后台服务器对请求的处理逻辑问 题业务交互检测的是后台“容错机制”是否完整 而 ui 更多会去关注页面展示数据转换界面排序这些功能当然也会后台数据处理的问题ui 测 试其实已经包含了接口测试。系统功能的用例更全面不仅有界面的也有业务功能用例还有其他 用户场景的用例功能入口用例流程用例而接口测试主要根据各种入参场景来设置用例。
9.6 给你一个新的接口你怎么去设计用例?
首先要对于每个要测的接口都要先搞清楚这个接口的功能它的作用是什么熟悉这个业务功能需要 用到什么协议请求方式是什么接口有哪些参数。对于每个参数的作用都要搞清楚像数的类型 是否有约束限制是否为必填的长度其他的限制等等如果两个参数之间有关联我们还要考虑参 数的组合场景对于参数不理解的一般都会跟开发沟通下然后考虑返回数据的类型返回数据中 的返回码和返回信息是什么通过以上几个点去提炼测试点设计用例。 参数约束——长度、必选项、格式、数据类型 业务场最——正确的业务场景;错误的业务场景异常场景服务器空间不足 组合场景——相互依赖手机和验证码、用户名和验证码 相互排斥二选一当然还有边界值等价类等等 Jmeter 测试流程步骤如下 创建 jmeter 线程组一添加 HPPT 请求-输入协议-域-端口-路径-编码-请求方式-请求参数-启动 Jmeter 测试流程 先需求再根据需求写测试点转换成测试用例根据测试用例编写测试脚本执行测试脚本 提交 BUG跟踪 BUG
9.7 接口文档主要包含哪些内容?
接口文档一般两种形式的要不就是 word 版本的要不就是 htm 的形式具体内容 1URL(接口地址) 2接口功能 3请求方式post 4请求参数以及接口中每个参数的详细说明类型是否为必填约束条件等等 5响应数据及格式返回码返回码解释等等
9.8 你们什么时候测试接口
一般有需求就会做后台的接口开发好就可以开始测。例外如果增加了新需求也要做接口测试 还有就是开发对后台的接口做了修改交互逻辑发生变化我们也要重新对接口进行测试。
9.9 你怎么去检查分析
我们主要是根据入参情况去看接口的返回值对于返回值我主要关注的几个点1.状态码 2.提示信息 3.返回数据的具体内容。根据接口文档的说明去检查这个 3 个点是否满足接口需求文档 4.有些如果要检查数据库的就连接数据库获取数据与返回的数据做对比。 如果不满足就是有问题如果满足则通过如果有 Bug 我们会先大概分析下是什么原因 并进行复测如果还是有问题提交 Bug 给开发让开发修复之后再回归测试
9.10 什么是 api 接口测试
接口测试主要用于检测外部系统与系统之间以及内部各个子系统之间的交互点测试的重点 是要检查数据的交换传递和控制管理过程以及系统间的相互逻辑依赖关系等
9.11 什么情况下开展接口测试?
1、项目处于开发阶段 2、有接口需求文档开发已完成联调功能测试展开之前 3、专项测试参数约束测试业务场景测试测试接口请求响应时间性能 4、版本上线前进行整体回归测试查看接口是否有异常(如 404 等)
9.12 依赖于第三方的接口如何测试
1需要第三方接口的接口文档 2发送请求到第三方接口检查第三方接口返回的数据是否正确 3不正确的时候要跟第三方接口联调看是请求问题还是第三方接口返回数据有误 这个我们公司的第三方接口我们都是打通的比如电商我们通过调用微信接口等等都是打通的 比如要测试下单第三支付我们自己开店收款设置我们自己的账号然后通过商品设计 1 分钱去 测试的。 如果不打通的话基本也只能抓包主要保证我们发送出去的数据符合需求文档就行然后真正的上 线之前我们会在预生产环境做一个联调测试把各自系统连在一起做一个联调测试没有问题了 我们就可以上线基本就这么做的 联调测试怎么做的 其实联调测试就是数据拉通测试两个子系统连在一起形成一个完整的系统然后从上游下数据下游接到数据看传过来的数据是否符合下游的系统要求然后下游做了操作把数据返回给上游通知 上游说数据返回了上游看返回的数据是否符合要求如果没有问题就这个数据就拉通成功这个都 是按照用例来执行上游和下游一起出一份用例两边都评审通过然后按照测试用例执行每条用 例测试通过那么联调测就完成了。
9.13 你们接口怎么鉴权的?
(1)通过用户和密码auth 鉴权 (2)通过 cookie 和 session (3)通过 token (4)通过 sign 签名 现在 app 一般是通过 token 鉴权有些是通过把 token 放在请求头里面有些是通过 singn 签名这 个字段放在 body 里面去鉴权的一般的 web 是通过 session 去鉴权的
9.14 接口传输格式有哪些
常见的媒体格式类型如下 text/htmlHTML 格式 text/plain纯文本格式 text/xmXML 格式 Image/gifgif 图片格式 mage/jpegjpg 图片格式 Image/ngpng 图片格式 以 application 开头的媒体格式类型 application/xhtm xml XHTML 格式 application/mlXML 数据格式 application/atom xml Atom XML 聚合格式 application/jsonJsoN 数据格式 application/pdfpdf 格式 application/mswordWord 文档格式 application/octet-stream二进制流数据(如常见的文件下载) application/x-www-form-urlencodedencoded
中默认的 encType,form 表单数据被编码为 key/value 格式发送到服务器(表单默认的提交数据的格式) 另外一种常见的媒体格式是上传文件之时使用的 multipart/form-data需要在表单中进行文件上传时就需要使用该格式
9.15 cookie、session、token 的区别
它们都是用来做鉴权的区别的话大概是这样的 1、现在 cookie、session 一般是配合使用的用户第一次登陆时服务器会创建一个 session 生成一个 sessionIDsessionID 保存在 cookie 中然后返回到客户端保存在浏览器中。 客户端每次发请求都会把这个值带到服务器做一个鉴权和会话的跟踪或者时效的验证 2、token 和 cookie、session 差不多通过算法每次验陆会产生一串很长的随机字符串一般 是在放在返回的 body 里面或者返回的头里面他们都是服务器产生带过来是要做验证和时效的 验证的。一般在 app 中使用 token 比较多一点Web 端使用 cookie、session 的鉴权方式会多一点。
9.16 接口测试的工具有哪些?
Fiddler 抓包工具也可以做接口测试 Postman 接口测试工具支持接口自动化测试 wireshark 支持电脑上各种协议的抓包工具主要常见有 http 和 tcp 抓包 Soapui 功能强大的接口测试工具性能测试接口自动化测试 javahttpclient.jar java 代码实现接口自动化测试一般需要借助单元测试框架 junit 和 TestNG 接口自动化测试框架设计javahttpclientTestNG Python requests python 代码实现接口与接口自动化测试测试框架 unittestpytest 接口测试框架设计 python requests unittest htmlTestRunner 或者 python requests pytest Loadrunner 接口自动化测试接口性能测试(主要) jmeter 接口测试接口自动化测试接口性能测试(主要) Swagger 编写在线接口文档在线接口测试
行动吧在路上总比一直观望的要好未来的你肯定会感 谢现在拼搏的自己如果想学习提升找不到资料没人答疑解惑时请及时加入扣群 320231853里面有各种软件测试开发资料和技术可以一起交流学习哦。
最后感谢每一个认真阅读我文章的人礼尚往来总是要有的虽然不是什么很值钱的东西如果你用得到的话可以直接拿走 这些资料对于【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴上万个测试工程师们走过最艰难的路程希望也能帮助到你