精华内容
下载资源
问答
  • 软件测试面试题

    2018-10-10 07:59:00
    1. 软件测试主要包括哪几类 单元测试、集成测试、系统测试、验收测试 2. 软件是由哪四项组成 程序、数据、文档、服务 3. 代码评审 定义 代码评审也称代码复查,是指通过阅读代码来检查源代码与编码标准的符合...


    1. 软件测试主要包括哪几类

    • 单元测试、集成测试、系统测试、验收测试

    2. 软件是由哪四项组成

    • 程序、数据、文档、服务

    3. 代码评审

    • 定义
      • 代码评审也称代码复查,是指通过阅读代码来检查源代码与编码标准的符合性以及代码质量的活动。

    4. 设计系统测试计划需要参考的项目文档有

    • 软件测试计划、软件需求规范、迭代计划

    5. β测试

    • 定义:
      • 软件开发公司组织各方面的典型用户在日常工作中实际使用β版本,即发放给一部分用户进行测试,并要求用户报告异常情况,提出批评意见,然后软件开发公司再对β版本进行改错和完善。

    6. 什么是软件缺陷

    • 软件缺陷的定义:
      • 计算机系统或程序中存在的任何一种破坏正常运行的问题、错误,或者隐藏的功能缺陷、瑕疵。
    • 什么样的可以定义为软件缺陷:
      • 1.软件未实现产品说明书要求的功能。
      • 2.软件出现了产品说明书指明不会出现的错误。
      • 3.软件超出实现了产品说明书提到的功能。
      • 4.软件未实现产品说明书未明确指出但是应该实现的目标。
      • 5.软件难以理解,不易使用,运行缓慢或者终端用户认为使用效果不佳。

    7. 软件缺陷的种类

    • 1.功能、特性没有实现或部分实现
    • 2.设计不合理,存在缺陷
    • 3.实际结果和预期结果不一致。
    • 4.运行出错,包括运行终止,系统崩溃,界面混乱。
    • 5.数据结果不正确,精度不够。
    • 6.用户不能接受的其他问题,如存取时间过长,界面不美观。

    8. 软件缺陷的级别

    • 1.致命的
      • 造成系统或应用程序崩溃、死机,造成数据丢失、主要功能完全丧失。
    • 2.严重的
      • 功能或特性没有实现,主要功能部分丧失,次要功能完全丧失,或致命的错误申明。
    • 3.一般的
      • 次要功能丧失,提示信息不太准确或用户界面差,操作时间长等。
    • 4.微小的
      • 对功能几乎没有影响,产品及属性仍可使用。
    • 5.建议
      • 程序的易用性,设计合理性提出建议。
    • 划分的原则:
      • 按照软件缺陷造成的恶劣程度划分。

    9. 缺陷有哪些属性

    • 严重等级、版本、模块、状态、描述、详细说明、建议、紧急程度等

    10. 测试用例包括哪些属性

    • 模块,子模块,编号,用例等级,输入,输出,测试结果

    11. 软件缺陷的状态,按顺序列出

    • 新建(New): 测试中新报告的软件缺陷;
    • 打开(Open): 被确认并分配给相关开发人员处理;
    • 修正(Fixed): 开发人员已完成修正,等待测试人员验证;
    • 拒绝(Declined): 拒绝修改缺陷;
    • 延期(Deferred): 不在当前版本修复的错误,下一版修复;
    • 重新打开(Reopen): 错误未解决,重新开启;
    • 关闭(Closed): 错误已被修复

    12. 软件测试的定义

    • 定义一:
      • 软件测试时为了发现错误而执行程序的过程
    • 定义二:
      • 软件测试时根据软件开发各个阶段规格说明书和程序的内部结构而精心设计的一批测试用例,并利用这些测试用例运行程序以及发现错误的过程。

    13. 什么叫测试?

    • 首先是项活动,在这项活动中某个系统或组成的部分将在特定的条件下运行,结果将被观察和记录,并对系统或组成部分进行评价。测试活动有两种结果:1.找出缺陷和故障;2.显示软件执行的正确。测试是一个或多个测试用例的集合。

    14. 什么是测试用例?

    • 是为了特定的目的而设计的一组测试输入、执行条件和预期的结果;测试用例是执行测试的最小实体。

    15. 什么是测试步骤?

    • 测试步骤详细规定了如何设置、执行、评估特定的测试用例。

    16. 简述一下软件的生命周期

    • 一个软件生命周期包括制定计划需求分析定义软件设计程序编码软件测试软件运行软件维护软件停用,八个阶段。

    17. 软件测试的对象是什么?

    • 软件开发过程中所产生的需求说明书、概要设计说明书、详细设计说明书以及源程序。

    18. 软件测试在软件生命周期的两个阶段

    • 第一阶段:单元测试与集成测试阶段
    • 第二阶段:综合测试阶段,即在完成单元测试后进行的测试。

    19. 软件测试的原则

    • 1.尽早地和不断地进行软件测试
    • 2.设计测试用例时,包括合理输入条件和不合理的输入条件。
    • 3.充分注意测试中的集群现象。
    • 4.严格执行测试计划
    • 5.应当对每个测试结果做全面的检查。
    • 6.妥善保存测试计划,测试用例,出错统计和最终分析报告
    • 7.测试用例应由测试输入数据,测试执行步骤和与之对应的预期结果三部分组成。
    • 8.后期系统测试阶段(不包括单元测试),应当避免由程序员检查自己的程序。

    20. 软件测试的分类是什么?

    • 从执行被测软件角度
      • 静态测试和动态测试
        • 静态测试:通过被测程序的静态审查,对程序的数据流和控制流等信息进行分析,发现代码中潜在的错误,得出测试报告。
        • 动态测试:指通常意义的测试,即使用和运行被测软件。
      1. 从测试用例设计方法
      • 黑盒测试、白盒测试、灰盒测试
        • 黑盒测试:称为功能测试,是一种从用户角度出发的测试,数据驱动测试和基于规格说明的测试。使用这种方法测试,把测试程序当做一个黑盒,忽略程序内部的结构的特性,只依靠被测程序输入和输出之间的关系或程序功能的测试用例。
        • 白盒测试:
          • 称为结构测试。是基于产品的内部结构来进行测试,检查内部操作是否按规格说明书的规定执行,软件各个部分功能是否得到充分利用。
        • 灰盒测试:
          • 是介于白盒测试与黑盒测试之间的一种测试,灰盒测试多用于集成测试阶段,不仅关注输出、输入的正确性,同时也关注程序内部的情况。
    • 从软件测试的策略和过程
      • 单元测试,集成测试,确认测试,系统测试和验收测试

    22. 如果执行完全的黑盒测试,还有必要执行白盒测试吗?

    • 白盒测试可以发现软件设计结构的问题,而且白盒测试比黑盒测试在穷尽路径方面比黑盒测试效率高,尽早的防止问题,可以节约产品的研发成本。

    23. 黑盒测试和白盒测试不同点

    项目 黑盒测试法 白盒测试法
    规划方面 功能测试 结构测试
    优点 从用户角度出发进行测试 能够对程序内部特定部位进行覆盖性测试
    缺点 1.无法测试程序内部特定部位
    2.当规格说明有误,则不能发现问题
    1.无法检查程序的外部特性
    2.无法对未实现规格说明的程序内部欠缺部分进行测试
    应用范围 等价划分法
    边界分析法
    因果图
    决策表
    错误推测法
    语句覆盖,判断覆盖,
    条件覆盖,判断条件覆盖,
    路径覆盖,循环覆盖
    模块接口测试

    24. 黑盒测试主要是发现哪些错误?

    • 1.是否有不正确的功能,是否有遗漏的功能
    • 2.在接口上,是否能够正确地接收输入数据并产生正确的输出结果;
    • 3.是否有数据结构错误或外部信息访问错误。
    • 4.性能上是否能够满足要求
    • 5.是否有程序初始化和终止方面的错误。

    25. 黑盒测试用例方法

    • 等价类划分法、边界值分析法、因果图法、决策表法、正交试验法、场景法、错误推测法

    26. 白盒测试用例方法

    • 语句覆盖;判断覆盖;条件覆盖;判断条件覆盖;条件组合覆盖;路径覆盖;模块接口测试;

    27. 测试用例的特性

    • 有效性
    • 可复用性
    • 易组织性
    • 可评估性
    • 可管理性

    28. 设计测试用例的基本准则

    • 代表性
    • 简洁性
    • 可判断性
    • 可再现性

    29. 测试用例的设计过程

    • 1.分析系统程序的工作流程
    • 2.确定并制定测试用例
    • 3.确定测试用例数据
    • 4测试用例的修改更新

    30. 黑盒测试用例方法

    • 等价类划分法
      • 定义:
        • 它将不能穷举的测试过程进行合理分类,从儿保证设计出来的测试用例具有完整性和代表性。
        • 把所有可能的输入数据划分为若按部分,然后从每个部分中选取少数具有代表性的数据作为测试用例。
      • 划分的依据:
        • 1.按照区间划分,可以确定一个有效等价类和两个无效等价类。
        • 2.按照数值划分,可以确定对个有效等价类和一个无效等价类。
        • 3.按照数值集合划分,可以确定一个有效等价类和一个无效等价类。
        • 4.按照限制条件或规则划分,可以确定一个有效等价类和多个无效等价类。
        • 5.细分等价类,对等价类进一步划分为更小的等价类,并建立等价类表。
      • 等价类测试的分类:
        • 1.弱一般等价类测试

               ^
        • 2.强一般等价类测试

               ^
        • 3.弱健壮等价类测试

               ^
        • 4.强健壮等价类测试。
    • 边界值分析法
      • 定义:
        • 对输入会输出的边界值进行测试
      • 边界值分析法步骤:
        • 确定边界值情况
        • 选取正好等于,刚刚大于或刚刚小于边界的值作为测试数据。
    • 决策表法
      • 定义:
        • 决策表是: 分析和表达多逻辑条件下执行不同操作情况的工具。
      • 决策表的组成:
        • 条件桩:列出问题的条件
        • 动作桩:列出可能采取的操作
        • 条件项:列出所有可能的取值
        • 动作项:根据各组取值下应该采取的动作
        • 在决策表中贯穿条件项和动作项的一列就是一条规则
      • 决策表法步骤:
        • 1.确定规则的个数,取2的n次方
        • 2.列出所有的条件桩和动作桩
        • 3.填入条件项
        • 4.根据条件项推导出动作项,得到初始决策表
        • 5.合并相似规则(合并条件项用“ - ”表示)
    • 因果图法
      • 定义:
        • 一种利用图解法分析输入的各种组合情况,从而设计测试用例的方法
      • 因果图法步骤:
        • 1.根据程序说明书描述,分析病区定因和果,画出因果图。
        • 2.将得到的因果图转化为判断表
        • 3.为判定表中每一类所表示的情况设计一个测试用例
    • 正交试验法
      • 定义:
        • 从大量的试验点中挑选出适量的、有代表性的点,依据正交表,合理安排试验一种测试方法。
      • 正交试验法步骤:
        • 1.提取功能说明,构造因子——状态表
        • 2.加权筛选,生成因素分析表
        • 3.利用正交表构造测试数据集
        • 4.用正交表每行数据构造测试用例
    • 错误推测法
      • 定义:基于经验和直觉推测程序中所有可能存在的各种错误,从而有针对性的设计测试用例的方法。

    31. 上述几种测试方法该如何选择?

    • 原则:
      • 1.根据程序的重要性和一旦发生故障将造成的损失来确定测试等级和测试重点。
      • 2.选择合理的测试策略,从中找到一个平衡点。
        • 参考原则
          • 1.任何情况下必须采用边界值分析法
          • 2.必要时采用等价类划分法作为补充
          • 3.采用错误推断法再追加测试用例
          • 4.检查设计出的测试用例在逻辑上负载程度,如果没有达到要求覆盖标准,应补充更多测试用例
          • 5.如果程序的功能说明中含有输入条件的组合情况,则应考虑选用决策表法 或 因果图法。
      • 3.时间、成本、质量

    32. 单元测试

    • 定义:
      • 对软件基本组成单元进行的测试。单元测试的对象是软件设计的最小单位——模块。单元测试的只要目标是确保各单元模块被正确地编码。

    33. 集成测试

    • 定义:
      • 是介于单元测试和系统测试之间的过度阶段。根据实际情况对程序模块采用适当的集成测试策略组装起来,对系统的接口以及集成后的功能进行正确校验的测试工作。
    • 集成测试的层次
      • 1.对传统软件来讲
        • 模块内集成测试
        • 子系统内集成测试
        • 子系统间集成测试
      • 2.对于面向对象的应用系统来说
        • 类内集成测试
        • 类间集成测试

    34. 确认测试

    • 定义:
      • 也称合格性测试(有效性测试),检验所开发的软件是否能按用户提出的要求运行,对软件的功能和性能要求在软件需求规格说明中已经明确规定。它的任务是验证软件的功能和性能及其特性是否与客户的要求一致。

    35. 系统测试

    • 定义:
      • 系统测试是最接近人们的日常测试实践。它是将已经集成好得软件系统与整个计算机系统结合在一起,在实际运行环境下,对计算机系统进行一系列的组装测试和确认测试。

    36. 验收测试

    • 定义:
      • 通过综合的测试之后,软件测试最后一步——验收测试即可开始,是向用户表明系统能够像预定要求运行。
    • 验收测试流程(分为软件配置和可执行程序)
      • 文档审核——源代码审核——配置脚本审核——测试程序审核——可执行程序审核

    37. 系统测试的方法有哪些?

    • 1.恢复测试
      • 定义:
        • 是通过各种手段,强制性地使软件出错,使其不能正常工作,进而检验系统的恢复能力。
      • 恢复测试有哪些内容?
        • 平均修复时间
        • 重新初始化
        • 数据恢复
        • 重新启动
    • 2.安全测试
      • 定义:
        • 设置一些测试用例试图突破系统的安全保密措施,检验系统是否有安全保密的漏洞。
      • 安全测试有哪些内容?
        • 用户管理和访问控制
        • 数据存储和数据通信的远程安全控制
    • 3.强度测试
      • 定义:
        • 也称压力测试,在反常规数据量、频率或资源的方式下运行系统,以检验系统能力的最高实际限度。
    • 4.性能测试
      • 定义:用来测试软件在系统集成中的运行的性能。
      • 性能测试有哪些测试内容?
        • 运行速度
        • 系统资源占有
        • 响应时间
    • 5.容量测试
      • 定义:
        • 指系统正常运行的范围内测定系统能过处理的数据容量,测试系统承受超额数据容量的能力。
    • 6.正确性测试
      • 定义:
        • 检查软件的各项功能是否符合规格说明书的要求。
      • 正确性测试有哪些测试内容?
        • 设计一些逻辑正确的输入值,检查运行结果是不是期望值。方法如下:
          • 枚举法
          • 边界值法
    • 7.可靠性测试
      • 定义:
        • 是从验证的角度出发,检验系统的可靠性是否达到预期目标,同时要考虑当前系统可靠性增长情况。
      • 可靠性测试有哪些测试内容?
        • 首先,最关键测试数据包括失效间隔时间,失效修复时间,失效数量,失效级别。
        • 然后应用可靠性模型,得到系统的失效率及可靠性增长趋势。
      • 可靠性指标如何界定?
        • 采用平均故障时间
        • 生产环境中,系统最大出现故障数量。
    • 8.兼容性测试
      • 定义:
        • 是检测各软件之间能否正确地交互和共享信息。
      • 兼容性测试有哪些测试内容?
        • 检测与操作系统,浏览器和应用软件的兼容
        • 检测与各软件之间共享数据的能力
    • 9.Web网站测试
      • Web网站测试有哪些测试内容?
        • 文字测试、链接测试、图像测试、表单测试
        • 动态内容测试、数据库测试、服务器性能及负载测试、安全性测试
        • 配置测试、兼容测试、可用性测试、文档测试

    38. 软件测试的过程

    • 测试计划——测试设计——测试执行——测试总结
    • 测试计划
      • 输入:软件测试任务书和需求说明书
      • 输出:软件测试计划
    • 测试设计
      • 输入:软件测试计划
      • 输出:测试用例和测试数据
    • 测试执行:
      • 输入:测试用例和测试数据
      • 输出:软件测试记录
    • 测试总结
      • 输入:软件测试计划、测试用例、软件测试记录
      • 输出:测试报告

    39. 测试计划的目的?包含哪些元素?

    • 目的:
      • 定义测试活动的范围、方法、资源和进度,明确要测试的条目、要测试的特性、要实施的测试任务、对每个任务的个人反映,以及与计划相关的风险。
    • 测试计划的组成部分:
      • 测试需求,测试策略,资源分配,工作量估算,测试时间计划表,风险评估,子计划制定,缺陷报告说明

    40. 为什么要进行软件测试?软件测试的目的?

    • 因为软件也是一种产品,是产品都得经过测试才可以上市。所以软件产品需要进行测试是无可厚非的。在项目生命周期中,测试是给软件进行把关的一个重要环节。
    • 软件测试的目的:
      • 基于不同的立场,存在两种完全不同的测试目的。
        • 从用户的角度出发,希望通过软件测试是暴露软件中隐藏的错误和缺陷,以考虑是否接受该产品。
        • 从开发者的角度出发,希望成为表明软件产品中不存在错误的过程,验证该软件已正确地实现了用户的要求,确立人们对软件质量的信心。

    41. 5w1h

    • who 谁来测
      • 指出由谁来测
    • what 做什么
      • 明确测试的范围和内容
    • when 什么时候测试
      • 确定测试的开始和结束日期
    • why 为什么做
      • 可以帮助测试团队理解测试的目的
    • where 在哪里
      • 给出测试文档和软件的存放位置
    • how 如何做
      • 指出测试的方法和工具

    42. 5C原则

    • Correct 准确
      • 每个组成部分的描述准确,不会引起误解
    • Clear 清晰
      • 每个组成部分的描述清晰,易于理解
    • Concise 简洁
      • 只包含必不可少的信息,不包括任何多余的内容
    • Complete 完整
      • 包含复现该缺陷的完整步骤和其他本质信息
    • Consistent 一致
      • 按照一致的格式书写全部缺陷报告

    43. 软件测试的模型

    • V

      gqIVW6L.jpg
    • X
    • W
    • H
    • 迭代
    • 快速
    • 瀑布
    • 螺旋

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

    • 1.寻找bug
    • 2.避免软件开发过程中的缺陷
    • 3.衡量软件的品质
    • 4.关注用户的需求

    45. 软件测试的目的

    • 测试的最终目的是为了避免错误的发生,确保应用程序能够正常高效的运行。
    • 好的测试用例在于发现至今未发现的错误。
    • 成功的测试是发现了至今未发现的错误的测试。
    • 好的测试工程师应该做到不仅发现问题,还能帮助开发人员分析问题。

    46. 什么是回归测试?

    • 回归测试是指修改旧代码后,重新进行测试以确认修改没有引入新的错误或导致其他代码产生错误。自动回归测试将大幅降低系统测试、维护升级等阶段的成本。回归测试作为软件生命周期的组成部分,在整个软件测试过程中占有很大的工作量比重,软件开发的各个阶段都会进行多次回归测试。

    47. 什么情况下进行回归测试?

    • 每个环节都可能进行回归测试

    48. 什么是冒烟测试?

    • 在测试中发现问题,找到一个Bug,然后开发人员来修复这个Bug。这是想知道这次修复是否真的解决了程序的Bug,或者是否对其他模块造成影响,就需要针对此问题进行专门的测试,这个过程称为冒烟测试。冒烟测试优点节省测试时间,防止build失败。缺点是覆盖率比较低。冒烟测试是自由测试的一种。

    49. 冒烟测试的流程?如何判断测试是否通过?

    • 冒烟测试一般用于每日构建,首先从服务器下载最新的源代码,然后编译单元测试,运行单元测试通过后,编译可执行文件,可执行文件若可运行,并能执行最基本的功能,则认为通过了冒烟测试。

    50. 冒烟测试和回归测试的区别?

    • 冒烟测试就是完成一个新版本开发后,对该版本最基本的功能进行测试,保证基本的功能和流程能走通。如果不通过,则打回开发那里重新开发;如果通过测试,才会进行下一步的测试(功能测试,集成测试,系统测试)。冒烟测试优点是节省时间,防止build失败。缺点是覆盖率比较低。
      1. 回归测试是在以前版本中发现bug在新版本中验证是否存在且是否引发新的bug.我对回归测试的理解:一是当你修复一个bug后,把之前的测试用例再次应用到修复后的版本上进行测试。二是当一个新版本开发好后,而且冒烟测试通过,此时可以先用上一个版本的测试用例对新版本进行测试,看是否有bug。

    52. 什么是软件质量保证?如何保证?

    • 软件质量保证是建立一套有计划,有系统的方法,来向管理层保证拟定出的标准、步骤、实践和方法能够正确地被所有项目所采用。软件质量保证的目的是使软件过程对于管理人员来说是可见的。它通过对软件产品和活动进行评审和审计来验证软件是合乎标准的。
    • 如何保证
      • 质量是全面质量管理

        • 1.代码质量:开发通过单元测试保证

        • 2.使用质量: 让用户参与测试,保证用户体验

        • 3.引入QA,保存过程环节质量

        • 4.系统测试工程师保证系统质量满足需求

      • 测试人员人员的质量保证

        • 1.测试策略:质量是多维度的,功能测试、性能测试、兼容性测试等多种测试类型的结合

        • 2.用例质量:采用合适的用例方法,如何进行需求分析,用例评审

        • 3.执行质量:如何保证执行深度与广度

        • 4.缺陷质量:Bug评审,引入合适的Bug流程

        • 5.过程质量:合理的软件测试流程,测试过程监控

    53. 简述软件项目测试全过程?

    • 首先对软件的需求进行分析(需求文档),测试计划的制定(人员成本风险的分析阶段),测试用例的设计(最关键的阶段),测试用例的执行,回归测试,编写测试报告和总结。

    54. 如何保障编写用例不会有功能遗漏?

    • 功能测试中要保证测试不会有功能遗漏,首先要做好测试需求分析,测试需求获取方法包含了2种,显式需求及隐式需求。

    • 做好需求分析,及时维护测试需求文档。将不同的需求来源划分成一个个需求点,针对每一点进行测试分析,界定测试范围,利用各种测试设计的方法产生功能测试节点。

    • 用例设计阶段,首先要保证产品或项目在主要功能测试用例完全覆盖的情况下去对细节进行测试用例设计,可以运用多种测试用例设计方法来减少功能遗漏。

    • 强化测试用例评审阶段的作用,以测试用例评审会议来检验功能是否覆盖完全,评审会成员需要有设计,开发,测试及专家组成员。

    • 测试全面不等于全面测试,不要过分的追求高测试覆盖率,要结合实际情况去考虑

    55. 项目测试结束后是否需要总结?总结有哪些方面?如何操作?

    • 需要总结
    • 在项目测试结束后还需要将测试工作产品归档,同时对测试过程和测试活动进行相关数据的收集和分析,总结经验和教训。这些内容可以帮助测试团队在以后的项目中尽量避免重复以前的错误。可以发现哪些方面需要改进,并把结果运动到以后的项目中,可以帮助后继项目的持续改进。当确定测试结束后,应当收集主要的输出成果,并且交给相应人员或归档,这些活动称为结束活动。
    • 总结哪些方面:
      • 由于在测试的后期发现不曾预料的缺陷集群现象,和客户沟通,分析原因找出对策
      • 测试活动是否实现了测试计划测定的目标
      • 有哪些非期望的事情和风险发生、发生的原因是什么,是不是有效的解决了这些风险,是否存在没有解决的变更请求。
      • 测试过程中哪些方面做得不够好,为什么会存在这些问题,如何在下一个项目中做得更好。
      • 哪些方面做得比较好及相应的经验
      • 实际工作量和原来的工作量是否差距很大,分析原因
      • 缺陷趋势分析,引起缺陷的原因和影响的分析
    • 记录测试过程中所有的经验教训,并且将经验教训文档化,避免以后测试中出现重复这些错误。

    56. 测试用例如何设计,测试用例设计依据应该考虑到哪些方面?

    • 首先应该有明确的需求,然后才进行思考如何设计测试用例。通常来讲,我们考虑一个测试对象的时候至少从下面六个方面来考虑:功能性、兼容性、易用性、可靠性、性能、安全
    • 比如文本框输入一串数字后提交
      • 从功能方面考虑
        • 从需求中分析,比如最长最少输入字符是多少,输入字符类型是否有限制
      • 从兼容性方面考虑
        • 各浏览器是否显示正确,点击按钮是否有效。
        • 浏览器各版本显示是否正确,点击按钮是否有效
        • 是否支持手持移动设备,比如手机和平板
      • 从易用性方面考虑
        • web界面外观,风格是否合适
        • 文本输入框长度是否合适,是否应该默认提示如何输入
        • 输入错误时提示是否友好
      • 可靠性和性能方面考虑
        • 输入HTML和js相关标签字符,是否会破坏页面。
        • 这个应用是否在同一台服务器上运行多个实例,多个用户同时使用是否有问题
        • 在大并发下使用,计算速度是否满足要求。
      • 从安全性方面考虑
        • 输入的数据是否被保存,输入字符可能包含的敏感信息。
        • 是否可以复制粘贴字符串
        • 尝试快速点击提交按钮
        • 考虑是否有安全漏洞,请求是否被截取,导致返回失败

    转载于:https://www.cnblogs.com/sunning-days/p/9764255.html

    展开全文
  • 目录 2、问:给你一个网站,你如何测试? 3、在搜索引擎中输入汉字就可以解析到对应的域名,请问如何用LoadRunner进行测试。 4、问:一台客户端有三百个客户与三百个客户端有三...11、软件的安全性应从哪几方面

    目录

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

    3、在搜索引擎中输入汉字就可以解析到对应的域名,请问如何用LoadRunner进行测试。

    4、问:一台客户端有三百个客户与三百个客户端有三百个客户对服务器施压,有什么区别?

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

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

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

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

    9、什么是软件质量?

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

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

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

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

    14、软件质量保证体系是什么 国家标准中与质量保证管理相关的几个标准是什么?他们的编号和全称是什么?

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

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

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

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

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

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

    21、黑盒测试和白盒测试是软件测试的两种基本方法,请分别说明各自的优点和缺点!      

    22、测试计划工作的目的是什么?测试计划文档的内容应该包括什么?其中哪些是最重要的?

    23、黑盒测试的测试用例常见设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。

    24、详细的描述一个测试活动完整的过程。(供参考,本答案主要是瀑布模型的做法)

    26、BUG管理工具的跟踪过程(用BugZilla为例子)

    27、您认为在测试人员同开发人员的沟通过程中,如何提高沟通的效率和改善沟通的效果?维持测试人员同开发团队中其他成员良好的人际关系的关键是什么?

    28、你对测试最大的兴趣在哪里?为什么?

    29、你自认为测试的优势在哪里?

    33、简述你在以前的工作中做过哪些事情,比较熟悉什么。参考答案如下。

    34、在C/C++中static有什么用途?(请至少说明两种)

    35、引用与指针有什么区别?

    36、Internet采用哪种网络协议?该协议的主要层次结构?Internet物理地址和IP地址转换采用什么协议?

    37、说说你对集成测试中自顶向下集成和自底向上集成两个策略的理解,要谈出它们各自的优缺点和主要适应于哪种类型测试;

    38、软件验收测试包括?

    39、系统测试的策略有很多种的?

    40、设计系统测试计划需要参考的项目文档有?

    41.通过画因果图来写测试用例的步骤为___、___、___、___及把因果图转换为状态图共五个步骤。 利用因果图生成测试用例的基本步骤是:

    43、请说出这些测试最好由那些人员完成,测试的是什么?

    44、 设计测试用例时应该考虑哪些方面,即不同的测试用例针对那些方面进行测试?

    45、 在windows下保存一个文本文件时会弹出保存对话框,如果为文件名建立测试用例,等价类应该怎样划分?

    46、假设有一个文本框要求输入10个字符的邮政编码,对于该文本框应该怎样划分等价类?

    47、软件测试项目从什么时候开始,?为什么? 

    48、什么是回归测试?

    49.单元测试、集成测试、系统测试的侧重点是什么? 

    51.一个测试工程师应具备那些素质? 

    53、你所了解的的软件测试类型都有哪些,简单介绍一下。

    54、你认为做好测试计划工作的关键是什么?

    55、您认为做好测试用例设计工作的关键是什么?

    56、你的测试职业发展目标是什么?

    57、测试结束的标准是什么?

    59、一套完整的测试应该由哪些阶段组成? 

    61、您是否了解以往所工作的企业的软件开发过程?如果了解,请试述一个完整的开发过程需要完成哪些工作?分别由哪些不同的角色来完成这些工作?您在以往的测试工作中都曾经具体从事过哪些工作?其中最擅长哪部分工作?

    62、测试用例设计的原则是什么?目前主要的测试用例设计方法有哪些?

    63、面向对象的测试用例设计有几种方法?如何实现?

    64、LoadRunner分为哪三个模块?请简述各模块的主要功能。

    65、你对测试最大的兴趣在哪里?为什么?

    66、您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试……)

    67、请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。

    68、当开发人员说不是BUG时,你如何应付?

    69、为什么要在一个团队中开展软件测试工作?

    71、一份测试计划应该包括哪些内容?

    72、针对于软件的行业背景,你如何理解软件的业务?

    74、如何定位测试用例的作用?

    76、什么是兼容性测试?请举例说明如何利用兼容性测试列表进行测试。

    77、对某软件进行测试,发现在WIN98上运行得很慢,怎么判别是该软件存在问题还是其软硬件运行环境存在问题?

    78、需求测试的注意事项有哪些?

    81、主键、外键的作用,索引的优点与不足?

    84、性能测试的流程?

    88、简述bug的生命周期?

    89、缺陷记录应包含的内容?

    91 、您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试……)

    93、您认为做好测试计划工作的关键是什么?

    95、您认为做好测试用例设计工作的关键是什么?

    96、您以往的工作中是否曾开展过测试用例的评审工作?如果有,请描述测试用例评审的过程和评审的内容。

    98、您认为性能测试工作的目的是什么?做好性能测试工作的关键是什么?

    100、您以往所从事的软件测试工作中,是否使用了一些工具来进行软件缺陷(Bug)的管理?如果有,请结合该工具描述软件缺陷(Bug)跟踪管理的流程。

    101、您如何看待软件过程改进?在您曾经工作过的企业中,是否有一些需要改进的东西呢?您期望的理想的测试人员的工作环境是怎样的?


    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) 缺陷描述内容
    缺陷描述的内容可以包含缺陷操作步骤,实际结果和期望结果。操作步骤可以方便开发人员再现缺陷进行修正,有些开发的再现缺陷能力很差,虽然他明白你所指的缺陷,但就是无法再现特别是对系统不熟悉的新加入开发人员,介绍步骤可以方便他们再现。实际结果可以让开发明白错误是什么,期望结果可以让开发了解正确的结果应该是如何。

     

    21、黑盒测试和白盒测试是软件测试的两种基本方法,请分别说明各自的优点和缺点!      

    黑盒测试的优点有:比较简单,不需要了解程序内部的代码及实现;与软件的内部实现无关;  从用户角度出发,能很容易的知道用户会用到哪些功能,会遇到哪些问题;基于软件开发文档,所以也能知道软件实现了文档中的哪些功能;在做软件自动化测试时较为方便。

    黑盒测试的缺点有:不可能覆盖所有的代码,覆盖率较低,大概只能达到总代码量的30%;自动化测试的复用性较低。

    白盒测试的优点有:帮助软件测试人员增大代码的覆盖率,提高代码的质量,发现代码中隐    藏的问题。

    白盒测试的缺点有:程序运行会有很多不同的路径,不可能测试所有的运行路径;测试基于代码,只能测试开发人员做的对不对,而不能知道设计的正确与否,可能会漏掉一些功能需求;系统庞大时,测试开销会非常大。

     

    22、如何测试一个纸杯?

    功能度:用水杯装水看漏不漏;水能不能被喝到

    安全性:杯子有没有毒或细菌

    可靠性:杯子从不同高度落下的损坏程度

    可移植性:杯子在不同的地方、温度等环境下是否都可以正常使用

    兼容性:杯子是否能够容纳果汁、白水、酒精、汽油等

    易用性:杯子是否烫手、是否有防滑措施、是否方便饮用

    用户文档:使用手册是否对杯子的用法、限制、使用条件等有详细描述

    疲劳测试:将杯子盛上水(案例一)放24小时检查泄漏时间和情况;盛上汽油(案例二)放24小时检查泄漏时间和情况等

    压力测试:用根针并在针上面不断加重量,看压强多大时会穿透

     

    22、测试计划工作的目的是什么?测试计划文档的内容应该包括什么?其中哪些是最重要的?

    软件测试计划是指导测试过程的纲领性文件:

    • 领导能够根据测试计划进行宏观调控,进行相应资源配置等
    • 测试人员能够了解整个项目测试情况以及项目测试不同阶段的所要进行的工作等
    • 便于其他人员了解测试人员的工作内容,进行有关配合工作

    包含了产品概述、测试策略、测试方法、测试区域、测试配置、测试周期、测试资源、测试交流、风险分析等内容。借助软件测试计划,参与测试的项目成员,尤其是测试管理人员,可以明确测试任务和测试方法,保持测试实施过程的顺畅沟通,跟踪和控制测试进度,应对测试过程中的各种变更。

    测试计划编写6要素(5W1H):

    • why——为什么要进行这些测试;

    • what—测试哪些方面,不同阶段的工作内容;

    • when—测试不同阶段的起止时间;

    • where—相应文档,缺陷的存放位置,测试环境等;

    • who—项目有关人员组成,安排哪些测试人员进行测试;

    • how—如何去做,使用哪些测试工具以及测试方法进行测试

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

     

    23、黑盒测试的测试用例常见设计方法都有哪些?请分别以具体的例子来说明这些方法在测试用例设计工作中的应用。

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

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

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

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

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

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

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

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

    7)状态图法:通过输入条件和系统需求说明得到被测系统的所有状态,通过输入条件和状态得出输出条件;通过输入条件、输出条件和状态得出被测系统的测试用例。

    8)大纲法:大纲法是一种着眼于需求的方法,为了列出各种测试条件,就将需求转换为大纲的形式。大纲表示为树状结构,在根和每个叶子结点之间存在唯一的路径。大纲中的每条路径定义了一个特定的输入条件集合,用于定义测试用例。树中叶子的数目或大纲中的路径给出了测试所有功能所需测试用例的大致数量。

     

    24、详细的描述一个测试活动完整的过程。(供参考,本答案主要是瀑布模型的做法)

    项目经理通过和客户的交流,完成需求文档,由开发人员和测试人员共同完成需求文档的评审,评审的内容包括:需求描述不清楚的地方和可能有明显冲突或者无法实现的功能的地方。项目经理通过综合开发人员,测试人员以及客户的意见,完成项目计划。然后SQA进入项目,开始进行统计和跟踪

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

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

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

    测试人员搭建环境

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

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

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

    如果有客户反馈的问题,需要测试人员协助重现并重新测试。

     

    26、BUG管理工具的跟踪过程(用BugZilla为例子)

    测试人员发现了BUG,提交到Bugzilla中,状态为new,BUG的接受者为开发接口人员

    开发接口将BUG分配给相关的模块的开发人员,状态修改为已分配,开发人员和测试确认BUG,如果是本人的BUG,则设置为接收;如果是别的开发人员的问题,则转发出去,由下一个开发人员来进行此行为;如果认为不是问题,则需要大家讨论并确认后,拒绝这个BUG,然后测试人员关闭此问题。

    如果开发人员接受了BUG,并修改好以后,将BUG状态修改为已修复,并告知测试在哪个版本中可以测试。

    测试人员在新版本中测试,如果发现问题依然存在,则拒绝验证;如果已经修复,则关闭BUG。

     

    27、您认为在测试人员同开发人员的沟通过程中,如何提高沟通的效率和改善沟通的效果?维持测试人员同开发团队中其他成员良好的人际关系的关键是什么?

    尽量面对面的沟通,其次是能直接通过电话沟通,如果只能通过Email等非及时沟通工具的话,强调必须对特性的理解深刻以及能表达清楚。

    运用一些测试管理工具如TestDirector进行管理也是较有效的方法,同时要注意在TestDirector中对BUG有准确的描述。

    在团队中建立测试人员与开发人员良好沟通中注意以下几点:

    一真诚、二是团队精神、三是在专业上有共同语言、四是要对事不对人,工作至上

    当然也可以通过直接指出一些小问题,而不是进入BUG Tracking System来增加对方的好感。

     

    28、你对测试最大的兴趣在哪里?为什么?

    回答这个面试题,没有固定统一的答案,但可能是许多企业都会问到的。提供以下答案供考:

    最大的兴趣,感觉这是一个有挑战性的工作;

    测试是一个经验行业,工作越久越能感觉到做好测试的难度和乐趣

    通过自己的工作,能使软件产品越来越完善,从中体会到乐趣

    回答此类问题注意以下几个方面:

    尽可能的切合招聘企业的技术路线来表达你的兴趣,例如该企业是数据库应用的企业,那么表示你的兴趣在数据库的测试,并且希望通过测试提升自己的数据库掌握能力。

    表明你做测试的目的是为了提升能力,也是为了更好的做好测试;提升能力不是为了以后转开发或其他的,除非用人企业有这样的安排。

    不要过多的表达你的兴趣在招聘企业的范畴这外。比如招聘企业是做财务软件的,可是你表现出来的是对游戏软件的兴趣;或招聘是做JAVA开发的,而你的兴趣是在C类语言程序的开发。

     

    29、你自认为测试的优势在哪里?

    该面试也没有固定不变的答案,但可参考以下几点,并结合自身特点:

    有韧性、有耐心、做事有条理性、喜欢面对挑战、有信心做好每一件事情、较强的沟通能力、从以前的经理处都得到了很好的评价表明我做的很好

     

    33、简述你在以前的工作中做过哪些事情,比较熟悉什么。参考答案如下。

    我过去的主要工作是系统测试和自动化测试。在系统测试中,主要是对BOSS系统的业务逻辑功能,以及软交换系统的Class 5特性进行测试。性能测试中,主要是进行的压力测试,在各个不同数量请求的情况下,获取系统响应时间以及系统资源消耗情况。自动化测试主要是通过自己写脚本以及一些第三方工具的结合来测试软交换的特性测试。

    在测试中,我感觉对用户需求的完全准确的理解非常重要。另外,就是对BUG的管理,要以需求为依据,并不是所有BUG均需要修改。

    测试工作需要耐心和细致,因为在新版本中,虽然多数原来发现的BUG得到了修复,但原来正确的功能也可能变得不正确。因此要注重迭代测试和回归测试。

     

    34、在C/C++中static有什么用途?(请至少说明两种)


    1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。
    2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。
    3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用

     

    35、引用与指针有什么区别?


        1) 引用必须被初始化,指针不必。
        2) 引用初始化以后不能被改变,指针可以改变所指的对象。
        3) 不存在指向空值的引用,但是存在指向空值的指针。

     

    36、Internet采用哪种网络协议?该协议的主要层次结构?Internet物理地址和IP地址转换采用什么协议?

    TCP/IP协议主要层次结构为: 应用层/传输层/网络层/数链路层。

    ARP (Address Resolution Protocol)(地据址解析协议)

     

    37、说说你对集成测试中自顶向下集成和自底向上集成两个策略的理解,要谈出它们各自的优缺点和主要适应于哪种类型测试

    自顶向下集成

    优点:较早地验证了主要控制和判断点;按深度优先可以首先实现和验证一个完整的软件功能;功能较早证实,带来信心;只需一个驱动,减少驱动器开发的费用;支持故障隔离。

    缺点:柱的开发量大;底层验证被推迟;底层组件测试不充分。

    适应于产品控制结构比较清晰和稳定;高层接口变化较小;底层接口未定义或经常可能被修改;产口控制组件具有较大的技术风险,需要尽早被验证;希望尽早能看到产品的系统功能行为。

    2、自底向上集成

    优点:对底层组件行为较早验证;工作最初可以并行集成,比自顶向下效率高;减少了桩的工作量;支持故障隔离。

    缺点:驱动的开发工作量大;对高层的验证被推迟,设计上的错误不能被及时发现。
    适应于底层接口比较稳定;高层接口变化比较频繁;底层组件较早被完成。

     

    38、软件验收测试包括?

    正式验收测试、alpha测试、beta测试三种测试。


    39、系统测试的策略有很多种的?

    有性能测试、负载测试、强度测试、易用性测试、安全测试、配置测试、安装测试、文档测试、故障恢复测试、用户界面测试、恢复测试、分布测试、可用性测试。

    40、设计系统测试计划需要参考的项目文档有?

    软件测试计划、软件需求工件、和迭代计划


    41.通过画因果图来写测试用例的步骤为___、___、___、___及把因果图转换为状态图共五个步骤。 利用因果图生成测试用例的基本步骤是:

    § 分析软件规格说明描述中,哪些是原因(即输入条件或输入条件的等价类),哪些是结果(即输出条件),并给每个原因和结果赋予一个标识符。

    § 分析软件规格说明描述中的语义,找出原因与结果之间,原因与原因之间对应的是什么关系? 根据这些关系,画出因果图。

    § 由于语法或环境限制,有些原因与原因之间,原因与结果之间的组合情况不可能出现。为表明这些特殊情况,在因果图上用一些记号标明约束或限制条件。 § 把因果图转换成判定表。

    § 把判定表的每一列拿出来作为依据,设计测试用例。

     

    43、请说出这些测试最好由那些人员完成,测试的是什么?

    代码、函数级测试一般由白盒测试人员完成,他们针对每段代码或函数进行正确性检验,检查其是否正确的实现了规定的功能。

    模块、组件级测试主要依据是程序结构设计测试模块间的集成和调用关系,一般由测试人员完成。

    系统测试在于模块测试与单元测试的基础上进行测试。了解系统功能与性能,根据测试用例进行全面的测试。

     

    44、 设计测试用例时应该考虑哪些方面,即不同的测试用例针对那些方面进行测试?

    设计测试用例时需要注意的是,除了对整体流程及功能注意外,还要注意强度测试、性能测试、压力测试、边界值测试、稳定性测试、安全性测试等多方面。(测试用例需要考虑的四个基本要素是输入、输出、操作和测试环境;另外,测试用例需要考虑的是测试类型(功能、性能、安全……),这部分可以参照TP做答。此外,还需要考虑用例的重要性和优先级)

     

    45、 在windows下保存一个文本文件时会弹出保存对话框,如果为文件名建立测试用例,等价类应该怎样划分?

    单字节,如A;双字节, AA、我我;特殊字符 /‘。‘;、=-等;保留字,如com;文件格式为8.3格式的;文件名格式为非8.3格式的;/,\,*等九个特殊字符。

     

    46、假设有一个文本框要求输入10个字符的邮政编码,对于该文本框应该怎样划分等价类?

    特殊字符,如10个*或¥;英文字母,如ABCDefghik;小于十个字符,如123;大于十个字符,如11111111111;数字和其他混合,如123AAAAAAA;空字符;保留字符

     

    47.软件测试项目从什么时候开始,?为什么? 


    软件测试应该在需求分析阶段就介入,因为测试的对象不仅仅是程序编码,应该对软件开发过程中产生的所有产品都测试,并且软件缺陷存在放大趋势.缺陷发现的越晚,修复它所花费的成本就越大.
     

    48、什么是回归测试?

    回归测试: (regression   testing): 回归测试有两类:用例回归和错误回归;用例回归是过一段时间以后再回头对以前使用过的用例在重新进行测试,看看会重新发现问题。错误回归,就是在新版本中,对以前版本中出现并修复的缺陷进行再次验证,并以缺陷为核心,对相关修改的部分进行测试的方法。


    49.单元测试、集成测试、系统测试的侧重点是什么? 


      单元测试针对的是软件设计的最小单元--程序模块(面向过程中是函数、过程;面向对象中是类。),进行正确性检验的测试工作,在于发现每个程序模块内部可能存在的差错.一般有两个步骤:人工静态检查\动态执行跟踪 
      集成测试针对的是通过了单元测试的各个模块所集成起来的组件进行检验,其主要内容是各个单元模块之间的接口,以及各个模块集成后所实现的功能. 
      系统测试针对的是集成好的软件系统,作为整个计算机系统的一个元素,与计算机硬件\外设\某些支持软件\数据和人员等其他系统元素结合在一起,要在实际的运行环境中,对计算机系统进行一系列的集成测试和确认测试.


    51.一个测试工程师应具备那些素质? 


    1、责任心2、沟通能力3、团队合作精神4、耐心、细心、信心5、时时保持怀疑态度,并且有缺陷预防的意识6、具备一定的编程经验


    53:你所了解的的软件测试类型都有哪些,简单介绍一下。

    按测试策略分类:1、静态与动态测试2、黑盒与白盒测试 3、手工和自动测试 4、冒烟测试 5、回归测试;

    按测试阶段分类:单元测试、集成测试、系统测试;

    其他常见测试方法:1、功能测试 2、性能测试 3、压力测试 4、负载测试 5、易用性测试 6、安装测试 7、界面测试 8、配置测试 9、文档测试 10、兼容性测试 11、安全性测试 12、恢复测试

     

    54:你认为做好测试计划工作的关键是什么?

    明确测试的目标,增强测试计划的实用性

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

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

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

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

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

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

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

    55:您认为做好测试用例设计工作的关键是什么?

    白盒测试用例设计的关键是以较少的用例覆盖尽可能多的内部程序逻辑结果

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

     

    56:你的测试职业发展目标是什么?

    测试经验越多,测试能力越高。所以我的职业发展是需要时间累积的,一步步向着高级测试工程师奔去。而且我也有初步的职业规划,前3年累积测试经验,不断的更新自己改正自己,做好测试任务。

     

    57:测试结束的标准是什么?

    从微观上来说,在测试计划中定义,比如系统在一定性能下平稳运行72小时,目前Bug Tracking System中,本版本中没有一般严重的BUG,普通BUG的数量在3以下,BUG修复率90%以上等等参数,然后由开发经理,测试经理,项目经理共同签字认同版本Release。

    如果说宏观的,则是当这个软件彻底的消失以后,测试就结束了。

     

    59、一套完整的测试应该由哪些阶段组成? 


    可行性分析、需求分析、概要设计、详细设计、编码、单元测试、集成测试、系统测试、验收测试

     

    61、您是否了解以往所工作的企业的软件开发过程?如果了解,请试述一个完整的开发过程需要完成哪些工作?分别由哪些不同的角色来完成这些工作?您在以往的测试工作中都曾经具体从事过哪些工作?其中最擅长哪部分工作?

    开发过程---需求调研(需求人员)、需求分析(需求人员)、概要设计(设计人员)、详细设计(设计人员)、编码(开发人员)

    测试过程---需求评审、系统测试设计、概要设计评审、集成测试设计、详细设计评审、单元测试设计、测试执行

    测试工作的整个过程都做过,擅长做测试设计

    过程决定质量,软件的过程改进正是为了提高软件的质量,将过往的种种经验教训积累起来。

     

    62、测试用例设计的原则是什么?目前主要的测试用例设计方法有哪些?

    代表性:能够代表并覆盖各种合理的和不合理、合法的和非法的、边界的和越界的、以及极限的输入数据、操作和环境设置等.

    可判定性:即测试执行结果的正确性是可判定的,每一个测试用例都应有相应的期望结果.

    可再现性:即对同样的测试用例,系统的执行结果应当是相同的。

    方法有等价类、边界值、因果图、状态图、正交法、大纲法

     

    63、面向对象的测试用例设计有几种方法?如何实现?

    给类中的每个构造函数设计一组测试用例

    组合类中的类变量、实例变量

    组合类中的各种方法

    根据前置条件和后置条件设计测试用例

    根据代码设计测试用例

     

    64、LoadRunner分为哪三个模块?请简述各模块的主要功能。

    Virtual User Generator:用于录制脚步

    Mercury LoadRunner Controller:用于创建、运行和监控场景

    Mercury LoadRunner Analysis:用于分析测试结果

     

    65、你对测试最大的兴趣在哪里?为什么?

    最大的兴趣就是测试有难度,有挑战性!做测试越久越能感觉到做好测试有多难。曾经在无忧测试网上看到一篇文章,是关于如何做好一名测试工程师。一共罗列了11,12点,有部分是和人的性格有关,有部分需要后天的努力。但除了性格有关的1,2点我没有把握,其他点我都很有信心做好它。

    刚开始进入测试行业时,对测试的认识是从无忧测试网上了解到的一些资料,当时是冲着做测试需要很多技能才能做的好,虽然入门容易,但做好很难,比开发更难,虽然当时我很想做开发(学校专业课我基本上不缺席,因为我喜欢我的专业),但看到测试比开发更难更有挑战性,想做好测试的意志就更坚定了。

    我觉得做测试整个过程中有2点让我觉得很有难度(对我来说,有难度的东西我就非常感兴趣),第一是测试用例的设计,因为测试的精华就在测试用例的设计上了,要在版本出来之前,把用例写好,用什么测试方法写?(也就是测试计划或测试策略),如果你刚测试一个新任务时,你得花一定的时间去消化业务需求和技术基础,业务需求很好理解(多和产品经理和开发人员沟通就能达到目的),而技术基础可就没那么简单了,这需要你自觉的学习能力,比如说网站吧,最基本的技术知识你要知道网站内部是怎么运作的的,后台是怎么响应用户请求的?测试环境如何搭建?这些都需要最早的学好。至少在开始测试之前能做好基本的准备,可能会遇到什么难题?需求细节是不是没有确定好?这些问题都能在设计用例的时候发现。

    第二是发现BUG的时候了,这应该是测试人员最基本的任务了,一般按测试用例开始测试就能发现大部分的bug,还有一部分bug需要测试的过程中更了解所测版本的情况获得更多信息,补充测试用例,测试出bug。还有如何发现bug?这就需要在测试用例有效的情况下,通过细心和耐心去发现bug了,每个用例都有可能发现bug,每个地方都有可能出错,所以测试过程中思维要清晰(测试过程数据流及结果都得看仔细了,bug都在里面发现的)。如何描述bug也很有讲究,bug在什么情况下会产生,如果条件变化一点点,就不会有这个bug,以哪些最少的操作步骤就能重现这个bug,这个bug产生的规律是什么?如果你够厉害的话,可以帮开发人员初步定位问题。

     

    66、您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试……)


      测试类型有:功能测试,性能测试,界面测试。
      功能测试在测试工作中占的比例最大,功能测试也叫黑盒测试。是把测试对象看作一个黑盒子。利用黑盒测试法进行动态测试时,需要测试软件产品的功能,不需测试软件产品的内部结构和处理过程。采用黑盒技术设计测试用例的方法有:等价类划分、边界值分析、错误推测、因果图和综合策略。 
      性能测试是通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。负载测试和压力测试都属于性能测试,两者可以结合进行。通过负载测试,确定在各种工作负载下系统的性能,目标是测试当负载逐渐增加时,系统各项性能指标的变化情况。压力测试是通过确定一个系统的瓶颈或者不能接收的性能点,来获得系统能提供的最大服务级别的测试。
      界面测试,界面是软件与用户交互的最直接的层,界面的好坏决定用户对软件的第一印象。而且设计良好的界面能够引导用户自己完成相应的操作,起到向导的作用。同时界面如同人的面孔,具有吸引用户的直接优势。设计合理的界面能给用户带来轻松愉悦的感受和成功的感觉,相反由于界面设计的失败,让用户有挫败感,再实用强大的功能都可能在用户的畏惧与放弃中付诸东流。
      区别在于,功能测试关注产品的所有功能上,要考虑到每个细节功能,每个可能存在的功能问题。性能测试主要关注于产品整体的多用户并发下的稳定性和健壮性。界面测试更关注于用户体验上,用户使用该产品的时候是否易用,是否易懂,是否规范(快捷键之类的),是否美观(能否吸引用户的注意力),是否安全(尽量在前台避免用户无意输入无效的数据,当然考虑到体验性,不能太粗鲁的弹出警告)?做某个性能测试的时候,首先它可能是个功能点,首先要保证它的功能是没问题的,然后再考虑该功能点的性能测试

     

    67、请试着比较一下黑盒测试、白盒测试、单元测试、集成测试、系统测试、验收测试的区别与联系。


      黑盒测试:已知产品的功能设计规格,可以进行测试证明每个实现了的功能是否符合要求。
      白盒测试:已知产品的内部工作过程,可以通过测试证明每种内部操作是否符合设计规格要求,所有内部成分是否以经过检查。
      软件的黑盒测试意味着测试要在软件的接口处进行。这种方法是把测试对象看做一个黑盒子,测试人员完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求规格说明书,检查程序的功能是否符合它的功能说明。因此黑盒测试又叫功能测试或数据驱动测试。黑盒测试主要是为了发现以下几类错误:
      1、是否有不正确或遗漏的功能?2、在接口上,输入是否能正确的接受?能否输出正确的结果?3、是否有数据结构错误或外部信息(例如数据文件)访问错误?4、性能上是否能够满足要求?5、是否有初始化或终止性错误?
      软件的白盒测试是对软件的过程性细节做细致的检查。这种方法是把测试对象看做一个打开的盒子,它允许测试人员利用程序内部的逻辑结构及有关信息,设计或选择测试用例,对程序所有逻辑路径进行测试。通过在不同点检查程序状态,确定实际状态是否与预期的状态一致。因此白盒测试又称为结构测试或逻辑驱动测试。白盒测试主要是想对程序模块进行如下检查:
      1、对程序模块的所有独立的执行路径至少测试一遍。
      2、对所有的逻辑判定,取“真”与取“假”的两种情况都能至少测一遍。
      3、在循环的边界和运行的界限内执行循环体。
      4、测试内部数据结构的有效性,等等。
      单元测试(模块测试)是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确。通常而言,一个单元测试是用于判断某个特定条件(或者场景)下某个特定函数的行为。
      单元测试是由程序员自己来完成,最终受益的也是程序员自己。可以这么说,程序员有责任编写功能代码,同时也就有责任为自己的代码编写单元测试。执行单元测试,就是为了证明这段代码的行为和我们期望的一致。
      集成测试(也叫组装测试,联合测试)是单元测试的逻辑扩展。它的最简单的形式是:两个已经测试过的单元组合成一个组件,并且测试它们之间的接口。从这一层意义上讲,组件是指多个单元的集成聚合。在现实方案中,许多单元组合成组件,而这些组件又聚合成程序的更大部分。方法是测试片段的组合,并最终扩展进程,将您的模块与其他组的模块一起测试。最后,将构成进程的所有模块一起测试。
      系统测试是将经过测试的子系统装配成一个完整系统来测试。它是检验系统是否确实能提供系统方案说明书中指定功能的有效方法。(常见的联调测试)
      系统测试的目的是对最终软件系统进行全面的测试,确保最终软件系统满足产品需求并且遵循系统设计。
      验收测试是部署软件之前的最后一个测试操作。验收测试的目的是确保软件准备就绪,并且可以让最终用户将其用于执行软件的既定功能和任务。
    验收测试是向未来的用户表明系统能够像预定要求那样工作。经集成测试后,已经按照设计把所有的模块组装成一个完整的软件系统,接口错误也已经基本排除了,接着就应该进一步验证软件的有效性,这就是验收测试的任务,即软件的功能性能如同用户所合理期待的那样。

     

    68、当开发人员说不是BUG时,你如何应付?


      开发人员说不是bug,有2种情况,一是需求没有确定,所以我可以这么做,这个时候可以找来产品经理进行确认,需不需要改动,3方商量确定好后再看要不要改。二是这种情况不可能发生,所以不需要修改,这个时候,我可以先尽可能的说出是BUG的依据是什么?如果被用户发现或出了问题,会有什么不良结果?程序员可能会给你很多理由,你可以对他的解释进行反驳。如果还是不行,那我可以给这个问题提出来,跟开发经理和测试经理进行确认,如果要修改就改,如果不要修改就不改。其实有些真的不是bug,我也只是建议的方式写进TD中,如果开发人员不修改也没有大问题。如果确定是bug的话,一定要坚持自己的立场,让问题得到最后的确认。

     

    69、为什么要在一个团队中开展软件测试工作?

    因为没有经过测试的软件很难在发布之前知道该软件的质量,就好比ISO质量认证一样,测试同样也需要质量的保证,这个时候就需要在团队中开展软件测试的工作。在测试的过程发现软件中存在的问题,及时让开发人员得知并修改问题,在即将发布时,从测试报告中得出软件的质量情况。

     

    71、一份测试计划应该包括哪些内容?

    背景、项目简介、目的、测试范围、测试策略、人员分工、资源要求、进度计划、参考文档、常用术语、提交文档、风险分析。

     

    72、针对于软件的行业背景,你如何理解软件的业务?

    阅读用户手册了解软件的功能和操作流程;看一些业务的专业书籍补充业务知识;如果有用户实际的数据,可以拿实际的数据进行参考;参考以前的用例和BUG报告;在使用软件的过程中多思考;多与产品经理交流。

     

    74、如何定位测试用例的作用?

    组织性:编写、组织性、功能覆盖、重复性、跟踪、测试确认

     

    76、什么是兼容性测试?请举例说明如何利用兼容性测试列表进行测试。

    主要验证软件产品在不同版本之间的兼容性。包括向下兼容和交错兼容,向下兼容是测试软件新版本保留它早期版本功能的情况,交错兼容是验证共同存在的两个相关但不相同的产品之间的兼容性。

     

    77、对某软件进行测试,发现在WIN98上运行得很慢,怎么判别是该软件存在问题还是其软硬件运行环境存在问题?

    看软件的运行环境要求。如果符合要求则是程序存在问题,若不符合要求则是硬件系统存在问题

     

    78、需求测试的注意事项有哪些?

    是否使用了公司的模板、文档内容是否符合规范、所有的需求是分级是否清析适当、所有的需求是否具有一致性、需求是否可行(即,该需求组合有解决方案)、需求可否用己知的约束来实现、需求是否足够(即,可以把它送到一个规范的开发组织,并有一个生产出所需要产品的合理的可能性)、所有的其它需求是交叉引用是否正确、用户描述是否清楚、是否用客户的语言来描述需求、每个需求描述是否清楚没有岐义,可以移交给一个独立的组去实现时也能理解、是否所有的需求都是可验证的、是否每条需求都具有独立性,即使发生了变化也不会影响其它需求、性能指标是否明确、非功能性需求是否得到充分表现、是否完整列出适用的标准或协议、标准和协议之间是否存在冲突

     

    81、主键、外键的作用,索引的优点与不足?

      答:主键:是表中的唯一标示键。作用:保证实体的完整性;加快数据库的操作速度;增加新的表记录时,数据库会自动检索新记录的主键值,不允许该值与其他表中记录的主键重复;数据库会按主键值的顺序显示记录,如果没有设定主键,则按输入的顺序显示记录。

      外键:是主键的从属,表示了两个表之间的联系。作用:使用外键可以避免冗余。

    索引的优点: 1、通过创建唯一性的索引,可以保证表中数据的唯一性; 2、加速数据的检索速度; 3、加快表与表之间的连接; 4、在使用分组与排序数据检索时,可以显著检索分组与排序的时间; 5、在查询的过程中使用优化隐藏器,提供系统性能。

    缺点: 1、创建索引需要时间,且随着数据量的增加而增加; 2、索引需要占用物理空间;

            3、当对表中数据进行修改时,索引也要动态维护,降低了数据的维护速度。

     

    84、性能测试的流程?

      1.测试需求分析2.测试计划制定与评审3.测试用例设计与开发4.测试执行与监控5.分析测试结果6.编写性能测试报告7.测试经验总结

     

    88、简述bug的生命周期?

      1, 有效地记录BUG 2, 使用BUG模板 3, 评价BUG优先级和严重性 4, BUG的生命 5, 维护BUG数据库

     

     

    89、缺陷记录应包含的内容?

      缺陷标识、缺陷类型、缺陷严重程度、缺陷产生可能性、缺陷优先级、缺陷状态、缺陷起源、缺陷来源、缺陷原因; 

     

    91 您所熟悉的软件测试类型都有哪些?请试着分别比较这些不同的测试类型的区别与联系(如功能测试、性能测试……)

      易用性测试-界面的友好性,操作方便性等。

      功能测试-系统中功能性需求的满足

      安全性测试-系统是否存在安全隐患和漏洞

      性能测试-系统在大并发下的响应速度和健壮性

     

    93、您认为做好测试计划工作的关键是什么?

      了解项目或系统的业务需求

      和项目经理协调好,了解项目的进度计划安排情况 

     

    95您认为做好测试用例设计工作的关键是什么?

      对业务和软件需求非常清楚,可以根据需求不同选择不同的测试用例设计

     

    96、.您以往的工作中是否曾开展过测试用例的评审工作?如果有,请描述测试用例评审的过程和评审的内容

      评审计划->预审->评审;

      评审内容主要是测试用例对软件需求的覆盖程度,对于相关边界是否考虑,是否针对复杂流程准备多套测试数据,是否有专门针对非功能性需求的测试。 

     

    98.您认为性能测试工作的目的是什么?做好性能测试工作的关键是什么?

      关键是测试脚本的录制,测试时候测试环境的干净。

    100、.您以往所从事的软件测试工作中,是否使用了一些工具来进行软件缺陷(Bug)的管理?如果有,请结合该工具描述软件缺陷(Bug)跟踪管理的流程。

      CQ,也可以使用BugFree等免费工具。

    101、.您如何看待软件过程改进?在您曾经工作过的企业中,是否有一些需要改进的东西呢?您期望的理想的测试人员的工作环境是怎样的?

      将先进的经验或思想固化到过程中,通过过程改进和能力提高来改进软件质量。

     

    TCP/IP五层协议:应用层、传输层、网络层、数据链路层、硬件层

     

    还有什么要问的问题:

     

       测试部门多少人

       项目情况

       晋升机制

       没回答上来的问题

    展开全文
  • SnifferPro

    2012-09-21 19:54:48
    以及应用的流量趋势进行监控,几方面数据的对比分析为技术人员分析应用性能问题提供有效的数据,我们可以直观的看到连接数量、流量、重传、以及交易处理时间之间的关系,有效分析应用服务质量。 目前的Appintell ...
  • 目前国内装饰企业数以十万计,这里包括如九鼎装饰,紫名都,广东星艺等等知名连锁企业,也包括大大小小的各地品牌企业和正在起步阶段的装饰公司。在这个激烈的市场竞争背景下,如何取得更大的市场份额,如何提高公司...
  • 4.12.21 OMS(Oracle Management Service,Oracle服务管理) 123 4.12.22 连接到Grid Control 123 4.12.23 登录到Grid Control 123 4.12.24 Grid Control的特性 124 4.12.25 使用Grid Control主页 124 ...
  • 语义是否已经包括了同步的意思? 问题1-17:为什么协议不能设计成100%可靠的? 问题1-18:什么是因特网的穆尔定律? 问题1-19:局域网、广域网和公用网、专用网有什么关系? 问题1-20:信道的利用率是否越高越好? ...
  • 24.CITT在电路交換系统中规定了哪几类接口及各类接口的作用? 答 1)中继側接口:即至其它交换机的接口,Q.511规定了连接到其它交换机的接口 有三种: 轟掇口:数字接口,逍PCM一次群线路连榜至其它交换机 B接口:数宇接口,...
  • 从这方面来进行比较,数据链路层协议和运输层协议的主要区别是什么? 问题5-6:TCP协议能够实现可靠的端到端传输。在数据链路层和网络层的传输还有没有必要来保证可靠传输呢? 问题5-7:在TCP报文段的首部中只有端口...
  • ①个性因素,管理者个性方面的素质通常体现在他与组织中其他人的交往过程中所表现出来的理解力和行为方式上,优秀的项目经理能够有效理解项目中其他人的需求和动杋并具有良好的沟通能力,具体内容包括:号召力,即...
  • 4.4.6 你知道哪几种垃圾收集器,各自的优缺点,重点讲下cms和G1,包括原理,流程,优缺点。 4.4.7 垃圾回收算法的实现原理。 4.4.8 当出现了内存溢出,你怎么排错。 4.4.9 JVM内存模型的相关知识了解多少,比如重...
  • JAVA面试题最全集

    2010-03-13 13:09:10
    84.dotnet由哪几个基本框架组成? 85.Oracle中SGA是什么? 86.web servers是什么? 87.UNIX中QT是什么意思? 88.在软件开发生命周期中的哪个阶段开始测试? 89.dotnet与J2EE的比较? 90.什么是ActiveX? 91.Java中...
  • (4) 认可需求 就是对需求规格说明达成一致,其主要任务是冲突求解,包括定义冲突和冲突求解两方面。常用的冲突求解方法有:协商、竞争、仲裁、强制、教育等,其中有些只能用人的因素去控制。 (5) 进化需求 客户的...
  • 人月神话(pdf)

    2007-07-31 11:13:15
    1995年版包括了令人感兴趣的新的章,但原来的随笔依然是这本书的心脏与灵魂。在这本书中,Brooks解决了如何组织和管理大规模编程项目的问题。这些项目要求成百上千的程序员,产生百万行代码(想想SAP、Oracle...
  • asp学习相关资料大全

    2009-03-01 14:12:05
    很多关于asp的学习,很有...经过调查、研究、分析、计算,在学生信息管理中的应用已经条件成熟,将从以下方面总结系统开发的可行性,具体情况如下: (1)技术可行性 以WindowsXP为操作系统,采用ASP为脚本语言
  • C++网络爬虫项目

    2018-07-04 00:59:17
    经过十年的发展,搜索引擎已经成为互联网的重要入口之一,Twitter联合创 始人埃文•威廉姆斯提出了“域名已死论”,好记的域名不再重要,因为人们会 通过搜索进入网站。搜索引擎排名对于中小网站流量来说至关重要...

空空如也

空空如也

1 2 3 4
收藏数 73
精华内容 29
热门标签
关键字:

服务质量包括哪几方面