下方查看历史精选文章
重磅发布 - 自动化框架基础指南pdf 大数据测试过程、策略及挑战
前言
本文就python selenium自动化测试实践中所需要的POM设计模式进行分享,以便大家在实践中对POM的特点、应用场景和核心思想有一定的理解和掌握。
基于python selenium2开始UI级自动化测试并不是多么艰巨的任务。**只需要定位到元素,执行对应的操作即可。**下面我们看一下这个简单的脚本实现百度搜索。
from selenium import webdriverimport time
driver = webdriver.Firefox()driver.implicitly_wait(30)
# 启动浏览器,访问百度driver.get("http://www.baidu.com")
# 定位 百度搜索框,并输入seleniumdriver.find_element_by_id("kw").send_keys("selenium")
# 定位 百度一下 按钮并单击进行搜索driver.find_element_by_id("su").click()
time.sleep(5)driver.quit()
从上述代码来看,我们所能做的就是定位到元素,然后进行键盘输入或鼠标动作。就这个小程序而已,维护起来看起来是很容易的。但随着时间的迁移,测试套件将持续的增长。脚本也将变得越来越臃肿庞大。如果变成我们需要维护10个页面,100个页面,甚至1000个呢?那页面元素的任何改变都会让我们的脚本维护变得繁琐复杂,而且变得耗时易出错。
那怎么解决呢? 在自动化测试中,引入了Page Object Model(POM):页面对象模式来解决,POM能让我们的测试代码变得可读性更好,高可维护性,高复用性。
下图为非POM和POM对比图:
下面我们看看POM的代码目录组织示例:
下面我们看下使用POM百度搜索 POM代码示例: 看先下代码组织结构如下:
# basePage.py代码如下
# _*_ coding:utf-8 _*_
__author__ = '苦叶子'
import sysreload(sys)sys.setdefaultencoding("utf-8")
# pages基类class Page(object): """ Page基类,所有page都应该继承该类 """ def __init__(self, driver, base_url=u"http://www.baidu.com"): self.driver = driver self.base_url = base_url self.timeout = 30 def find_element(self, *loc): return self.driver.find_element(*loc) def input_text(self, loc, text): self.find_element(*loc).send_keys(text) def click(self, loc): self.find_element(*loc).click() def get_title(self): return self.driver.title# searchPage.py 代码如下# _*_ coding:utf-8 _*_
__author__ = '苦叶子'
import sysfrom selenium.webdriver.common.by import Byfrom pages.basePage import Page
reload(sys)sys.setdefaultencoding("utf-8")
# 百度搜索pageclass SearchPage(Page): # 元素集 # 搜索输入框 search_input = (By.ID, u'kw') # 百度一下 按钮 search_button = (By.ID, u'su') def __init__(self, driver, base_url=u"http://www.baidu.com"): Page.__init__(self, driver, base_url) def gotoBaiduHomePage(self): print u"打开首页: ", self.base_url self.driver.get(self.base_url) def input_search_text(self, text=u"开源优测"): print u"输入搜索关键字:开源优测 " self.input_text(self.search_input, text) def click_search_btn(self): print u"点击 百度一下 按钮" self.click(self.search_button)# testSearchPage.py代码如下
# _*_ coding:utf-8 _*_
__author__ = '苦叶子'import unittestimport sysfrom selenium import webdriverfrom pages.searchPage import SearchPage
reload(sys)sys.setdefaultencoding("utf-8")
# 百度搜索测试class TestSearchPage(unittest.TestCase): def setUp(self): self.driver = webdriver.Ie() def testSearch(self): driver = self.driver # 百度网址 url = u"http://www.baidu.com" # 搜索文本 text = u"开源优测" # 期望验证的标题 assert_title = u"开源优测_百度搜索" print assert_title search_Page = SearchPage(driver, url) # 启动浏览器,访问百度首页 search_Page.gotoBaiduHomePage() # 输入 搜索词 search_Page.input_search_text(text) # 单击 百度一下 按钮进行搜索 search_Page.click_search_btn() # 验证标题 self.assertEqual(search_Page.get_title(), assert_title) def tearDown(self): self.driver.quit()# 主入口程序代码如下# _*_ coding:utf-8 _*___author__ = '苦叶子'
import unittestimport sysfrom common import HTMLTestRunnerfrom testcase.testSearchPageimport TestSearchPage
reload(sys)sys.setdefaultencoding("utf-8")if __name__ == '__main__': testunit = unittest.TestSuite() testunit.addTest(TestSearchPage('testSearch')) # 定义报告输出路径 htmlPath = u"page_demo_Report.html" fp = file(htmlPath, "wb") runner = HTMLTestRunner.HTMLTestRunner(stream=fp, title=u"百度测试", description=u"测试用例结果") runner.run(testunit) fp.close()
按照如图所示组织代码结构,输入如上代码,执行以下命令运行,会在当前目录生成测试报告:
python main.py
最后做个总结,所有代码请手动输入,不要直接拷贝。再次对POM进行小结
微信搜一搜 或 长按加群
开源优