貌似这篇是我之前看的虫师博客运行的
得出结论是我们封装后的sele相当于就是pyse
记得之前还看了pytest框架喜欢里面的loginfo
Pytest的报告多种多样很友好
下次可以考虑把unnitest框架换成pytest
依旧八种定位=>
id_ (to avoid conflict with the built-in keyword id)
name
class_name
css_selector
tag_name
xpath
link_text
partial_link_text
testbaidu.py
from pyse import Pyse, TestRunner
from time import sleep
import unittest
class BaiduTest(unittest.TestCase):
def setUp(self):
self.driver = Pyse("ff")
def test_case(self):
''' baidu search key : pyse '''
driver = self.driver
driver.open("https://www.baidu.com")
driver.clear("id=>kw")
driver.type("id=>kw", "pyse")
driver.click("css=>#su")
sleep(1)
self.assertTrue("pyse",driver.get_title())
def tearDown(self):
self.driver.quit()
if __name__ == '__main__':
# runner = TestRunner()
# runner.run()
unittest.main()
testpom.py
#coding=utf-8
from pyse import Pyse
from time import sleep
class Page(object):
'''
基本类,用于所页面的继承
'''
login_url = 'http://uniqlotest.r-pac.com.hk/'
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 = '/login?ReturnUrl=%2f'
def type_username(self,username):
self.driver.type("id=>Username",username)
def type_password(self,password):
self.driver.type("id=>Password",password)
def submit(self):
self.driver.click("xpath=>//*[@id='btn_login']")
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("ff")
username = 'admin'
password = 'testxxxx'
test_user_login(driver, username, password)
sleep(3)
text = driver.get_text("class=>user_text")
assert(text == 'Administrator'),u"用户名称不匹配,登录失败!"
finally:
# 关闭浏览器窗口
driver.close()
if __name__ == '__main__':
main()
也就是pyse封装的函数
pyse.py
# coding=utf-8
from selenium import webdriver
from selenium.webdriver.common.action_chains import ActionChains
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
class WeTest(object):
'''
Pyse framework for the main class, the original
selenium provided by the method of the two packaging,
making it easier to use.
'''
def __init__(self, browser='ff'):
'''
Run class initialization method, the default is proper
to drive the Firefox browser. Of course, you can also
pass parameter for other browser, Chrome browser for the "Chrome",
the Internet Explorer browser for "internet explorer" or "ie".
'''
if browser == "firefox" or browser == "ff":
driver = webdriver.Firefox()
elif browser == "chrome":
driver = webdriver.Chrome()
elif browser == "internet explorer" or browser == "ie":
driver = webdriver.Ie()
elif browser == "opera":
driver = webdriver.Opera()
elif browser == "phantomjs":
driver = webdriver.PhantomJS()
try:
self.driver = driver
except Exception:
raise NameError("Not found %s browser,You can enter 'ie', 'ff' or 'chrome'." % browser)
def element_wait(self, css, secs=5):
'''
Waiting for an element to display.
Usage:
driver.element_wait("css=>#el",10)
'''
if "=>" not in css:
raise NameError("Positioning syntax errors, lack of '=>'.")
by = css.split("=>")[0]
value = css.split("=>")[1]
if by == "id":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.ID, value)))
elif by == "name":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.NAME, value)))
elif by == "class":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.CLASS_NAME, value)))
elif by == "link_text":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.LINK_TEXT, value)))
elif by == "xpath":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.XPATH, value)))
elif by == "css":
WebDriverWait(self.driver,secs,1).until(EC.presence_of_element_located((By.CSS_SELECTOR, value)))
else:
raise NameError("Please enter the correct targeting elements,'id','name','class','link_text','xpaht','css'.")
def get_element(self,css):
'''
Judge element positioning way, and returns the element.
'''
if "=>" not in css:
raise NameError("Positioning syntax errors, lack of '=>'.")
by = css.split("=>")[0]
value = css.split("=>")[1]
if by == "id":
element = self.driver.find_element_by_id(value)
elif by == "name":
element = self.driver.find_element_by_name(value)
elif by == "class":
element = self.driver.find_element_by_class_name(value)
elif by == "link_text":
element = self.driver.find_element_by_link_text(value)
elif by == "xpath":
element = self.driver.find_element_by_xpath(value)
elif by == "css":
element = self.driver.find_element_by_css_selector(value)
else:
raise NameError("Please enter the correct targeting elements,'id','name','class','link_text','xpaht','css'.")
return element
def open(self, url):
'''
open url.
Usage:
driver.open("https://www.baidu.com")
'''
self.driver.get(url)
def max_window(self):
'''
Set browser window maximized.
Usage:
driver.max_window()
'''
self.driver.maximize_window()
def set_window(self, wide, high):
'''
Set browser window wide and high.
Usage:
driver.set_window(wide,high)
'''
self.driver.set_window_size(wide, high)
def type(self, css, text):
'''
Operation input box.
Usage:
driver.type("css=>#el","selenium")
'''
self.element_wait(css)
el = self.get_element(css)
el.send_keys(text)
def clear(self, css):
'''
Clear the contents of the input box.
Usage:
driver.clear("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
el.clear()
def click(self, css):
'''
It can click any text / image can be clicked
Connection, check box, radio buttons, and even drop-down box etc..
Usage:
driver.click("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
el.click()
def right_click(self, css):
'''
Right click element.
Usage:
driver.right_click("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
ActionChains(self.driver).context_click(el).perform()
def move_to_element(self, css):
'''
Mouse over the element.
Usage:
driver.move_to_element("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
ActionChains(self.driver).move_to_element(el).perform()
def double_click(self, css):
'''
Double click element.
Usage:
driver.double_click("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
ActionChains(self.driver).double_click(el).perform()
def drag_and_drop(self, el_css, ta_css):
'''
Drags an element a certain distance and then drops it.
Usage:
driver.drag_and_drop("css=>#el","css=>#ta")
'''
self.element_wait(el_css)
element = self.get_element(el_css)
self.element_wait(ta_css)
target = self.get_element(ta_css)
ActionChains(driver).drag_and_drop(element, target).perform()
def click_text(self, text):
'''
Click the element by the link text
Usage:
driver.click_text("新闻")
'''
self.driver.find_element_by_partial_link_text(text).click()
def close(self):
'''
Simulates the user clicking the "close" button in the titlebar of a popup
window or tab.
Usage:
driver.close()
'''
self.driver.close()
def quit(self):
'''
Quit the driver and close all the windows.
Usage:
driver.quit()
'''
self.driver.quit()
def submit(self, css):
'''
Submit the specified form.
Usage:
driver.submit("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
el.submit()
def F5(self):
'''
Refresh the current page.
Usage:
driver.F5()
'''
self.driver.refresh()
def js(self, script):
'''
Execute JavaScript scripts.
Usage:
driver.js("window.scrollTo(200,1000);")
'''
self.driver.execute_script(script)
def get_attribute(self, css, attribute):
'''
Gets the value of an element attribute.
Usage:
driver.get_attribute("css=>#el","type")
'''
el = self.get_element(css)
return el.get_attribute(attribute)
def get_text(self, css):
'''
Get element text information.
Usage:
driver.get_text("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
return el.text
def get_display(self, css):
'''
Gets the element to display,The return result is true or false.
Usage:
driver.get_display("css=>#el")
'''
self.element_wait(css)
el = self.get_element(css)
return el.is_displayed()
def get_title(self):
'''
Get window title.
Usage:
driver.get_title()
'''
return self.driver.title
def get_url(self):
'''
Get the URL address of the current page.
Usage:
driver.get_url()
'''
return self.driver.current_url
def get_windows_img(self, file_path):
'''
Get the current window screenshot.
Usage:
driver.get_windows_img()
'''
self.driver.get_screenshot_as_file(file_path)
def wait(self, secs):
'''
Implicitly wait.All elements on the page.
Usage:
driver.wait(10)
'''
self.driver.implicitly_wait(secs)
def accept_alert(self):
'''
Accept warning box.
Usage:
driver.accept_alert()
'''
self.driver.switch_to.alert.accept()
def dismiss_alert(self):
'''
Dismisses the alert available.
Usage:
driver.dismiss_alert()
'''
self.driver.switch_to.alert.dismiss()
def switch_to_frame(self, css):
'''
Switch to the specified frame.
Usage:
driver.switch_to_frame("css=>#el")
'''
self.element_wait(css)
iframe_el = self.get_element(css)
self.driver._switch_to.frame(iframe_el)
def switch_to_frame_out(self):
'''
Returns the current form machine form at the next higher level.
Corresponding relationship with switch_to_frame () method.
Usage:
driver.switch_to_frame_out()
'''
self.driver._switch_to.default_content()
def open_new_window(self, css):
'''
Open the new window and switch the handle to the newly opened window.
Usage:
driver.open_new_window()
'''
original_windows = self.driver.current_window_handle
el = self.get_element(css)
el.click()
all_handles = self.driver.window_handles
for handle in all_handles:
if handle != original_windows:
self.driver._switch_to.window(handle)
if __name__ == '__main__':
driver = Pyse("chrome")