1.框架设计模式
- PO模式
- 组件化封装(分层),以功能相关进行分类
2.实例:以题库选择试卷为例子分为两种情况
a)没有登录使用题库步骤: 1.启动app,点击题库 2.获取页面提示信息,id=com.lemon.lemonban:id/button_go_login
b)登录后使用题库 1.登录成功 2.进入题库 3.选择题库 choose_tiku(name),xpath = //*[@text="Linux"] 4.选择题库难度,初级,xpath = //*[@text="初级"] 5.选择试卷,xpath = //*[@text="Linux--初级--第1套"] 6.断言标题时候包含1,定位 id= com.lemon.lemonban:id/toolbar_textview 7.点击显示答案,id = com.lemon.lemonban:id/switch_button 8.断言是否有答案,id =com.lemon.lemonban:id/tvBody 长度>0 9.滑动5次之后,断言标题是不是5,id= com.lemon.lemonban:id/toolbar_textview
首先可以对 底部菜单进行单独管理,放置在menu类中,完成组件化封装
"""菜单组件"""
from common.native_page import NativePage
class Menu(NativePage):
"""底部菜单栏"""
# 主页
locator_homepage = ('id','com.lemon.lemonban:id/navigation_home')
# 题库
locator_tiku = ('id','com.lemon.lemonban:id/navigation_tiku')
# 用户 我的柠檬
locator_user = ('id', 'com.lemon.lemonban:id/navigation_my')
def enter_homepage(self):
"""进入主页"""
self.touch(self.locator_homepage)
def enter_tiku(self):
"""进入题库"""
self.touch(self.locator_tiku)
def enter_user_page(self):
"""进入我的柠檬"""
self.touch(self.locator_user)
此时,homepage类中代码就可以优化为(直接继承Menu,不需要其他操作)
from pages.menu impor