基于selenium的pyse自动化测试框架

WebUI automation testing framework based on Selenium

介绍: pyse基于selenium(webdriver)进行了简单的二次封装,比selenium提供的方法操作更简洁。

 

起因:

  python + selenium 自动化测试写久了发现selenium(webdriver)提供原生的方法并简便,于是,产生了二次封装的想法。想不到太炫酷的名字,于是各取了两个单词的前两个字母-- pyse。

 

特点:

  • 所有方法只提供xpath定位,webdriver提供了8种定位方法(id\name\class name\tag name\link text\partial link text\xpath\css selector)但xpath一定程度可以替代id\name\class name\tag name 等方法,本框架所提供的click_text()方法可以替代link text方法,所以只用xpath定位对不影响框架对元素的定位能力,又保证了定位方法的一致性。
  • 本框架只是对selenium(webdriver)原方法的简单封装,精简为30个方法,经过我的自动实践,这些方法完全够胜任于我们的自动化工作。
  • 集成了HTMLTestRunner 测试报告,使生成报告变得很简单。

 

安装及前提条件:

 

例子: 请查看demo目录

先看一下百度搜索的例子:

baidu.py

基于selenium的pyse自动化测试框架
#coding=utf-8
from pyse import Pyse
from time import sleep

driver = Pyse("chrome")

driver.open("https://ww.baidu.com")
driver.type("//*[@id='kw']",u"pyse自动化测试")
driver.click("//*[@id='su']")
sleep(2)
driver.quit()
基于selenium的pyse自动化测试框架

 

再看一个page object 设计模式的例子

page_object_case.py

基于selenium的pyse自动化测试框架
#coding=utf-8
from pyse import Pyse
from time import sleep

class Page(object):
    '''
    基本类,用于所页面的继承
    '''
    login_url = 'http://www.126.com'

    def __init__(self, selenium_driver, base_url=login_url, parent=None):
        self.base_url = base_url
        self.driver = selenium_driver
        self.timeout = 30
        self.parent = parent
    
    def _iopen(self,url):
        url = self.base_url + url
        self.driver.open(url)
        assert self.on_page(),'Did not land on %s' % url

    def iopen(self):
        self._iopen(self.url)

    def on_page(self):
        return self.driver.get_url() == (self.base_url + self.url)

class LoginPage(Page):
    '''
    126邮箱登录页面模型
    '''
    url = '/'
    
    def type_username(self,username):
        self.driver.type("//*[@id='idInput']",username)
    
    def type_password(self,password):
        self.driver.type("//*[@id='pwdInput']",password)
    
    def submit(self):
        self.driver.click("//*[@id='loginBtn']")


def test_user_login(driver, username, password):
    """
    测试获取的用户名密码 是否可以登录
    """
    login_page = LoginPage(driver)
    login_page.iopen()
    login_page.type_username(username)
    login_page.type_password(password)
    login_page.submit()


def main():
    try:
        driver = Pyse("chrome")
        username = 'username'
        password = 'password'
        test_user_login(driver, username, password)
        sleep(3)
        text = driver.get_text("//span[@id='spnUid']")
        assert(text == 'username@126.com'),u"用户名称不匹配,登录失败!"
    finally:
        # 关闭浏览器窗口
        driver.close()

if __name__ == '__main__':
    main()
基于selenium的pyse自动化测试框架

 

再看一个使用unittest单元测试框架的例子。

unittest_case.py

基于selenium的pyse自动化测试框架
#coding=utf-8
from pyse import Pyse,TestRunner
from time import sleep
import unittest

class baiduTest(unittest.TestCase):

    def setUp(self):
        self.driver = Pyse("chrome")
        self.driver.wait(10)
        self.base_url = "http://www.baidu.com"

    def test_case(self):
        driver = self.driver
        driver.open(self.base_url)
        driver.click_text("设置")
        driver.click_text("搜索设置")
        sleep(2)
        driver.click("//a[@class='prefpanelgo']")
        sleep(1)
        driver.accept_alert()

    def tearDown(self):
        self.driver.quit()

if __name__ == '__main__':
    TestRunner(r".\demo").run()
基于selenium的pyse自动化测试框架

  调用TestRunner()测试类时需要指定一个测试用例的目录,如:E:\mytestpro\test_case 。然后,调用的它的run()方法来运行测试用例。

  匹配测试用例文件的规则是*_case.py 。所以,测试文件的命名一定要为 aa_case.py ,a12_case.py等。

  它会自动在test_case目录下生成report目录并在其下面生成测试报告。如下:

基于selenium的pyse自动化测试框架

 

项目地址:https://github.com/defnngj/pyse

上一篇:Fluid: 让大数据和 AI 拥抱云原生的一块重要拼图


下一篇:学习云计算从入门到实践,一大波视频干货拿走不谢!(文末有彩蛋)