软件测试之白盒测试技术.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
变异体简单实例 程序P …. x = y+z ….. * * 程序P的一个变异体 …. x = y*z …. 测试用例(y=3,z=1)可以kill变异体 测试用例(y=2,z=2)执行后变异体仍存活 等价变异体 虽然在语法上存在差异,但在语义上保持一致 例如 for (int i =0; i 10; i++){…} for (int i =0; i != 10; i++){…} * * 等价变异体检测问题是研究难题 其他问题 变异测试 符号执行和动态符号执行 数据流分析 * * Symbolic Execution Adapted from slide by D. Rietmann Adapted from slide by D. Rietmann * 但符号执行是一种静态分析技术 仅能分析形参是简单数据类型的函数,当形参是数组或类的时候,该方法无法使用 UC Berkely的Koushik Sen等人将随机测试引入符号执行,提出动态符号执行技术(Dynamic Symbolic Exectuion,DSE) 思路简单但功能强劲,很精彩的研究工作 从论文的引用率可以看出该工作的影响力 * * DART: directed automated random testing ,2005(被引用831) CUTE: A concolic unit testing engine for C ,2005(被引用566) Dynamic Symbolic Execution Code to generate inputs for: Constraints to solve a!=null a!=null a.Length0 a!=null a.Length0 a[0]==1234567890 void CoverMe(int[] a) { if (a == null) return; if (a.Length 0) if (a[0] == 1234567890) throw new Exception(bug); } Observed constraints a==null a!=null !(a.Length0) a!=null a.Length0 a[0]!=1234567890 a!=null a.Length0 a[0]==1234567890 Data null {} {0} {123…} a==null a.Length0 a[0]==123… T T F T F F ExecuteMonitor Solve Choose next path Done: There is no path left. Negated condition 微软针对该方法基于.net平台实现了工具Pex /en-us/projects/pex/ * * DSE彻底解决该问题了吗? DSE受到约束求解器求解能力的约束,并不能保证生成可覆盖所有可能路径的测试用例 演化测试是DSE技术的一个很好的补充 例如:演化测试可以更好的生成面向对象程序测试用例的方法调用序列 * * 其他问题 变异测试 符号执行和动态符号执行 数据流分析 * * * Data Flow Criteria Definition (def) : A location where a value for a variable is stored into memory Use : A location where a variable’s value is accessed def (n) or def (e) : The set of variables that are defined by node n or edge e use (n) or use (e) : The set of variables that are used by node n or edge e Goal: Try to ensure that values are computed and used correctly 0 2 1 6 3 5 4 X = 42 Z = X-8 Z = X*2 Defs: def (0) = {X} def (4) = {Z} def (5) = {Z} Uses: use (4) = {X} use (5) = {X} * DU Pairs and DU Paths DU pair : A pair of locations (li, lj) such tha

文档评论(0)

beautyeve + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档