python接口测试_Python接口测试之token&session处理(完结)

902a3a1fd8b7a7827a20374e699c7735.png

在之前章节详细了介绍了使用postman工具如何来获取token,以及对token变量的调用和处理,同时介绍了在jmeter的测试工具中,使用jmeter然后处理token和session,cookie,以及对token的调用,那么本节课将继续沿着上面的知识点进行,不过本节课将是以代码的方式进行,而不再是工具的形式。

在前面我们介绍了使用postman,jmeter如何获取token以及传递token,下面我们就来使用python语言来进行实现,在这里我们使用第三方的库requests,需要单独的安装下,安装的命令是:

pip install -U requests

见安装的截图:

26fbe28e04ea3a849a272882e275fb8e.png

安装成功后,如果可以在正常的导入,说明安装OK,见截图:

acc15df944ae382b290709b5aaee346c.png

安装好requests好后,我们就可以开始了,关于requests有不清楚的,可以看Python接口测试之requests(七),这里我们直接来进行实战,我们再来进行回顾下我们需要做的事情,我们需要做的就是登录成功后,获取token,后面的接口都需要这个参数,所以我们需要把获取的token当作参数来进行传递,在这里我们来思考一个问题,在python的函数中,为什么会有返回值?返回值可以干什么?python中,函数的返回值是为了给另外一个函数传递参数,传递参数可以理解为是通过自动将对象赋值给本地变量名来实现。OK,下面我们就来使用实现这个过程,我们首先使用代码来实现登录的接口并且获取返回的json字符串,见实现的代码:

4f40152e20287fa546bcbb283a140e5f.png

见执行函数getToken后获取的json字符串:

743ba1acbfb849b9990fe507cbbc7a06.png

我们可以看到,获取的内容是json字符串,经过反序列化后,数据类型是字典(dict),按字典的方式来获取token就很简单的,见获取token的代码:

cde8da6b6863310f51291dae7a4239dd.png

见执行后,获取的token字符串,见截图:

97c91123e0f5c5f3298b5d44648ad7ee.png

下面来实现infoGet接口的测试,依据前面的案例我们知道,该接口的参数就是token,而且必须是和登录成功后返回的token是一致,否则就会提示502的错误,token无效,我们来实现infoGet接口测试,见实现代码:

004d987f0f04461ba94af4ec422fc724.png

见执行infoGet函数后,返回的json字符串内容:

C:Python27python.exe D:/git/Python/UnitCI/blog/weke.py

{u'status': 0, u'msg': u'', u'data': {u'username': u'autoapi', u'online_agreement': 0, u'name': u'自动化测试', u'valid_period': 0, u'id': 600192, u'phone': u'', u'pigeon_id': u'maLdrGaCEMAoS9kYW9t1514038531444', u'address': u'', u'supports': u'0', u'email': u'', u'park_code': 6666666666L}}

我们接着加一个接口,该接口为isSoonExpire,见测试该接口实现的代码:

c441121264540d997848088ca82df00d.png

下面我们对代码进行重构下,引入unittest,见重构后的代码:

如上的接口测试用例缺少断言,在这里特别强调,没有断言的自动化测试用例是无效的,是没有任何的价值的。至于具体断言什么,得格局具体的接口测试的业务来进行,我们对如上的接口添加断言,见增加断言后的接口测试代码:

f462a74d0d914cfe4e9bcf6e17904098.png

执行上面的测试用例后,我们发现二个测试用例都调用了getToken()方法,而getToken()方法我们知道是登录的接口,登录成功后获取token,言外之意也就是说登录了二次,缺点很明显,如果在N个测试用例,参数都需要token,都会调用getToken(),那么也会出现登录N次,很实现这个方法不是我们想要的,我们要实现的是不管有多少个接口测试用例,登录只能是一次,如果登录多次,会出现token无效502的问题,或者引起其他的问题,在这里我们把登录成功后的token存储在文件中,然后从文件中读取,这样就可以登录一次,见实现的代码:

4ccf4b29a6f78f473154e06bda6d10b3.png
f50f7f3c84164ccb71ccd036ae8c24ac.png

代码经过重构后,不管有多少个测试用例,我们的登录只会进行一次。接下来我们会写关于session这部分,python是如何解决的。

python处理session

下面我们使用python来处理session的部分,下面我们来看一个例子,登录成功后,并没有返回token,只是返回了请求成功的code,而是存储session中,那么我们应该如何来获取session了,我们编写该登录的接口用例,看返回的json字符串是什么,见实现的代码以及输出的截图:

b9fef91c0becbeac13d87e79ef80cdd6.png

在截图中我们看到,输出的json字符串只有code是200的,再没有什么,但是后面的请求都需要带上session,我们看下一个接口请求的内容,见截图:

70390470661ce2318f3b8df9d3c0335d.png

那么就说明我们登录后必须得获取session,见获取session的代码:

6b74d3332ac18465fad8968197cd0c4f.png

通过cookies.get_dict()就可以获取session,见如上截图中获取的session内容,下面的就很简单,我们在下一个接口用例中带上session,见实现的码:

e18cc6c8b41b272ee35071c3a7f762a4.png

执行如上的代码后,我们发现代码错误,错误的原因是test_access_datas()函数没有带上登录成功后的session,所以导致错误,不带session,一般直接就跳转到了login的页面,让重新登录,那么如何解决了,我们只需要在test_access_datas()函数中,在接口请求中带上session就可以了,见修改后执行的代码:

ccc72966def131eca821f584f8f8b4a6.png

如此,总结了使用postman,jmeter,python语言来处理token和session的问题,在这里一次性的进行总结,如您对我写的内容感兴趣,请分享到朋友圈让更多的人来关注,谢谢。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的接口自动化测试框架。 首先,需要安装pytest库。可以使用以下命令: ```python pip install pytest ``` 然后,可以创建一个项目文件夹,并在其中创建以下文件: 1. `conftest.py`:用于定义全局配置和夹具。 2. `test_*.py`:包含测试用例的文件(可以有多个)。 接下来,我们将逐步介绍如何编写这些文件。 ## conftest.py 在这个文件中,我们可以定义一些全局配置和夹具。这里有一个例子: ```python import pytest import requests @pytest.fixture(scope="session") def api(): """创建一个API客户端实例""" return requests.Session() @pytest.fixture(scope="session") def base_url(): """定义API的基本URL""" return "http://api.example.com" @pytest.fixture(scope="module") def auth(api, base_url): """执行身份验证,并返回访问令牌""" response = api.post(f"{base_url}/auth", json={"username": "user", "password": "pass"}) token = response.json()["access_token"] api.headers.update({"Authorization": f"Bearer {token}"}) return token ``` 在这个例子中,我们定义了三个夹具: 1. `api`:创建一个API客户端实例,用于发送HTTP请求。 2. `base_url`:定义API的基本URL。 3. `auth`:执行身份验证,并返回访问令牌。 其中,`api`夹具的作用域为`session`,也就是说,在整个测试过程中,只会创建一次这个夹具。而`base_url`和`auth`的作用域为`module`,也就是说,在每个测试模块(即每个`test_*.py`文件)中,都会创建一次这两个夹具。 ## test_*.py 在这些文件中,我们可以编写测试用例。以下是一个例子: ```python def test_get_users(api, base_url, auth): """测试获取所有用户""" response = api.get(f"{base_url}/users") assert response.status_code == 200 assert len(response.json()) > 0 def test_create_user(api, base_url, auth): """测试创建新用户""" data = {"username": "newuser", "password": "newpass"} response = api.post(f"{base_url}/users", json=data) assert response.status_code == 201 assert response.json()["username"] == data["username"] ``` 在这个例子中,我们定义了两个测试用例: 1. `test_get_users`:测试获取所有用户,并检查返回的状态码和用户数量。 2. `test_create_user`:测试创建新用户,并检查返回的状态码和用户名。 这些测试用例将通过以下命令运行: ```python pytest ``` 这将在当前目录中查找所有以`test_*.py`命名的文件,并运行其中的所有测试用例。 总的来说,这是一个非常简单的接口自动化测试框架。您可以根据需要添加更多的夹具和测试用例,并使用pytest的各种特性(如参数化、装饰器等)来扩展它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值