多个项目中的页面对象设计模式

时间:2011-05-25 17:00:17

标签: design-patterns selenium

我们使用selenium进行测试并使用页面对象设计。也就是说,我们有一个库文件,其中包含我们网站上某个页面的所有功能。 “功能”我也指进程 - 我们有一个“页面对象”库,用于“登录”,“注册”,......这些页面不是真正的页面。

当我们有多个具有相同功能的项目时,问题就开始了。例如,我们有一个移动版本的网站,一个ipad版本,......高级流程保持不变(例如,登录,你仍然:1)填写用户名2)填写密码3)点击进入)但xpath在站点之间发生变化。在大多数情况下,测试是相同的,除了非常少的差异(例如,在登录 - 移动,你没有4)勾选记住我。

我们有一个解决方案(我将说明下面的主要思想)涉及页面对象的继承。我很高兴听到你如何解决这个问题。

我们的解决方案:

  • 我们使用我们称之为用户
  • 的对象来说唱selenium对象
  • 每个项目都有自己的用户:即mobileUser,ipadUser等。它们都是从父(抽象)用户继承的。
  • 我们的库文件是彼此继承的类。
  • 由于“main”脚本对于所有项目都是相同的,我们为每个项目调用相同的代码段,每次都为它提供不同类型的用户。
  • 由于每个项目都有一个用户,我们通过用户
  • “导入”正确的库文件

例如:

def testLogin(user):
    user.lib.Login.LoginAction("username", "password")

库名称为“Login”,我们要调用的函数是“LoginAction”。如果user是移动用户,则Login将成为移动登录库。如果user是ipadUser,它将是ipad登录库,依此类推。

虽然看起来我们已经找到了解决这个问题的方法,但是出来的代码有点像意大利面。我很高兴听到有关如何改进以及如何解决问题的建议。

1 个答案:

答案 0 :(得分:1)

我们有同样的问题,我们的方式是继承。创建几个常见的类作为超类,并且只要您想进行小的更改,就可以扩展它并使用新的XPATH创建子类。 我们还尝试使用java反射来解决多个类的开销,但由于我们主要是QA团队,所以我们对反射不满意。