自动化测试模型可以看作自动化测试框架与工具设计的思想。自动化测试不仅仅是单纯写脚本运行就可以了,还需要考虑到如何使脚本运行效率提高,代码复用、参数化等问题。自动化测试模型分为四大类:线性模型、模块化驱动测试、数据驱动、关键字驱动。
1、线性模型
通过录制或编写对应应用程序的操作步骤产生的线性脚本。单纯的来模拟用户完整的操作场景。线性脚本中每个脚本都相互独立,且不会产生其他依赖与调用,其实就是简单模拟用户某个操作流程都脚本。
操作,重复操作,数据都混合在一起。
优点:每个脚本相对独立,且不产生其他依赖和调用。
缺点:开发成本高,用例之间存在重复的操作。比如重复的用户登录和退出。维护成本高,由于重复的操作,当重复的操作发生改变时,则需要逐一进行脚本的修改。
''' 案例:自动登录与退出操作 ''' from selenium import webdriver from time import sleep driver = webdriver.Firefox() driver.get_cookie("http://localhot/") # 输入用户名 driver.find_element_by_name('username').clear() driver.find_element_by_name('username').send_keys('zxw') # 输入密码 driver.find_element_by_name('password').clear() driver.find_element_by_name('password').send_keys('123456') # 登录 driver.find_element_by_name('Submit').click() sleep(3) # 退出 driver.find_element_by_link_text('退出').click() driver.switch_to.alert().accept() sleep(3) driver.quit()
2、模块化驱动测试
线性模型虽然每个用例都可以拿来独立运行,但是用例之间重复代码很多,开发、维护成本高。其实把重复的操作代码封装为独立的公共模块,当用例执行时需要用到这部分,直接调用即可,这就是模块驱动的方式。比如登录系统、退出登录、截图函数等等。
操作+(重复操作,数据)混合在一起。
优点:由于最大限度消除了重复,从而提高了开发效率和提高测试用例的可维护性。
缺点:虽然模块化的步骤相同,但是测试数据不同。比如说重复的登录模块,如果登录用户不同,依旧要重复编写登录脚本。
from selenium import webdriver from time import sleep class Login(): def user_login(self, driver): # 输入用户名 driver.find_element_by_name('username').clear() driver.find_element_by_name('username').send_keys('zxw') # 输入密码 driver.find_element_by_name('password').clear() driver.find_element_by_name('password').send_keys('123456') # 登录 driver.find_element_by_name('Submit').click() def user_logout(self, driver): # 退出 driver.find_element_by_link_text('退出').click() sleep(3) driver.switch_to.alert().accept() if __name__ == '__main__': driver = webdriver.Firefox() driver.get("http://127.0.0.1") # 隐式等待 driver.implicitly_wait(10) Login.user_login(driver) Login.user_logout(driver) # 调用登录模块 from LoginClass import * driver = webdriver.Firefox() driver.get("http://localhost/") driver.implicitly_wait(10) Login().user_login(driver) Login.user_logout(driver)
3、数据驱动测试(参数化)
模块驱动测试等模型虽然解决了脚本的重复问题,但是需要测试不同数据的用例时,模块驱动的方式就不狠适合了。数据驱动就是数据的改变从而驱动自动化测试的执行,最终引起测试结果的改变。装载数据的方式可以使列表、字典或是外部文件(txt、csv、xml、excel),目的就是实现数据和脚本的分离。
操作+重复操作+数据分开。
优点:通过这种方式,将数据和重复操作分开,可以快速增加相似测试,完成不同数据情况下的测试。
from selenium import webdriver from time import sleep class Login(): def user_login(self, driver, username, password): # 输入用户名 driver.find_element_by_name('username').clear() driver.find_element_by_name('username').send_keys(username) # 输入密码 driver.find_element_by_name('password').clear() driver.find_element_by_name('password').send_keys(password) # 登录 driver.find_element_by_name('Submit').click() def user_logout(self, driver): # 退出 driver.find_element_by_link_text('退出').click() sleep(3) driver.switch_to.alert().accept() if __name__ == '__main__': driver = webdriver.Firefox() driver.get("http://127.0.0.1") # 隐式等待 driver.implicitly_wait(10) Login.user_login(driver, "test", "123456") Login.user_logout(driver) # 调用登录模块 from LoginClass_para import * driver = webdriver.Firefox() driver.get("http://localhost/") driver.implicitly_wait(10) Login().user_login(driver, "test", "123456") Login.user_logout(driver)
4、关键字驱动测试
通过关键字的改变从而驱动自动化测试的执行,最终引起测试结果的改变。selenium IDE是一种传统的关键字驱动的自动化工具,Robot Framework是一个功能更强大的关键字驱动测试框架。