zoukankan      html  css  js  c++  java
  • 软件测试知识点总结

    软件测试:特定的环境、特定的条件下运行软件,验证其能正常运行,并发现其缺陷,对软件的质量进行评估的过程;

    软件测试过程:设计、计划、实现、执行;

    软件测试流程:需求、计划、方案、用例、执行、总结;

    lampp(xampp):apache+mysql+php+per;

    wampp:windows+apache+mysql+php;

    apache的http的默认端口为80,https的默认端口为443;

    (http端口设置在xampp文件下httpd.conf,https端口设置在xampp文件下的http—ssl.conf)

    数据库mysql的默认端口为3306,oracle的默认端口为1521;

    在控制命令符中查看端口的占用情况命令:netstat  -ano | findstr  “80”

    SVN的使用:上传commit、更新update、查看日志、更新版本、clean up;

    几个人同时编辑文档:先锁定、再编辑、再提交;

    1、测试需求

    测试需求分析:分析识别测试范围,解决测什么的问题,方便测试的跟踪和管理;

    测试需求分析的流程需求采集—>需求分析—>需求评审;

    测试需求分析的评审:完整性、准确性、一致性、易理解性、无歧义性;

    测试需求分析的时间:开发需求完成后;

    负责人:有丰富经验的测试工程师;

    参考依据:

    (1)狭义依据:需求规格;

    (2)广义依据:参照上面的测试需求分析来源;

    在测试需求不明确的情况下,如何保证测试质量:

    (1)多方收集需求;

    (2)多与开发人员沟通;

    (3)若有以前的系统,参照以前的系统;

    (4)找类似的产品熟悉;

    (5)到网上查找与系统相关的业务知识、专业术语;

    测试需求分析的来源:

    (1)开发文档:需求规格、概设、详设、数据库结构设计文档、模块功能图等;

    (2)用户需求:与用户或需求分析人员沟通,需求调研的会议纪要,与用户邮件往来;

    (3)软件雏形:可运行软件,软件的框架;

    (4)相关的规划及标准:各行各业的标准、国家标准、行业标准、企业标准、项目标准、国家法律法规;

    (5)类似的产品:公司内部相同的旧版本产品,行业其他公司类似的产品;

    (6)测试知识经验库:测试人员的业务背景、系统业务知识的积累、个人的测试经验积累;

    (7)其他隐性的需求:产品利益相关者的建议、会议纪要、备忘录、沟通记录、邮件往来等;

    测试需求分析的内容:

    (1)业务流程图的分析;

    (2)用户和角色的分析;

    (3)数据库结构的分析;

    (4)测试要点的分析;

    测试需求分析的方法:

    (1)测试功能点分析法;

    (2)功能交互分析法;

    (3)质量特性分析法;

    (4)测试类型分析法;

    2、测试计划

    测试计划:管理层文档,对测试过程、测试活动起到指导的作用,解决做什么的问题,5W;

    测试计划编写时间:测试需求完成之后;

    编写人:由项目测试负责任编写;

    评审人:项目经理、QA、开发、产品、设计人员

    输出文档总的测试计划文档;

    测试计划的内容:

    (1)项目背景,缩略语(专业术语);

    (2)测试的参考文档、测试的交付文档;

    (3)测试目标、测试范围、测试环境、测试工具、测试策略、测试风险;

    (4)人力资源的分配、工作量的估算;

    (5)测试时间、进度安排、任务分配、培训计划等;

    (6)出入口准则(准入准出标准)等;

    测试风险:质量、时间进度、成本、变更、人员变动等;

    QA与QC的区别:QA为质量保证、QC为质量控制;

    冒烟测试:在测试之前,对软件进行可测性检查,保证基本功能,基本流程可通,提高工作效率;

    回归测试:包括完全回归和部分回归(根据操作频率和风险选择)

    项目 项目时间周期 测试用例数量
    3个月—10个月 500-1000个
    10个月—1.5年 1000-2000个
    1.5年以上 2000个以上
    测试阶段 占用时间比例
    测试需求阶段 10%-20%
    测试计划 小项目2-3天,大项目5天左右
    测试方案 小项目1周,大项目2周
    测试用例 测试总时间的30%
    测试执行 测试总时间的40%
    测试报告 小项目2-3天,大项目5天

    编写测试用例效率:35个/人天;

    执行测试用例效率:35个/人天;

    缺陷发现效率:10个/人天;

    测试用例的质量:30%(缺陷的总数/已执行的测试用例总数)

    集成策略:

    (1)非增量式集成:大爆炸式集成;

    (2)增量式集成:自顶向下、自底向上、三明治;

    测试准入条件:

    (1)测试用例编写,测试评审完成;

    (2)开发人员完成编码,并完成自测;

    (3)冒烟测试通过;

    (4)开发组提交了测试申请单;

    测试准出条件:

    (1)时间标准:项目时间用尽;

    (2)缺陷修复:致命/严重缺陷比率为0%,一般<5%,轻微<10%;

    (3)测试用例执行覆盖率为100%;

    (4)测试用例对需求覆盖率>95%;

    (5)缺陷修复率达到一定的标准;

    (6)收益比:存在bug,但是修复需要花费的时间大于受益,测试停止;

    (7)完成软件测试验收报告,并且报告结果达到认可;

    3、测试方案

    测试方案:技术层面文档,主要对被测软件测试特性、方法、环境等进行规范,解决怎么做的问题;

    测试方案的编写时间:测试计划完成之后;

    负责人:有经验的测试工程师;

    参考依据:测试计划、测试需求分析、测试规格、概设、详设;

    评审人员:测试人员、开发人员、项目经理、QA

    测试内容:

    (1)项目背景、测试目标、测试范围、测试环境、测试策略、测试工具;

    (2)测试特性的分析;

    (3)测试特性方法的分析;

    以最少的用例更全面的覆盖需求,测试不能发现潜在的缺陷;

    单元测试:80%缺陷;

    集成、系统测试:20%中的80%;

    4%-6%的缺陷遗留到用户现场;

    缺陷的群集:80%的缺陷存在20%的模块中;

    缺陷的级别:致命、严重、一般(不超过15%)、轻微(不超过20%)、建议;

    缺陷处理状态迁移图:新建—打开—已修正—已关闭—拒绝—延迟—重新打开;

    缺陷优先级的考虑方面:

    (1)缺陷本身的严重级别;

    (2)功能的重要性方面;

    (3)功能发布的时间进度;

    (4)功能的可见性方面;

    (5)从操作频率方面;

    (6)从安全性方面;

    4、测试用例

    负责任:测试工程师

    参考依据:参考方案、需求分析的结果、需求规格;

    评审人:测试工程师、QA、开发人员、测试经理;

    输出文档:测试用例文档

    用例设计需考虑的方面:(以最少的用例更全面的覆盖需求,以此发现更多的缺陷)

    (1)编写所有必填项(一个用例);

    (2)编写所有项包括必填和非必填(一个用例);

    (3)一个完整的流程一次性走完(一个用例);

    (4)编写预期结果:包括前台、后台、数据库等方面;

    (5)新增和修改的链接为同一界面(代码一致为前提):在修改中只需测试进入界面的默认情况,其余字段只需在新增上测试,修改所有字段点击保存、重置,修改后直接返回需要提示;

    (6)删除:子信息有调用情况(全删、不能删除),例:品牌和商品,删除品牌时则提示,物理删除:可到数据库中回滚,数据库不存在;标志删除:到回收站用来做历史记录,后台可看,前台不可;

    (7)登陆:账号长度限制,正确登陆,不正确登陆;

    (8)业务流程图:场景法、基本流和备选流,串行用乘,并行用加;例:银行取款流程图;

    (9)查询:精确查询和模糊查询,like“%x%”;多条件搜索可用正交法、再补充;

    测试用例过程:

    (1)输入—动作—输出;

    (2)输入—测试环境—测试目的—执行条件—动作—输出;

    (3)为了达到某种特定目标而设计的一组测试输入、执行条件和预期结果,其目的是为了检测某个程序或何时是否满足某个特定的需求;

    测试用例的作用:便于软件质量的度量,方便测试任务的跟踪管理,方便缺陷的提交;

    如何衡量测试用例的好坏:清晰、准确、完整、简洁、一致;

    黑盒测试用例设计方法:包括等价类划分法、边界值分析法、错误推测法、因果图法、判定表驱动法、正交试验设计法、功能图法等。

    因果图:

    (1)因果图关系:(输入与输出)恒等、非~、与^、或V;

    (2)输入约束:异E最多只能一个为1、或I最少有一个为1、唯一O有且只有一个唯一;要求R两个取值一样如C1为1C2也为1;

    (3)输出约束:强制M两个输出互异;

    白盒测试用例设计方法:语句覆盖率、条件覆盖率、判定覆盖率、条件判定覆盖率、组合覆盖率、路径覆盖率;

    对于搜索框的测试用例设计:

    (1)单个条件;

    (2)所有条件;

    (3)任意几个条件组合:应用正交实验法再补充情况;

    (4)不符合条件查询;

    (5)条件中有相互冲突的条件,需单独测试;

    (6)输入合理的查询条件后,点击返回需有提示;

    5、测试执行

    参考依据:测试用例(需求);

    执行人:软件测试工程师;

    输出:缺陷报告;

    Test Case执行结果:

    (1)未测试:Not test;

    (2)通过:pass;

    (3)失败:failed;

    (4)阻塞:black;因为其它的问题导致用例无法执行;

    (5)观察:investigates;

     bug的内容:bug描述、重现步骤、实际结果、预期结果;

    测试执行注意事项:

    (1)注意用例执行的先后顺序:数据流向、优先级、时间进度安排;

    (2)执行的前置条件、测试环境、备注里的特殊说明;

    (3)发现问题/缺陷时,应立即保留证据,再重现缺陷;

    (4)缺陷至少重现3次,并初步定位到问题

    (5)测试过程中,根据实际情况维护测试用例;

    维护测试用例情况:

    (1)需求、编码、设计发生了变更;

    (2)执行过程中发现用例描述有错误;

    (3)发现的缺陷不能对应用例,需补充用例;

    (4)发现重复、冗余的用例需删除;

    对于偶然发现,并难以重现的缺陷如何处理:

    (1)先保留证据(抓包、截图、视频等);

    (2)本机重现问题,无法重现则换电脑重现;

    (3)若重现,则根据缺陷的实际影响情况定义缺陷的严重级别;若无法重现,则找开发人员协助重现;在开发人员的协助下仍未能重现,则需要对此问题边重现边录视频(最多两小时),若2小时内重现则从发现问题的前半小时开始分析,若2小时内未重现,则需直接提交缺陷,降低缺陷的级别,将缺陷改成延迟状态,该缺陷至少历经半年或者在用户现场历经多个版本后关闭;

    什么是缺陷(遗漏、错误、额外实现):

    (1)需求规格说明书中明确要求实现的未实现;

    (2)需求规格说明书中虽未明确规定,但实际需要实现的缺陷;

    (3)未正确实现(错误实现);

    (4)实现了需求规格中明确不需要的功能(额外实现)或实际不需要的功能;

    (5)性能、易用性等方面,站在用户的角度,会认为不好的;

    缺陷的生命周期:

    提交->确认->分配->修复->验证->关闭

    缺陷的内容:

    缺陷编号、模块、项目名、版本、缺陷标题、缺陷级别、优先级、缺陷类型、测试环境、缺陷描述(bug描述、重现步骤、实际结果、预期结果、修改建议)、状态、缺陷引入原因、缺陷引入条件、发现人、发现时间、修改人、修改时间、关闭人、关闭时间、附件、对应的用例编号;

    6、测试报告

    定义:对于测试过程、产品质量进行评估,并对测试结果进行总结、下结论;

    编写人:有经验的测试工程师;

    依据:测试用例的执行情况,缺陷数据的统计结果;

    评审人:整个项目人员;

    测试报告评估人:测试经理、测试人员

    目的:

    (1)用于项目经理决策提供依据;

    (2)用于下一个项目维护提供方便;

    (3)对测试进行评估;

    内容:

    项目背景、测试目标、测试范围、测试环境、测试策略、测试工具、测试人力资源、测试时间、测试用例数据统计、缺陷数据统计、遗留问题、测试风险、测试过程开发、产品质量评估、测试结论、经验教训与建议、附录;

  • 相关阅读:
    看云学习文档列表
    linux&&ubutun 21.06使用查询资料
    element-admin 查询资料笔记
    tp6 composer install 报Your requirements could not be resolved to an installable set of packages。
    centos 7 install npm
    centos 7 dev
    解決npm run dev 报: 'webpack-dev-server' 不是内部或外部命令,也不是可运行的程序 或批处理文件 错误
    解決vue-cli · Failed to download repo vuejs-templates/webpack: tunneling socket could not be established, cause=getaddrinfo ENOTFOUND 10809报错问题
    Linux创建命令快捷方式
    JS 闭包写法
  • 原文地址:https://www.cnblogs.com/melodylin/p/5600133.html
Copyright © 2011-2022 走看看