WebKit自动化回归测试之LayoutTest实践 (超时问题的处理)

本文主要是介绍WebKit自动化回归测试之LayoutTest实践 (超时问题的处理),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载请注明出处:http://blog.csdn.net/horkychen

WebKit的回归测试是由一组脚本构成的Layout Tests,测试内容是测试的网页和标准结果(Baseline)。其测试脚本执行的基本方式示意如下:

 *脚本会启动http服务器以支持网页加载,在此不做描述。


而每个网页里面都含有测试用的JavaScript脚本, 主要因为有一些DOM对象被动态注入了供JavaScript本使用。(关于如何添加这个DOM对象,可以参考这篇文章的第二种情况。代码在WebCoreTestSupport.cpp::injectInternalsObject()) 。这些对象中就是testRunnereventSenderGCControllertextInputControllerinternals。它们的功能是和DumpRenderTree交互。可以交互的内容列在这里了:

     Write Layout Tests for DumpRenderTree

 

测试脚本其实就是JavaScript脚本加上这些新对象。需要注意在使用这些对象前最好检查一下,保持一个兼容性,如官网给的例子:

    <script>

    if (window.testRunner)

    {

    testRunner.dumpAsText(true);

    }

   ……


使用WebKit提供的脚本就可以开始测试了: (以下是在WebKit目录下执行)

 Tools/Scripts/run-webkit-tests --verbose --debug [目标目录]

  *更多选项,使用Tools/Scripts/run-webkit-tests --help可以看到。


下面讲一个实作,中间要解决一个关于时间控制的问题。


先架环境,下载了Webkit后,还需要从Webkit的代码库中导出LayoutTest。在WebKit目录执行:

  svn export http://svn.webkit.org/repository/webkit/trunk/LayoutTests/ LayoutTests

 

等吧!有1.5G之大,我可是下了两天。


说明一下测试目标。测试一下JS Engine对时间控制的准确性。写了一段JS脚本,会每隔两秒输出当前时间及与上次的时间差。所以Document加载完成后,脚本还需要运行一段时间。好在testRunner提供waitUntilDonenotifyDone可以使用。waitUntilDone表示测试程序要等待脚本发送notifyDone才表示测试用例执行结束,然后才能收集结果。否则DumpRenderTree当网页加载完成后,就后直接Dump,然后走人,而这个时候,这个测试脚本还什么都没发生呢。


测试的网页如下:

[html]  view plain copy print ?
  1. <html>  
  2. <head>  
  3.   
  4. </head>  
  5.   
  6. <body>  
  7.   
  8.     <div id="dd"></div>  
  9.   
  10.   
  11.     <script>  
  12.     if (window.testRunner)  
  13.     {  
  14.     testRunner.dumpAsText(true);  
  15.     }  
  16.       
  17. totalCount = 20;  
  18.         text = "";  
  19.         nOld= -1;  
  20.         var handle;  
  21.   
  22.         function repaint()  
  23.         {  
  24.             var now = new Date();  
  25.               
  26.              str = "<b>" + now + "</b>####" ;  
  27.               
  28.             if(-1==nOld)  
  29.             {  
  30.             nOld=now.getTime();  
  31.             str+= "  <span style=\"color:#0000FF;\"]] > Begin</span><div />"  
  32.             }  
  33.             else  
  34.             {  
  35.             nDiff = now.getTime()-nOld;  
  36.             if(  Math.abs(nDiff-2000) >=5 )  
  37.             {  
  38.             str+= "<span style=\"color:#FF0000;\"]]  
  39. >  
  40. NG ("+nDiff+")</span><div />"  
  41.             }  
  42.             else  
  43.             {  
  44.               str+= "<span style=\"color:#0000FF;\"]] > OK</span><div />"  
  45.             }  
  46.             nOld=now.getTime();  
  47.             }  
  48.               
  49.             text = str + text;  
  50.             document.getElementById('dd').innerHTML = text;  
  51.               
  52.             totalCount--;  
  53.               
  54.             if( 0 == totalCount )  
  55.             {  
  56.                 clearInterval(handle);  
  57.                 if (window.testRunner)   
  58.                 {  
  59.                 testRunner.notifyDone();  
  60.                 }  
  61.             }  
  62.         }     
  63.   
  64.         handle = setInterval(repaint, 2000);  
  65.           
  66.         if (window.testRunner)  
  67.         {  
  68.         testRunner.waitUntilDone(); //Ask testRunner to wait the script done.  
  69.         }  
  70.   
  71.     </script>  
  72.   
  73. </body>  
  74.   
  75. </html>  


然后把脚本放到LayoutTests目录下:

执行Tools/Scripts/run-webkit-tests脚本,指定运行脚本的目录就可以了。不幸的是出错了。

 

看到是Time-Out的问题(脚本执行时加上--verbose可以看到更多的细节),前面的测试脚本会运行至少20*2s, 也就是至少需要40秒的时间。而run-webkit-tests默认的时间为35s (执行时脚本也有输出),所以超时了。喜欢探究一下的,可以看看Scripts/webkitpy/layout_tests/controllers/manager.py


 run-webkit-tests提供了一个参数可以指定自己的TimeOut设定。

     --time-out-ms=TIME_OUT_MS  (针对所有测试用例)


将Time-Out时间设为70秒再试一次:

     Tools/Scripts/run-webkit-tests --verbose --debug --no-build --no-retry --time-out-ms=70000 xxxxx

结果仍然出错了。真正的问题来了。

 

这里关于分析过程省略500字……


最终发现, DumpRenderTree还有一个对于waitUntilDone/notifyDone的限定。默认在收到waitUntilDone后,超过30秒没有接到notifyDone,就算超时。相关代码都在DumpRenderTree工程中:

     Mac OS        LayoutTestControllerMac.mm  ->waitToDumpWatchdogInterval赋值

     Windows       TestShell.cpp -> 建构函数


所以这里有两个Time-Out时间,一个是控制每个测试用例的运行时间,另一个是waitUntilDone等多久的时间。示意如下:

两个一组合,这个测试还是没过。而且后者在Mac OS的实现(Windows有入口可以改掉)是Hard Code没办法通过参数设置。我们只能强行改掉它了,关于这个问题我正在联系WebKit确认准备提交个Bug。


注意,改完后,要使用Tools/Scripts/build-dumprendertree来重新编译。在run-webkit-tests加--build帮不上你的。


然后再执行一次上面的脚本,就可以看到正常的结果了。测试的结果会被存储在与DumpRenderTree同级目录下:

*xxx-actual.txt -> 为实际dump出来的结果

*xxx-diff.txt ->差异比对结果

*xxx-expected.txt -> 标准输出

*xxx-stderr.txt -> 运行过程中的错误信息输出

 

另一种方案,修改layouttest脚本给DumpRenderTree加个--no-timeout使得每个Case几乎不用考虑超时的问题。这样做,风险就太高了,很可能卡死在某个测试用例。


补一张测试执行的示意图 (英文比较直接一点):
 

Reference:

   http://www.webkit.org/blog/1456/layout-tests-practice/

   http://trac.webkit.org/wiki/Writing%20Reftests

这篇关于WebKit自动化回归测试之LayoutTest实践 (超时问题的处理)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/799928

相关文章

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

golang内存对齐的项目实践

《golang内存对齐的项目实践》本文主要介绍了golang内存对齐的项目实践,内存对齐不仅有助于提高内存访问效率,还确保了与硬件接口的兼容性,是Go语言编程中不可忽视的重要优化手段,下面就来介绍一下... 目录一、结构体中的字段顺序与内存对齐二、内存对齐的原理与规则三、调整结构体字段顺序优化内存对齐四、内

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动