簡單Web UI 自動化測試框架 pyse

  • 2019 年 11 月 12 日
  • 筆記

WebUI automation testing framework based on Selenium and unittest.

基於 selenium 和 unittest 的 Web UI自動化測試框架。

特點

  • 默認使用CSS定位,同時支持多種定位方法(idnameclasslink_textxpathcss)。
  • 基於Selenium二次封裝,使用更簡單。
  • 提供腳手架,快速生成自動化測試項目。
  • 自動生成/reports/目錄,以及HTML測試報告生成。
  • 自帶斷言方法,斷言title、URL 和 text。
  • 支持用例參數化。

安裝

> pip install -U git+https://github.com/defnngj/pyse.git@master

pyse命令

1、查看幫助:

> pyse -h  usage: pyse [-h] [-V] [--startproject STARTPROJECT] [-r R]    WebUI automation testing framework based on Selenium.    optional arguments:    -h, --help            show this help message and exit    -V, --version         show version    --startproject STARTPROJECT                          Specify new project name.    -r R                  run test case

2、創建項目:

>pyse --startproject mypro    2019-11-07 00:24:57,783 - INFO - Start to create new test project: mypro    2019-11-07 00:24:57,784 - INFO - CWD: D:    2019-11-07 00:24:57,785 - INFO - created folder: mypro  2019-11-07 00:24:57,786 - INFO - created folder: myprotest_dir  2019-11-07 00:24:57,787 - INFO - created folder: myproreports  2019-11-07 00:24:57,788 - INFO - created file: myprotest_dirtest_sample.py  2019-11-07 00:24:57,789 - INFO - created file: myprorun.py

3、運行項目:

> cd mypro  > pyse -r run.py  Python 3.7.1     ______  __   __  _______  _______  |   _  ||  | |  ||  _____||   ____|  |  |_| ||  |_|  || |_____ |  |____  |   ___||_     _||_____  ||   ____|  |  |      |   |   _____| ||  |____  |__|      |___|  |_______||_______|  generated html file: file:///D:myproreports2019_11_12_22_28_53_result.html  .1                                                                              

4、查看報告

你可以到 myproreports 目錄查看測試報告。

API Documents

simple demo

請查看 test_sample.py 文件

import pyse    class BaiduTest(pyse.TestCase):        def test_baidu(self):          ''' baidu search key : pyse '''          self.open("https://www.baidu.com/")          self.type("#kw", "pyse")          self.click("#su")          self.assertTitle("pyse_百度搜索")    if __name__ == '__main__':      pyse.main("test_sample.py", debug=True)

說明:

  • 創建測試類必須繼承 pyse.TestCase
  • 測試用例文件命名必須以 test 開頭。
  • 元素定位方式默認使用 CSS 語法 #kw, 也可以顯示的使用 css=>#kw
  • pyse的封裝了assertTitleassertUrlassertText等斷言方法。
  • 通過main()方法運行測試用例。

API

pyse 提供的API

self.accept_alert()    self.clear("css=>#el")    self.click("css=>#el")    self.click_text("新聞")    self.dismiss_alert()    self.double_click("css=>#el")    self.drag_and_drop("css=>#el","css=>#ta")    self.get_alert_text()    self.get_attribute("css=>#el","type")    self.get_display("css=>#el")    self.get_text("css=>#el")    self.get_title()    self.get_url()    self.js("window.scrollTo(200,1000);")    self.max_window()    self.move_to_element("css=>#el")    self.open("https://www.baidu.com")    self.open_new_window("link_text=>註冊")    self.close()    self.quit()    self.refresh()    self.right_click("css=>#el")    self.screenshots('/Screenshots/foo.png')    self.select("#nr", '20')  self.select("xpath=>//[@name='NR']", '20')    self.set_window(wide, high)    self.submit("css=>#el")    self.switch_to_frame("css=>#el")    self.switch_to_frame_out()    self.type("css=>#el","selenium")    self.wait(10)  

main() 方法

pyse.main(path="./",            browser="chrome",            title="百度測試用例",            description="測試環境:Firefox",            debug=True  )

說明:

  • path : 指定測試目錄。
  • browser: 指定測試瀏覽器,默認Chrome。
  • title : 指定測試項目標題。
  • description : 指定測試描述。
  • debug : debug模式,設置為True不生成測試HTML測試。

Run the test

pyse.main(path="./")  # 當前目錄下的所有測試文件  pyse.main(path="./test_dir/")  # 指定目錄下的所有測試文件  pyse.main(path="./test_dir/test_sample.py")  # 指定目錄下的測試文件  pyse.main(path="test_sample.py")  # 指定當前目錄下的測試文件

說明:

  • 如果指定的目錄,測試文件必須以test 開頭。
  • 如果要運行子目錄下的文件,必須在子目錄下加 __init__.py 文件。

支持的瀏覽器及驅動

如果你想指定測試用例在不同的瀏覽器中運行,非常簡單,只需要在pyse.main()方法中通過browser設置。

  if __name__ == '__main__':      pyse.main(browser="firefox")  

支持的瀏覽器包括:"chrome""firefox""ie""opera""edge""chrome_headless" 等。

不同瀏覽器驅動下載地址:

geckodriver(Firefox):https://github.com/mozilla/geckodriver/releases

Chromedriver(Chrome):https://sites.google.com/a/chromium.org/chromedriver/home

IEDriverServer(IE):http://selenium-release.storage.googleapis.com/index.html

operadriver(Opera):https://github.com/operasoftware/operachromiumdriver/releases

MicrosoftWebDriver(Edge):https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver

==========================================================

元素定位

pyse支持多種定位方式,id、name、class、link text、xpath和css。把定位方法與定位內容一體,寫起更加簡潔。

<form id="form" class="fm" action="/s" name="f">      <span class="bg s_ipt_wr quickdelete-wrap">          <input id="kw" class="s_ipt" name="wd">

定位方式(推薦使用 CSS):

# 默認支持CSS語法  self.type(".s_ipt","pyse")     #css  self.type("#su","pyse")        #css    # id  self.type("id=>kw", "pyse")  #id    # class name  self.type("class=>s_ipt", "pyse")  #class定位    # name  self.type("name=>wd", "pyse")  #name    # xpath  self.type("xpath=>//*[@class='s_ipt']","pyse")  #xpath  self.type("xpath=>//*[@id='kw']","pyse")        #xpath    # link text  self.click_text("新聞") #link text (點擊百度首頁上的"新聞"鏈接)  

css選擇器參考手冊:
http://www.w3school.com.cn/cssref/css_selectors.asp

參數化測試用例

pyse 支持參數化測試用例,集成了parameterized

  import pyse  from pyse import ddt      class BaiduTest(pyse.TestCase):        @ddt.data([          (1, 'pyse'),          (2, 'selenium'),          (3, 'unittest'),      ])      def test_baidu(self, name, keyword):          """           used parameterized test          :param name: case name          :param search_key: search keyword          """          self.open("https://www.baidu.com")          self.clear("id=>kw")          self.type("id=>kw", keyword)          self.click("css=>#su")          self.assertTitle(keyword)