python接口自动化测试

一、以登录为例,cookie验证

 

1.打开登录页面--输入用户名密码--点击登录--前端进行密码加密--调用登录接口,传入用户名和加密后的密码--和数据库进行验证

2.打开登录页面--输入用户名密码--点击登录--调用登录接口,传入用户名和密码,并将密码加密--和数据库进行验证

一般都用第二种方法。前端加密不安全,使用f12就能看出系统使用哪种加密方式,并且加密方式若有改动时改动较大。一般复杂操作放到后端

 

封装一个登录的类libs\login.py  libs里放业务文件

class Login:
    def login(self,Data,mode=True): #登录方法
        # URL路径
        url=f'{HOST}'
        '''
        data:一般是表单格式
        json:json.单引号字典,双引号json
        files:文件上传接口
        params:参数会放到url路径里 ?后边
        '''
        resp = requests.post(url, Data)
        # print(resp.text.encode('utf8').decode('unicode-escape'))
        if mode:#获取cookie
            session = requests.Session()
            cookies_jar = session.post(url, Data).cookies
            cookie = requests.utils.dict_from_cookiejar(cookies_jar)
            return cookie
        else:#获取响应数据
           #查看响应unicode转码
            return resp.text.encode('utf8').decode('unicode-escape').replace("\/", "/") #json字符串


二、Yaml基本语法。需要安装pyYaml

冒号后边要加空格

data\loginCase.yaml

- #该符号表示列
  url:
  method: POST
- #test_01用例
  detail: 用户名密码都正确
  data:
    username: "xiajing001"
    password: "123456"
  resp:
    code: 0
    msg: "登录成功"
- #test_02用例
  detail: 用户名为空,密码正确
  data:
    username: ""
    password: "123456"
  resp:
    code: 1
    msg: "帐号或密码不正确"

tools\yamlControl.py

import yaml

def get_yaml_data(fileDir):
    #1.读取文件操作
    fo = open(fileDir,'r',encoding='utf-8') #file_Object
    #2.使用yaml方法获取数据
    res = yaml.load(fo,Loader=yaml.FullLoader)
    fo.close()
    #获取公共信息
    info = res[0]
    del res[0]
    return res
if __name__ == '__main__':
    res = get_yaml_data('../data/loginCase.yaml')
    print(res)

三、先不使用pytest框架写测试用例的执行

testCase\test_login.py  testCase里放测试文件

from Interface.tools.yamlControl import get_yaml_data
from Interface.libs.login import Login
import json

#执行用例
#获取用例数据
for res in get_yaml_data('../data/loginCase.yaml'):
    # print(res)
    #调用接口方法,获取响应数据
    respData = Login().login(res['data'],False)
    # print(respData)
    resp = json.loads(respData) #将string转化为dict
    # print(resp["code"])
    #断言 实际响应与预期做对比
    if res['resp']['code'] == resp['code'] :
        print('---用例通过---')

四、使用pytest框架

tools\yamlControl.py

import yaml

def get_yaml_data(fileDir):
    resList = [] #存放结果[(请求1,期望响应1),(请求2,期望响应2)]
    #1.读取文件操作
    fo = open(fileDir,'r',encoding='utf-8') #file_Object
    #2.使用yaml方法获取数据
    res = yaml.load(fo,Loader=yaml.FullLoader)
    fo.close()
    #获取公共信息,自己封装基类可以使用
    info = res[0]
    del res[0]
    for one in res:
        resList.append((one['data'],one['resp']))
    return resList #存放结果[(请求1,期望响应1),(请求2,期望响应2)]
if __name__ == '__main__':
    res = get_yaml_data('../data/loginCase.yaml')
    for one in res:
        print(one)

testCase\test_login.py

from Interface.tools.yamlControl import get_yaml_data
from Interface.libs.login import Login
import json
import pytest
'''
数据驱动--读取用例数据--给框架执行
1.用例的请求数据
2.用例的期望结果
'''

#登录接口-测试类封装
class TestLogin:
    # 测试方法
    @pytest.mark.parametrize('inBody,expData',get_yaml_data('../data/loginCase.yaml'))#数据驱动方法
    def test_login(self,inBody,expData):
        # 调用业务层代码
        res = Login().login(inBody,False)
        resp = json.loads(res)  # 将string转化为dict
        # 断言
        # print(resp['msg'])
        # print(expData['msg'])
        assert resp['msg'] == expData['msg']
if __name__ == '__main__':
    pytest.main(['test_login.py','-sq']) #-s输出打印信息,-q简化

五、allure报告

1.下载allure

https://repo.maven.apache.org/maven2/io/qameta/allure/allure-commandline/

2.配置allure系统环境变量。D:\tools\allure-2.14.0\bin 添加到path中

3.cmd窗口验证环境变量配置是否成功  输入allure

4.安装allure-pytest:

pip install allure-pytest

5.运行用例时使用allure生成报告

6.查看测试报告:

命令行输入 :allure serve 生成报告的目录

testCase\test_login.py

import allure,osif __name__ == '__main__':
    pytest.main(['test_login.py','-sq','--alluredir','../report/tmp']) #-s输出打印信息,-q简化
    #使用allure产生报告
    os.system("allure serve ../report/tmp")
testCase\conftest.py
'''
这是pytest中的预置函数定义的配置文件。注意文件名称一定是conftest
scope参数定义4种等级,默认为function:
session:在本次session级别中只执行一次
module:在模块级别中只执行一次
class:在类级别中只执行一次
function:在函数级别中执行,每有一个函数执行一次

'''
import pytest
import os
import shutil

# 自动化测试执行前--环境初始化操作 autouse:如果True,则为所有测试用例不需要传参也会调用这个fixture。如果为False则需要显示的调用fixture
@pytest.fixture(scope='session',autouse=True)
def start_running():
    print('---开始执行自动化测试,处理之前数据---')
    shutil.rmtree('../report/tmp')  # 强制删除文件夹
    os.mkdir('../report/tmp')  # 新建同名文件
    yield #yield前边是setup操作,后边是teardown操作
    # 自动化测试结束后,数据清除操作
    print('---自动化测试完成---')

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值