首先我們來看一下之前是如何書寫頁面模式中的類的:
BasePage:
class BasePage(object): """description of class""" #webdriver instance def __init__(self, driver): self.driver = driver
GoogleMainPage:
from BasePage import BasePage from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys class GoogleMainPage(BasePage): """description of class""" searchbox = (By.ID,'lst-ib') def inputSearchContent(self,searchContent): searchBox = self.driver.find_element(*self.searchbox) searchBox.send_keys(searchContent+Keys.RETURN)
重新審視之前的實現(xiàn),我們可以發(fā)現(xiàn)在各個子類頁面中,均需要引用相當(dāng)?shù)膕elenium類庫(比如webdriver),并且需要用webdriver來定位頁面元素,這就會造成各個子類頁面與selenium類庫有較多的集成,并且也是書寫上的浪費(fèi)。
現(xiàn)在來看一下做了結(jié)構(gòu)調(diào)整的部分呈現(xiàn):
BasePage:
from selenium import webdriver from selenium.webdriver.common.action_chains import ActionChains from selenium.common.exceptions import StaleElementReferenceException from selenium.webdriver.support import expected_conditions as EC from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.common.by import By from selenium.webdriver.common.keys import Keys class BasePage(object): """description of class""" #webdriver instance def __init__(self, browser='chrome'): ''' initialize selenium webdriver, use chrome as default webdriver ''' 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 findElement(self,element): ''' Find element element is a set with format (identifier type, value), e.g. ('id','username') Usage: self.findElement(element) ''' try: type = element[0] value = element[1] if type == "id" or type == "ID" or type=="Id": elem = self.driver.find_element_by_id(value) elif type == "name" or type == "NAME" or type=="Name": elem = self.driver.find_element_by_name(value) elif type == "class" or type == "CLASS" or type=="Class": elem = self.driver.find_element_by_class_name(value) elif type == "link_text" or type == "LINK_TEXT" or type=="Link_text": elem = self.driver.find_element_by_link_text(value) elif type == "xpath" or type == "XPATH" or type=="Xpath": elem = self.driver.find_element_by_xpath(value) elif type == "css" or type == "CSS" or type=="Css": elem = self.driver.find_element_by_css_selector(value) else: raise NameError("Please correct the type in function parameter") except Exception: raise ValueError("No such element found"+ str(element)) return elem def findElements(self,element): ''' Find elements element is a set with format (identifier type, value), e.g. ('id','username') Usage: self.findElements(element) ''' try: type = element[0] value = element[1] if type == "id" or type == "ID" or type=="Id": elem = self.driver.find_elements_by_id(value) elif type == "name" or type == "NAME" or type=="Name": elem = self.driver.find_elements_by_name(value) elif type == "class" or type == "CLASS" or type=="Class": elem = self.driver.find_elements_by_class_name(value) elif type == "link_text" or type == "LINK_TEXT" or type=="Link_text": elem = self.driver.find_elements_by_link_text(value) elif type == "xpath" or type == "XPATH" or type=="Xpath": elem = self.driver.find_elements_by_xpath(value) elif type == "css" or type == "CSS" or type=="Css": elem = self.driver.find_elements_by_css_selector(value) else: raise NameError("Please correct the type in function parameter") except Exception: raise ValueError("No such element found"+ str(element)) return elem def open(self,url): ''' Open web url Usage: self.open(url) ''' if url != "": self.driver.get(url) else: raise ValueError("please provide a base url") def type(self,element,text): ''' Operation input box. Usage: self.type(element,text) ''' element.send_keys(text) def enter(self,element): ''' Keyboard: hit return Usage: self.enter(element) ''' element.send_keys(Keys.RETURN) def click(self,element): ''' Click page element, like button, image, link, etc. ''' element.click() def quit(self): ''' Quit webdriver ''' self.driver.quit() def getAttribute(self, element, attribute): ''' Get element attribute ''' return element.get_attribute(attribute) def getText(self, element): ''' Get text of a web element ''' return element.text def getTitle(self): ''' Get window title ''' return self.driver.title def getCurrentUrl(self): ''' Get current url ''' return self.driver.current_url def getScreenshot(self,targetpath): ''' Get current screenshot and save it to target path ''' self.driver.get_screenshot_as_file(targetpath) def maximizeWindow(self): ''' Maximize current browser window ''' self.driver.maximize_window() def back(self): ''' Goes one step backward in the browser history. ''' self.driver.back() def forward(self): """ Goes one step forward in the browser history. """ self.driver.forward() def getWindowSize(self): """ Gets the width and height of the current window. """ return self.driver.get_window_size() def refresh(self): ''' Refresh current page ''' self.driver.refresh() self.driver.switch_to()
GoogleMainPage:
from BasePage import BasePage class GoogleMainPage(BasePage): """description of class""" searchbox = ('ID','lst-ib') def __init__(self, browser = 'chrome'): super().__init__(browser) def inputSearchContent(self,searchContent): searchBox = self.findElement(self.searchbox) self.type(searchBox,searchContent) self.enter(searchBox)
Test
所做的改變:
- 將與Selenium類庫相關(guān)的操作做二次封裝,放在BasePage中,其他子類頁面自動繼承相應(yīng)的操作方法(如findelement,click等等)
- 封裝了findelement方法,可以根據(jù)頁面元素的(類型,值)進(jìn)行查找,只需要調(diào)用一個方法findelement(s),而不需要針對不同的類型調(diào)用不同的find方法(fine_element_by_xxxx())
- 子類頁面不需要引用selenium的類庫,書寫更加簡單易讀
- 測試用例中也不需要引用selenium的任何類庫,簡單易讀
?現(xiàn)在我也找了很多測試的朋友,做了一個分享技術(shù)的交流群,共享了很多我們收集的技術(shù)文檔和視頻教程。
如果你不想再體驗自學(xué)時找不到資源,沒人解答問題,堅持幾天便放棄的感受
可以加入我們一起交流。而且還有很多在自動化,性能,安全,測試開發(fā)等等方面有一定建樹的技術(shù)大牛
分享他們的經(jīng)驗,還會分享很多直播講座和技術(shù)沙龍
可以免費(fèi)學(xué)習(xí)!劃重點!開源的!?。?qq群號:485187702【暗號:csdn11】
最后感謝每一個認(rèn)真閱讀我文章的人,看著粉絲一路的上漲和關(guān)注,禮尚往來總是要有的,雖然不是什么很值錢的東西,如果你用得到的話可以直接拿走!?希望能幫助到你!【100%無套路免費(fèi)領(lǐng)取】
文章來源:http://www.zghlxwxcb.cn/news/detail-848312.html
文章來源地址http://www.zghlxwxcb.cn/news/detail-848312.html
到了這里,關(guān)于基于Selenium的Web自動化框架的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!