InfoQ

新闻

值得为Selenium痛苦吗?

作者 Scott Delap 译者 宋玮 发布于 2007年8月7日 上午7时56分

社区
Java,
Agile
主题
敏捷技术,
单元测试,
Web框架
标签
测试,
Selenium

值得为Selenium痛苦吗?Atlassian开发者Nick Menere在Atlassian开发者博客(Atlassian Developer Blog)上提出了这样一个特别的问题。Selenium是为Web应用所提供的测试工具,其直接运行在浏览器中。在他的blog中,Menere表达了对于使用Selenium测试JIRA 3.10中两个新的Ajax特性时所碰到的障碍的看法。这些障碍包括:

键盘事件

显然,selenium.type(...) 并不真正模拟一个用户键入到输入框的动作。参看图片。因此需要我们键入文本并单独触发每个键盘事件——selenium.keyDown(...); selenium.keyPress(...); selenium.keyUp(...);。在Firefox中,它起作用了!!……在其他浏览器中,每个字符将会打印两次。

定时

……由于有非可选项目(section label等等),我们想测试一些元素属性没有被改变。我们发起一个该元素上的鼠标事件,接着用xpath定位器检查该元素的属性确实没有变化……这需要在事件发起与测试之间短暂暂停……“新增/加大暂停时间”是修正大多数可能失败的测试的常用方法。

鼠标定位问题

为了给用户更好的使用体验,我们决定加入自动滚动特征……在插入/加大了一堆暂停之后,我们仍不能使相关测试通过。为什么屏幕滚动造成了测试失败?我们在被选元素而非坐标上发起了事件。构建依然失败……我看到鼠标直接跑到了屏幕的中央,当浏览器窗口滚动时,鼠标被定位到了一个非可选择项目上……怎么修正呢?我安装了xwarppointer,以使我们通过bash来移动鼠标指针,并把鼠标指针塞到一个角落里。

纵观Menere的经验教训,最重要的一点是Selenium客户端不是一个用户。

查看英文原文:Is Selenium worth the pain?

有什么更好的替代方法吗? 发表人 pan zhu 发表于 2007年8月7日 下午8时28分
解决方案 发表人 Jackei Chan 发表于 2007年8月9日 上午12时18分
Re: 解决方案 发表人 乐 田 发表于 2007年8月9日 下午8时38分
Re: 乐 田 发表人 Jackei Chan 发表于 2007年8月24日 上午5时59分
  1. 返回顶部

    有什么更好的替代方法吗?

    2007年8月7日 下午8时28分 发表人 pan zhu

    Selenium确实有很多地方都不方便,但是目前还有更好的工具吗?

  2. 返回顶部

    解决方案

    2007年8月9日 上午12时18分 发表人 Jackei Chan

    1.键盘事件 可以直接使用 type 命令来输入; 2.定时 对于 Ajax 的应用,可以使用 waitforcondition 之类的 selenium 命令来等待条件成立后才执行后续脚本; 3.鼠标定位问题 从自动化测试的角度来说,这种 case 并不适合通过自动化脚本来实现。 任何一个自动化测试工具或者框架都不是完美的,一方面要看被测的应用或者所选择的 case 是否适合自动化,另一方面要增加对工具或框架的了解。

  3. 返回顶部

    Re: 解决方案

    2007年8月9日 下午8时38分 发表人 乐 田

    Nick Menere的意思是type不能触发真正的keyPress和keyDown这样的事件,它可以出发onChange和onBlur这样的事件。所以有些测试不好做。 Selenium市和不少场景,但是有些时候Selenium测试也是需要仔细构思才能模拟实际情况的,也就是说需要用开发者的观点写测试,这个有些时候QA人员是很不愿意看到的。此时,的确有些麻烦。 当然后面所说的一些浏览器兼容性问题,我想在以后版本的Selenium中还是可以得到解决的。我们应该充分的利用好这个工具,并亲手为他做一些贡献。

  4. 返回顶部

    Re: 乐 田

    2007年8月24日 上午5时59分 发表人 Jackei Chan

    很乐意跟有同好的朋友们交流和保持联系 ^_^ jackeichan@gmail.com http://jackei.cnblogs.com

深度内容

和Google互补的搜索引擎Wolfram|Alpha

Wolfram|Alpha与Google究竟是什么关系,Wolfram|Alpha自己是如何定位的?Wolfram|Alaph在多大程度上是语义网搜索呢?InfoQ中文站就等等这些问题采访了Wolfram研究公司中国区商务经理王翔。

SOA契约成熟度模型

本文说明了所推荐的契约版本管理设计策略是如何与SOA成熟度模型发生联系的。文章目的是为实现版本管理和可组合性提供一个路线图。

数据服务简介

Vijay Narayanan在这篇文章中对数据服务的几个方面进行了介绍,它们都是SOA实践者和数据架构师感兴趣的内容。本文对数据服务的几个方面进行了介绍,包括需求定义,基本原理和好处、范围、开发以及消费模式。

分块云计算

在本文中,Jimmy Nilsson描述了一种他在过去数年间观察到的一种正在缓慢成长的架构风格,他把这种风格称为“分块云计算”。

豆瓣网技术架构变迁

罗马不是一天建成的,豆瓣的技术架构也是随着用户规模的增长一直在持续变化中。在本次演讲中,豆瓣的首席架构师洪强宁将与大家一起分享从上线时的单台服务器架构开始一直到现在的豆瓣架构变迁历程。

融合思想:深入探索S#arp架构

Billy McCafferty展示了S#arp架构,它在ASP.NET MVC框架的基础上,荟萃了当今的最佳实践,应用在ASP.NET Web应用程序的架构设计中。

王雷谈开源以及新兴市场计划

中国作为新兴市场中的新兴市场,是Sun在美国之外实施SSE(SUN Startup Essentials)项目重点关注的地区。在QCon Beijing 2009期间,InfoQ中文站有幸对此项目的负责人王雷先生进行了采访,探讨了关于开源、新兴市场、SSE等话题。

使用HTML5构建下一代的Web Form

HTML5 是由 WHATWG发起的,最开始的名称叫做Web Application 1.0,而后这个标准吸纳了Web Forms 2.0的标准,并一同被W3C组织所采用,合并成为下一代的HTML5标准。