首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >appium+python自动化49-yaml管理定位元素

appium+python自动化49-yaml管理定位元素

作者头像
上海-悠悠
发布2018-07-25 15:37:28
1.2K0
发布2018-07-25 15:37:28
举报

前言

如何高效管理定位元素,这个是很有学问的问题,也是面试必问的[以下纯属个人观点,勿喷!]

  • 有的人用xml管理页面定位元素,这种逼格略高,但是小编认为学习成本大,贼麻烦。
  • 有的人提到用excel管理页面定位元素,这种略显逼格,至少做到了数据分离,但是读取excel太慢,不够高效,还得在excel里面维护,忒麻烦。
  • 有的人说把定位元素放数据库管理,这种除了装逼,没觉得有多高效,当然有小伙伴提到接口测试数据量比较大的时候,这种方法还可以。
  • 有的人用pageobject模式,直接在page类写定位方法,虽然这种没直接把定位独立出来,但这种非常直观,也易于阅读

那么有没有一种方法,既高效,直观,方便,又能装逼,还能迎合面试官口味呢?接下来就是要讲的这种yaml文件管理 对yaml不了解的可以看我之前发的这篇python笔记14-读取yaml配置文件

环境: python 3.6 appium 1.8 美团app yaml包安装:pip install pyyaml

PageObject

1.先回顾一下PageObject模式定位元素的写法,如下这种:

class HomePage:
    '''dec: 首页'''

    # name: 城市选择
    city_loc = ("id", "com.sankuai.meituan:id/city_button")

    # name: 首页搜索
    home_loc = ("id", "com.sankuai.meituan:id/search_edit")

yaml管理定位

1.把定位方法放到yaml文件管理,美团app首页元素定位如下:

HomePage:
  dec: 首页  
  # 作者:上海-悠悠 QQ交流群:512200893
  locators:
      -
        name: 城市选择
        type: id
        value: com.sankuai.meituan:id/city_button
      -
         name: 首页搜索
         type: id
         value: com.sankuai.meituan:id/search_edit

2.app上[我的]菜单页定位

MyPage:
  dec: 我的
  locators:
      -
        name: 我的
        type: accessibility_id
        value: 我的
      -
         name: 请点击登录
         type: id
         value: com.sankuai.meituan:id/user_name

3.登录页面定位,这里我把登录的几个流程页合并到一起了

---
LoginPage:
  dec: 登录页
  locators:
      -
        name: 微信登录
        type: id
        value: com.sankuai.meituan:id/passport_button_wechat
      -
         name: 手机号登录
         type: id
         value: com.sankuai.meituan:id/passport_button_meituan

      -
         name: 其它登录
         type: id
         value: com.sankuai.meituan:id/passport_button_other

      -
         name: QQ
         type: xpath
         value: //*[@text='QQ']

      -
         name: 微博
         type: xpath
         value: //*[@text='微博']

      -
         name: 账号密码
         type: xpath
         value: //*[@text='账号密码']

      -
         name: 输入账号
         type: id
         value: com.sankuai.meituan:id/edit_account

      -
         name: 输入密码
         type: id
         value: com.sankuai.meituan:id/edit_password

      -
         name: 登录按钮
         type: id
         value: com.sankuai.meituan:id/login_button

遍历读取os.walk()

1.把不同页面的元素放到对应的页面.yaml文件里,放到同一个目录下,方便一次性遍历读取

  • 在page总目录下,建一个pageelement的文件夹(这里是文件夹,里面不要有init.py文件),里面放页面元素的定位,不同的页面定义不同的namepage.yaml.
  • templetpage放一个自动生成用例的模板(这个模板是没后缀的文件),下一篇会讲
  • tools.py 用于运行代码后自动生成pages.py脚本
  • pages.py 运行tools里面代码后生成的

2.os.walk()遍历读取文件,之前有一篇专门讲过了python笔记4-遍历文件夹目录os.walk()

# coding:utf-8
import yaml
import os
# 当前脚本路径
basepath = os.path.dirname(os.path.realpath(__file__))
# yaml文件夹
yamlPagesPath = os.path.join(basepath, "pageelement")

def parseyaml():
    '''
    # 作者:上海-悠悠 QQ交流群:512200893
    遍历读取yaml文件
    '''
    pageElements = {}
    # 遍历读取yaml文件
    for fpath, dirname, fnames in os.walk(yamlPagesPath):
        for name in fnames:
            # yaml文件绝对路径
            yaml_file_path = os.path.join(fpath, name)
            # 排除一些非.yaml的文件
            if ".yaml" in str(yaml_file_path):
                with open(yaml_file_path, 'r', encoding='utf-8') as f:
                    page = yaml.load(f)
                    pageElements.update(page)
    return pageElements

if __name__ == "__main__":
    a = parseyaml()
    print(a)
    for i in a["HomePage"]['locators']:
        print(i)

运行结果:

下一篇讲通过templetpage模板自动生成pageobject模式的代码(用代码去写代码)

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-05-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 从零开始学自动化测试 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • PageObject
  • yaml管理定位
  • 遍历读取os.walk()
相关产品与服务
数据库智能管家 DBbrain
数据库智能管家(TencentDB for DBbrain,DBbrain)是腾讯云推出的一款为用户提供数据库性能、安全、管理等功能的数据库自治云服务。DBbrain 利用机器学习、大数据手段、专家经验引擎快速复制资深数据库管理员的成熟经验,将大量传统人工的数据库运维工作智能化,服务于云上和云下企业,有效保障数据库服务的安全、稳定及高效运行。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档