#!/usr/bin/env python
# -*- coding:utf-8 -*-
# *************************************
# @Time : 2019/7/1
# @Author : Zhang Fan
# @Desc : RobotFramework Library
# @File : MyKeyworks.py
# @Update : 2019/8/23
# *************************************
from robot.api import logger
import configparser
import jsonpointer
import jsonpatch
import datetime
import chardet
import random
import string
import json
import time class MyKeyword(object):
"""
===================================================================
===================== MyKeyword ======================
===================================================================
"""
@staticmethod
def detect_code(self, byte_string):
"""检测字节串编码. 参数:
byte_string:字节串 示例:
| Detect Code | ${byte_string} | #返回字节串编码,比如'utf-8' |
"""
return chardet.detect(byte_string)['encoding'] def get_config_value(self, cfg_path, section, name):
"""获取配置文件中指定节点下的指定选项值. 参数:
cfg_path:配置文件路径
section:节点名
name:选项名 示例:
| Get Config Value | ${CURDIR}\\config.ini | service_info | address |
"""
cfg = configparser.ConfigParser()
cfg.read(cfg_path)
return cfg.get(section, name) """
===============================================================
===================== Json Handle ====================
===============================================================
"""
def parse_json(self, json_string):
"""
解析JSON文档并返回数据结构. 参数:
json_string:JSON文档 示例:
| ${result}= | Parse Json | [1, 2, 3] |
| Length Should Be | ${result} | 3 |
"""
try:
return json.loads(json_string)
except ValueError as e:
raise ValueError("Could not parse '%s' as JSON: %s" % (json_string, e)) def stringify_json(self, data):
"""
将数据结构转换为包含其JSON字符串表示形式的字符串. 参数:
data:数据结构 示例:
| ${data} = | Create List | 1 2 3 |
| ${json_string}= | Stringify JSON | ${data} |
| Should Be Equal As Strings | ${json_string} | ["1", "2", "3"] |
"""
try:
return json.dumps(data, ensure_ascii=False)
except ValueError as e:
raise ValueError("Could not stringify '%r' to JSON: %s" % (data, e)) def get_json_value(self, json_string, json_pointer):
"""
获取JSON中指定目标节点值. 参数:
json_string:JSON文档
json_pointer:JSON节点 示例:
| ${result}= | Get Json Value | {"foo": {"bar": [1,2,3]}} | /foo/bar |
| Should Be Equal | ${result} | [1, 2, 3] | |
"""
try:
json_string = json.loads(str(json_string))
except:
json_string = eval(str(json_string))
return jsonpointer.resolve_pointer(json_string, json_pointer) def set_json_value(self, json_string, json_pointer, json_value):
"""
设置JSON中指定目标节点值. 参数:
json_string:JSON文档
json_pointer:JSON节点
json_value:JSON值 示例:
| ${result}= | Set Json Value | {"foo": {"bar": [1,2,3]}} | /foo | 12 |
| Should Be Equal | ${result} | {"foo": 12} | | |
"""
try:
json_string = json.loads(str(json_string))
except:
json_string = eval(str(json_string))
json_new = jsonpatch.apply_patch(json_string, [{'op': 'add', 'path': json_pointer,
'value': self.parse_json(json_value)}])
return self.stringify_json(json_new) """
===================================================================
==================== DateTime Handle =====================
===================================================================
"""
def calc_time_diff(self, date1, date2=None, format_=''):
"""计算与当前的时间差,返回秒数. 参数:
date: 日期字符串(支持多种日期格式,以及时间戳)
format_: 日期格式,默认为空 示例:
| Calc Time Diff | Jul 30, 2019 10:24:36 AM |
| Calc Time Diff | 2019-07-30T10:24:36Z |
| Calc Time Diff | 2019-07-30 10:24:36.000 |
| Calc Time Diff | 2019-07-30 10:24:36 |
| Calc Time Diff | 20190730102436 |
| Calc Time Diff | 1564453476000 |
"""
def format_date(date, format_=''):
if not format_:
if all(x in date for x in ['-', ' ', ':', '.']):
format_ = "%Y-%m-%d %H:%M:%S.%f"
elif all(x in date for x in ['-', 'T', ':', 'Z']):
format_ = "%Y-%m-%dT%H:%M:%SZ"
elif all(x in date for x in [' ', ',', ':']):
format_ = "%b %d, %Y %I:%M:%S %p"
elif all(x in date for x in ['-', ' ', ':']):
format_ = "%Y-%m-%d %H:%M:%S"
else:
format_ = "%Y%m%d%H%M%S"
try:
timestamp = time.mktime(time.strptime(date, format_))
return int(timestamp * 1000)
except ValueError as e:
raise ValueError(e) if not date2:
date2 = int(time.time() * 1000)
else:
date_string2 = str(date2).strip('b').strip('u').replace("'", '').replace('"', '')
date2 = format_date(date_string2, format_) date_string1 = str(date1).strip('b').strip('u').replace("'", '').replace('"', '')
if not date_string1:
return date_string1
if date_string1.isdigit() and len(date_string1) == 13:
return int(abs(date2 - int(date_string1))/1000)
date1 = format_date(date_string1, format_)
return int(abs(date2 - date1)/1000)

Python 接口自动化常用方法封装的更多相关文章

  1. Python接口自动化——soap协议传参的类型是ns0类型的要创建工厂方法纪要

    1:在Python接口自动化中,对于soap协议的xml的请求我们可以使用Suds Client来实现,其soap协议传参的类型基本上是有2种: 第一种是传参,不需要再创建啥, 第二种就是ns0类型的 ...

  2. python接口自动化(十)--post请求四种传送正文方式(详解)

    简介 post请求我在python接口自动化(八)--发送post请求的接口(详解)已经讲过一部分了,主要是发送一些较长的数据,还有就是数据比较安全等.我们要知道post请求四种传送正文方式首先需要先 ...

  3. python接口自动化-Cookie_绕过验证码登录

    前言 有些登录的接口会有验证码,例如:短信验证码,图形验证码等,这种登录的验证码参数可以从后台获取(或者最直接的可查数据库) 获取不到也没关系,可以通过添加Cookie的方式绕过验证码 前面在“pyt ...

  4. python接口自动化28-requests-html爬虫框架

    前言 requests库的好,只有用过的人才知道,最近这个库的作者又出了一个好用的爬虫框架requests-html.之前解析html页面用过了lxml和bs4, requests-html集成了一些 ...

  5. python接口自动化-参数化

    原文地址https://www.cnblogs.com/yoyoketang/p/6891710.html python接口自动化 -参数关联(一)https://www.cnblogs.com/11 ...

  6. python接口自动化 -参数关联(一)

    原文地址https://www.cnblogs.com/yoyoketang/p/6886610.html 原文地址https://www.cnblogs.com/yoyoketang/ 原文地址ht ...

  7. python接口自动化20-requests获取响应时间(elapsed)与超时(timeout)

    前言 requests发请求时,接口的响应时间,也是我们需要关注的一个点,如果响应时间太长,也是不合理的. 如果服务端没及时响应,也不能一直等着,可以设置一个timeout超时的时间 关于reques ...

  8. python接口自动化24-有token的接口项目使用unittest框架设计

    获取token 在做接口自动化的时候,经常会遇到多个用例需要用同一个参数token,并且这些测试用例跨.py脚本了. 一般token只需要获取一次就行了,然后其它使用unittest框架的测试用例全部 ...

  9. python接口自动化6-重定向(Location)

    前言 某屌丝男A鼓起勇气向女神B打电话表白,女神B是个心机婊觉得屌丝男A是好人,不想直接拒绝于是设置呼叫转移给闺蜜C了,最终屌丝男A和女神闺蜜C表白成功了,这种场景其实就是重定向了. 一.重定向 1. ...

随机推荐

  1. 在 ASP.NET Core 中使用 FluentValidation 进行验证

    目录 从 NuGet 安装 FluentValidation 争对 Resource类 建立 FluentValidation 在Startup中对写好的验证进行注册 从 NuGet 安装 Fluen ...

  2. swoole运行模式加速laravel应用的详细介绍

    本篇文章给大家带来的内容是关于swoole运行模式加速laravel应用的详细介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 一.Swoole Swoole号称重新定义了PHP, ...

  3. 权值初始化 - Xavier和MSRA方法

    设计好神经网络结构以及loss function 后,训练神经网络的步骤如下: 初始化权值参数 选择一个合适的梯度下降算法(例如:Adam,RMSprop等) 重复下面的迭代过程: 输入的正向传播 计 ...

  4. C#程序编写高质量代码改善的157个建议【10-12】[创建对象时需要考虑是否实现比较器、区别对待==和Equals]

    前言 建议10.创建对象时需要考虑是否实现比较器 建议11.区别对待==和Equals 建议12.重写Equals时也要重写GetHashCode 建议10.创建对象时需要考虑是否实现比较器 有对象的 ...

  5. Spring基础——IOC九种bean声明方式

    Spring简介 Spring不是服务于开发web项目的功能,或业务.而是服务于项目的开发,方便各层间的解耦调用,方便对类的批量管理,是提高软件开发效率,降低后期维护成本的框架. Spring的核心思 ...

  6. iOS核心动画高级技巧 - 7

    13. 高效绘图 高效绘图 不必要的效率考虑往往是性能问题的万恶之源. ——William Allan Wulf 在第12章『速度的曲率』我们学习如何用Instruments来诊断Core Anima ...

  7. 用Python在25行以下代码实现人脸识别

    在本文中,我们将看到一种使用Python和开放源码库开始人脸识别的非常简单的方法. OpenCV OpenCV是最流行的计算机视觉库.最初是用C/C++编写的,现在它提供了Python的API. Op ...

  8. 是时候扔掉 Postman 了,试试 IntelliJ IDEA 自带的高能神器!

    前言 接口调试是每个软件开发从业者必不可少的一项技能,一个项目的的完成,可能接口测试调试的时间比真正开发写代码的时间还要多,几乎是每个开发的日常工作项.所谓工欲善其事必先利其器,在没有尝到 IDEA ...

  9. k8s 使用 Init Container 确保依赖的服务已经启动

    k8s 使用 Init Container 确保依赖的服务已经启动 Intro 最近 helm 3 正式发布了,dotnetcore 3.1 也正式发布了,最近打算把我的活动室预约项目做一个升级,项目 ...

  10. java的各种日志框架

    本文是作者原创,版权归作者所有.若要转载,请注明出处.文章中若有错误和疏漏之处,还请各位大佬不吝指出,谢谢大家. java日志框架有很多,这篇文章我们来整理一下各大主流的日志框架, 包括log4j  ...