python接口自动化(三十五)-封装与调用--流程类接口关联(详解)

简介

  流程相关的接口,主要用 session 关联,如果写成函数(如上篇),s 参数每个函数都要带,每个函数多个参数,这时候封装成类会更方便。在这里我们还是以博客园为例,带着小伙伴们实践一下。

接口封装大致流程

1、在接口测试中,有些接口经常会被用到比如登录的接口,这时候我们可以每个接口都封装成一个方法,如:登录、保存草稿、发布随笔、删除随笔,这四个接口就可以写成四个方法

2、接口封装好了后,后面我们写用例那就直接调用封装好的接口就行了,有些参数,可以参数化,如保存草稿的 title 和 body 两个参数是动态的。调用时直接将其传入方法中,就可以了

3、像这种流程类的接口,后面的会依赖前面的,我们就可以通过 session将其关联起来

4、将自动化测试脚本保存到 login.py文件中,这样就可以是脚本和业务分离

实战实例

第一步:在pycharm中左上角点击“file”,然后点击“New Project”,修改名字为“jiekou”,点击“Create”

第二步:在jiekou文件夹下,分别创建python package分别命名为“blog”和“case”

第三步:都完成后,如下

第四步:在login.py文件中编辑自动化测试脚本

用例导入接口

1、导入上面 login.py 模块写的接口自动化测试脚本

2、在test_01.py中编辑测试用例

参考代码

login.py文件

 1 # coding=utf-8
 2 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
 3 
 4 # 2.注释:包括记录创建时间,创建人,项目名称。
 5 '''
 6 Created on 2019-5-15
 7 @author: 北京-宏哥
 8 Project:学习和使用封装与调用--流程类接口关联
 9 '''
10 # 3.导入模块
11 import requests
12 # 禁用安全请求警告
13 import urllib3
14 
15 urllib3.disable_warnings()
16 import warnings
17 
18 warnings.simplefilter("ignore", ResourceWarning)
19 
20 
21 class Blog():
22     def __init__(self, s):
23         s = requests.session()  # 全局参数
24         self.s = s
25 
26     def login(self):
27         '''登录接口'''
28         url = "http://localhost:8080/jenkins/j_acegi_security_check"
29         headers = {
30             "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64; rv:44.0) Gecko/20100101 Firefox/44.0"
31         }  # get方法其它加个ser-Agent就可以了
32         d = {"j_username": "admin",
33              "j_password": "111111",
34              "from": "",
35              "Submit": u"登录",
36              "remember_me": "on"
37              }
38 
39         s = requests.session()
40         r = s.post(url, headers=headers, data=d)
41         # print (r.content.decode('utf-8'))
42         # 正则表达式提取账号和登录按钮
43         import re
44         t = re.findall(r'<b>(.+?)</b>', r.content.decode('utf-8'))  # 用python3的这里r.content需要解码
45         print(t[0])
46         print(t[1])
47 
48     def get_postid(self, r2_url):
49         '''正则表达式提取'''
50         import re
51         postid = re.findall(r"postid=(.+?)&", r2_url)
52         print(postid)  # 这里是 list []
53         # 提取为字符串
54         print(postid[0])
55         return postid[0]
56 
57     def save(self, title, body):
58         '''保存草稿箱:
59         参数 1:title # 标题
60         参数 2:body # 中文'''
61         url2 = "https://i.cnblogs.com/EditPosts.aspx?opt=1"
62         d = {"__VIEWSTATE": "",
63              "__VIEWSTATEGENERATOR": "FE27D343",
64              "Editor$Edit$txbTitle": title,
65              "Editor$Edit$EditorBody": "<p>%s</p>" % body,
66              "Editor$Edit$Advanced$ckbPublished": "on",
67              "Editor$Edit$Advanced$chkDisplayHomePage": "on",
68              "Editor$Edit$Advanced$chkComments": "on",
69              "Editor$Edit$Advanced$chkMainSyndication": "on",
70              "Editor$Edit$lkbDraft": "存为草稿",
71              }
72         r2 = self.s.post(url2, data=d, verify=False)  # 保存草稿箱
73         print(r2.url)
74         return r2.url
75     
76     def del_tie(self, postid):
77         '''删除帖子'''
78         del_json = {"postId": postid}
79         del_url = "https://i.cnblogs.com/post/delete"
80         r3 = self.s.post(del_url, json=del_json, verify=False)
81         print(r3.json()["isSuccess"])
82         return r3.json()
83 
84 
85 if __name__ == "__main__":
86     s = requests.session()
87     Blog(s).login()

test_01.py

 1 # coding=utf-8
 2 # 1.先设置编码,utf-8可支持中英文,如上,一般放在第一行
 3 
 4 # 2.注释:包括记录创建时间,创建人,项目名称。
 5 '''
 6 Created on 2019-5-15
 7 @author: 北京-宏哥
 8 Project:学习和使用封装与调用--流程类接口关联
 9 '''
10 # 3.导入模块
11 import unittest
12 import requests
13 import warnings
14 from blog.login import Blog
15 
16 
17 class Test(unittest.TestCase):
18     def setUp(self):
19         warnings.simplefilter("ignore", ResourceWarning)
20         s = requests.session()
21         self.blog = Blog(s)
22 
23      def test_login_01(self):
24        self.blog.login()
25        print (result)
26        print (type(result))
27        print (result["success"] )# 登录,获取结果
28        self.assertEqual(result["success"] , True) # 拿结果断言
29     def test_del_02(self):
30         # 第一步:登录
31         self.blog.login()
32         # 第二步:保存
33         r2_url = self.blog.save(title="北京-宏哥,流程类接口关联", body="学习和使用封装与调用--流程类接口关联")
34         pid = self.blog.get_postid(r2_url)
35         # 第三步:删除
36         result = self.blog.del_tie(pid)
37         print(result)
38         self.assertEqual(result["isSuccess"], True)
39 
40 
41 if __name__ == "__main__":
42     unittest.main()

小结

   流程相关的接口的封装和调用给各位小伙伴暂且介绍到这里,因为博客园的登陆机制改变,小伙伴们可以用jenkins的仿照这一篇实战演练一下,下一篇我会带你们一起做一下。

欲知后事发展,请听下回分解!!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏毛利学Python

爬了CSDN,我发现了这些

本文涉及到的Python第三方模块,共计五个:分词模块jieba,文字云模块wordcloud,画图模块matplotlib,用来处理背景图片的模块cv2,访问...

7520
来自专栏毛利学Python

scrapy中的强大媒体管道(二)

上文用了scrapy爬取了百度的美女图片,今天写写scrapy中的Image Pipeline

13330
来自专栏毛利学Python

数据科学篇| Matplotlib和数据可视化(三)

数据的处理、分析和可视化已经成为Python近年来最为重要的应用领域之一,其中数据的可视化指的是将数据呈现为漂亮的统计图表,然后进一步发现数据中包含的规律以及隐...

8830
来自专栏毛利学Python

pandas

pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。Pandas 纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需...

13930
来自专栏毛利学Python

scrapy 入门(一)

Scrapy,Python开发的一个快速、高层次的屏幕抓取和web抓取框架,用于抓取web站点并从页面中提取结构化的数据。Scrapy用途广泛,可以用于数据挖掘...

7820
来自专栏毛利学Python

自然语言处理| NLTK库的详解

自然语言处理(natural language processing)是计算机科学领域与人工智能领域中的一个重要方向。它研究能实现人与计算机之间用自然语言进行有...

12020
来自专栏毛利学Python

数据科学篇| Numpy 库的使用(一)

实际上,标准的Python中,用列表保存数组的值。由于列表中的元素是任意的对象,所以列表中list保存的是对象的指针。虽然在Python编程中隐去了指针的概念,...

12030
来自专栏萌海无涯

Django学习安装django环境(2)

File --> Settings --> Project:django --> Project Inerpreter

7820
来自专栏毛利学Python

Numpy的总结

对数组执行数学运算和逻辑运算时,NumPy 是非常有用的。在用 Python 对 n 维数组和矩阵进行运算时,NumPy 提供了大量有用特征。

9120
来自专栏毛利学Python

keras入门

深度学习(Deep Learning, DL)或阶层学习(hierarchical learning)是机器学习的技术和研究领域之一,通过建立具有阶层结构的人工...

8420

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励