python+appium实战一:连接服务器

一、Desired Capabilities的配置
定义一个json文件,存储配置信息。

{
  "platformName": "Android",
  "deviceName": "test",
  "appPackage": "cn.xxx.xxx",
  "appActivity": "xxx",
  "autoGrantPermissions": true,
  "printPageSourceOnFindFailure": true,
  "noReset": true,
  "automationName":  "UiAutomator2"
}

2、连接appium服务器

class Driver(object):

    @classmethod
    def get_driver(cls):
        #caps_json = JsonUtils.load_json('../../data/
        caps = JsonUtils.load_json('./data/setting.json')
        cls.driver = webdriver.Remote('http://127.0.0.1:4723/wd/hub',caps)
        cls.driver.implicitly_wait(5)
        return cls.driver

3、日志工具类
日志输出对于发现问题是很有帮助的,先定义一个日志工具类,可按自定义最能定位问题的日志类,方便后续开发 使用。


'''
日志工具类
'''
import datetime
import logging
import os
import time
from logging import handlers


class Log(object):
    @classmethod
    def log(cls):
        cls.logger = logging.getLogger('wps')
        log_path = '../log'
        if not os.path.isdir(log_path):
            os.mkdir('../log')
        if not cls.logger.handlers:
            date = time.strftime('%Y%m%d',time.localtime(time.time()))
            save_to_file_handler = handlers.TimedRotatingFileHandler('../log/'+date+'.log',when = 'D',encoding = 'utf-8')
            save_to_file_handler.setLevel('WARNING')
            save_to_file_handler.setFormatter(logging.Formatter('%(name)s-%(levelname)s-%(asctime)s-%(filename)s-%(funcName)s[:%(lineno)d]-  %(message)s'))
            cls.logger.addHandler(save_to_file_handler)
        return cls.logger

在定义日志类时使用@classmethod,可以避免使用时都得实例化,可以直接通过类名调用并输出。在这里我使用了TimedRotatingFileHandler方法,表示日志文件按时间进行切割 ,日志文件以当天日期进行命名,方便查看。
通过四大组件自定义日志器的流程为:
(1)先通过logging.getlogger()获取一个logger对象,这里可以获取多个,但需注意name需为不同,不然会被指向同一个。
(2)获取Handler对象,一般不会直接实例化获取,在这里可以先判断当前logger是否已存在handler,如果已存在就不再执行添加,否则会出现一个日志信息输出多条(因为每次调用日志类时都会执行添加一个handler,多次就会添加多个handler,这样就会输出多条相同的日志)。
(3)设置处理器输出日志的等级
(4)自定义日志格式,
(5)logger与handler“绑定”
(6)返回一个logger对象,供外部类调用

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值