(一) 前言

简单的说就是分为2层,页面class
和测试class。

页面class:分为父类和子类(子类指具体的页面,每一个页面都创建一个类),父类中定义公有的属性和方法(操作)。

#对面向对象有了解的,应该很容易理解抽象出公有属性和方法的意思

#父类和子类我是按自己的理解进行描述的,或者可以说basepage对象(父对象,提供公有的属性、方法)
和 page对象(具体哪一个页面)

测试class:按照业务流程,对各个页面的属性、操作进行组合,形成一个测试用例。

使用page
object模式,抽象出各个页面的元素、方法,然后再按照测试用例的要求进行组合。这样做的好处是

1、页面修改了,只要对页面类进行修改就好了,对测试类(测试用例)没太大影响

2、可以在多个测试复用部分代码。

分成父类和子类(子类指现实的页面。3、测试代码(测试类、测试用例)部分变得更易读、灵活、可维护。

分成父类和子类(子类指现实的页面。我把上一篇的代码按照page
object模式修改了下,代码如下。

分成父类和子类(子类指现实的页面。(二) 分成父类和子类(子类指现实的页面。分成父类和子类(子类指现实的页面。父类(BasePage对象,base.py)

 1 from abc import abstractclassmethod
 2 class BasePage(object):
 3     def __init__(self,driver):
 4         self.driver = driver
 5 
 6     '''验证页面是否是指定的页面。
 7     @abstractclassmethod修饰符指该方法是抽象的'''
 8     @abstractclassmethod
 9     def validate_page(self,driver):
10         return

(三) 分成父类和子类(子类指现实的页面。首页(page对象(子类),homepage.py)

 1 from base import BasePage
 2 class HomePage(BasePage):
 3     #用来定位页面元素的ID、NAME、XPTH、CSS表达式等
 4     _login_area = '#login_area'
 5     _register = '注册'
 6 
 7     def validate_page(self,driver):
 8         return driver.title == '博客园 - 开发者的网上家园'
 9     #定位并点击 注册
10     def register_click(self):
11         self.login_area = self.driver.find_element_by_css_selector(self._login_area)
12         self.login_area.find_element_by_link_text(self._register).click()

(四) 注册页面(page对象(子类),registerpage.py)

 1 from base import BasePage
 2 class RegisterPage(BasePage):
 3     # 用来定位页面元素的ID、NAME、XPTH、CSS表达式等
 4     _user_email = 'Email'
 5     _user_phone_country = 'CountryCode'
 6     _user_phone = 'PhoneNum'
 7     _user_login_name = 'LoginName'
 8     _user_nickname = 'DisplayName'
 9     _user_password = 'Password'
10     _user_confirm_password = 'ConfirmPassword'
11     _phone_error = 'PhoneNum-error'
12     _loginName_error = 'LoginName-error'
13 
14     def validate_page(self,driver):
15         return driver.title == '用户注册 - 博客园'
16 
17     #输入注册信息
18     def send_keys(self,email,phone,login_name,nickname,password,confirm_password):
19         self.driver.find_element_by_id(self._user_email).clear()
20         self.driver.find_element_by_id(self._user_phone).clear()
21         self.driver.find_element_by_id(self._user_login_name).clear()
22         self.driver.find_element_by_id(self._user_nickname).clear()
23         self.driver.find_element_by_id(self._user_password).clear()
24         self.driver.find_element_by_id(self._user_confirm_password).clear()
25         self.driver.find_element_by_id(self._user_email).send_keys(email)
26         self.driver.find_element_by_id(self._user_phone).send_keys(phone)
27         self.driver.find_element_by_id(self._user_login_name).send_keys(login_name)
28         self.driver.find_element_by_id(self._user_nickname).send_keys(nickname)
29         self.driver.find_element_by_id(self._user_password).send_keys(password)
30         self.driver.find_element_by_id(self._user_confirm_password).send_keys(confirm_password)
31 
32     #手机号码有误时的提示信息
33     def phone_err(self):
34         phone_error = self.driver.find_element_by_id(self._phone_error)
35         return phone_error.text
36 
37     #登录名不合法时的提示信息
38     def loginName_error(self):
39         loginName_error = self.driver.find_element_by_id(self._loginName_error)
40         return loginName_error.text

(五)   测试类(测试用例,testRegisterNewUser.py)

 1 from selenium import webdriver
 2 from ddt import ddt,data,unpack
 3 import xlrd
 4 from homepage import HomePage
 5 from registerpage import RegisterPage
 6 from basetestcase import BaseTestCase
 7 #读取Excel数据的函数
 8 def get_data(file_name):
 9     rows = []
10     book = xlrd.open_workbook(file_name)
11     sheet = book.sheet_by_index(0)
12     for r_idx in range(1, sheet.nrows):
13         rows.append(list(sheet.row_values(r_idx,0)))
14         pthone = rows[r_idx - 1].pop(1)
15         rows[r_idx - 1].insert(1, str(int(pthone)))
16     return rows
17 @ddt
18 class RegisterNewUserDDT(BaseTestCase):
19     #重写setUpClass()
20     @classmethod
21     def setUpClass(cls):
22         cls.driver = webdriver.Chrome()
23         cls.driver.implicitly_wait(30)
24         cls.driver.maximize_window()
25         cls.driver.get('https://www.cnblogs.com/')
26         #创建HomePage()类的对象实例
27         home_page = HomePage(cls.driver)
28         home_page.register_click()
29     # 读取excel文件的数据作为参数
30     @data(*get_data('data/reTest.xlsx'))
31     @unpack
32     def test_register_new_user(self,email,phone,login_name,nickname,password,confirm_password,expected_result):
33         #创建RegisterPage()的对象实例
34         register_page = RegisterPage(self.driver)
35         self.assertTrue(register_page.validate_page(self.driver))
36         register_page.send_keys(email,phone,login_name,nickname,password,confirm_password)
37         if phone == '1':
38             self.assertTrue(register_page.phone_err() == expected_result)
39         elif login_name == 'b':
40             self.assertTrue(register_page.loginName_error() == expected_result)

(六) 测试准备(basetestcase.py)

#这部分本来想放到第二步的,不过感觉有点影响对page
object的理解,就放到最后了

  创建一个类,定义setup()和teardowm()方法,方便所有测试复用。这个类可以理解为是测试类的一部分,我只是把所有测试类(测试用例)都用到的setup()和teardowm()拿出来,方便复用。如果哪个测试用例有特殊要求,也可以重写。

 1 import unittest
 2 from selenium import webdriver
 3 
 4 class BaseTestCase(unittest.TestCase):
 5     @classmethod
 6     def setUpClass(cls):
 7         cls.driver = webdriver.Chrome()
 8         cls.driver.implicitly_wait(30)
 9         cls.driver.maximize_window()
10         cls.driver.get('https://www.cnblogs.com/')
11     @classmethod
12     def tearDownClass(cls):
13         cls.driver.quit()

相关文章