【Python】pact-python模块进行契约测试

2023-11-10 18:52

本文主要是介绍【Python】pact-python模块进行契约测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Pact是一个契约测试框架,有多种语言实现,本文主要介绍模块pact-python进行契约测。
官网:https://docs.pact.io/implementation_guides/python/readme

安装命令:pip install pact-python  
安装过程中如果报错,安装失败,需要进如pact包下载官网,找到对应的ZIP包自行下载,
https://github.com/pact-foundation/pact-ruby-standalone/releases 
放到pact\bin目录下,再重新用命令pip install pact-python  安装

此外需要安装另外两个依赖包:pip install requests 和pip install Flask

Step 1: 写一个 customer:customer_success.py

import requestsheaders = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0',"Content-Type": "application/json",
}
data={"data": {"transactionType": "C",  # "brnNo": "9998199930",   #"taxInvoiceNumber": "202106161221150000000001", "supplierBrnNo":"9998199954","creationDate": "20210616",     #"taxInvoiceType": "11",  # "supplyPrice": 75000000000,     #"taxAmount": 320000000,         # "buyerBrnNo": "9998199916",# 非必填"mainItems": "전산장비","remark1": "하드웨어 10종","remark2": "소프트웨어 30종","supplierCmpName": "서울데이터시스템","buyerCmpName": "종각은행"},"header": {"chanlId": "IDC","grpId": "GROUPID001","messageTimeStamp": '2021-05-17T20:00:20.123Z',"trackingId": "ABC123DEF456"}
}
url = 'http://127.0.0.1:8080'def OLTP_inquiry():api = '/api/v2/coperator/taxInvoice'f_url = url + apiprint("请求接口:",f_url)json_data = dataprint("请求参数:",json_data)resp = requests.post(f_url, json=json_data,headers=headers)print("响应参数:",resp.json())if __name__ == '__main__':OLTP_inquiry()


Step 2: 写一个 customer:customer_error.py

import requestsheaders = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0',"Content-Type": "application/json",
}
data={"data": {"transactionType": "C",  # C-create,目前只支持C"brnNo": "9998199930",   # BRN"taxInvoiceNumber": "202106161221150000000000",  # BRN"supplierBrnNo":"9998199954","creationDate": "20210616",     #"taxInvoiceType": "11",  # 11-Electronic Tax Invoice,21-Electronic Tax Invoice(Exempt from taxation),31-Electronic Tax Invoice(Customs)"supplyPrice": 75000000000,     # Supply Price in KRW"taxAmount": 320000000,         # Tax Amount in KRW"buyerBrnNo": "9998199916",# 非必填"mainItems": "전산장비","remark1": "하드웨어 10종","remark2": "소프트웨어 30종","supplierCmpName": "서울데이터시스템","buyerCmpName": "종각은행"},"header": {"chanlId": "IDC","grpId": "GROUPID001","messageTimeStamp": '2021-05-17T20:00:20.123Z',"trackingId": "ABC123DEF456"}
}
url = 'http://127.0.0.1:8080'def OLTP_inquiry_error():api = '/api/v2/coperator/taxInvoice'f_url = url + apiprint("请求接口:",f_url)json_data = dataprint("请求参数:",json_data)resp = requests.post(f_url, json=json_data,headers=headers)print("响应参数:",resp.json())if __name__ == '__main__':OLTP_inquiry_error()


Step 3: 写一个 provider:oltp_service.py

from flask import Flask,request
app = Flask(__name__)@app.route('/api/v2/coperator/taxInvoice',methods=["POST"])
def create_tax_invoice():resp_success  ={"result": {"trackingId": "test","messageTimeStamp": "2021-06-16T15:45:59.123Z","chanlId": "IDC","grpId": "group id"},"data": {"ackSignal": "0"}}resp_error ={"result": {"trackingId": "test","messageTimeStamp": "2021-06-16T15:45:59.123Z","chanlId": "IDC","grpId": "group id"},"data": {},"error": {"code": "1234modulenm","description": "사업자번호가 존재 하지 않습니다.","descriptionKr": "Not Exist Business Registration Number"}}data = request.get_json()print(data)resp_success['result'] = data['header']resp_error['result'] = data['header']tax_no = data['data']['taxInvoiceNumber']if tax_no[-1:]=='0':return resp_errorelse:return resp_successif __name__ == '__main__':app.run(port=8080)


Step 4: 获取预期结果
先运行oltp_service.py文件启动provider服务,然后分别运行customer_success.py和customer_error.py
最终得到正常类和异常类两种预期结果。
Step 5: 写一个正常类和一个错误类案例
根据上面两个预期结果编写两个对应的测试用例
正常类测试用例:invoice_tax_pact.py

import atexit
import requests
import unittest
from pact.consumer import Consumer
from pact.provider import Provider
from pact import Like# 定义一个pact,消费者是ModuleB,生产者是ModuleA,契约文件存放在pacts文件夹下
pact = Consumer('customer_success').has_pact_with(Provider('oltp_service'), pact_dir='../pacts')
# 启动服务
pact.start_service()
atexit.register(pact.stop_service)# 测试用例
class UserTesting(unittest.TestCase):def test_service(self):post_data = {"data": {"transactionType": "C","brnNo": "9998199930","taxInvoiceNumber": "202106161221150000000001","supplierBrnNo": "9998199954","creationDate": "20210616",  #"taxInvoiceType": "11","supplyPrice": 75000000000,"taxAmount": 320000000,"buyerBrnNo": "9998199916","mainItems": "전산장비","remark1": "하드웨어 10종","remark2": "소프트웨어 30종","supplierCmpName": "서울데이터시스템","buyerCmpName": "종각은행"},"header": {"chanlId": "IDC","grpId": "GROUPID001","messageTimeStamp": '2021-05-17T20:00:20.123Z',"trackingId": "ABC123DEF456"}}# 消费者定义的期望结果expected = {"result": {"trackingId": "test","messageTimeStamp": "2021-06-16T15:45:59.123Z","chanlId": "IDC","grpId": "group id"},"data": {"ackSignal": "0"}}# 消费者定义的契约的实际内容。包括请求参数、请求方法、请求头、响应值等(pact.given('test service.').upon_receiving('post request for oltp_service').with_request(method='post', path='/api/v2/coperator/taxInvoice',body=post_data,headers={'Content-Type': 'application/json'})# 具体校验内容.will_respond_with(200, body={'data': {"ackSignal": "0"},"result": {"trackingId": Like('hello world'),  # string类型"chanlId": "IDC","grpId": "GROUPID001"},}))# pact自带一个mock服务,端口 1234,用requests向mock接口发送请求,验证mock的结果是否正确with pact:res = requests.post("http://localhost:1234/api/v2/coperator/taxInvoice",json=post_data).json()self.assertEqual(res['data'], expected['data'])if __name__ == "__main__":ut = UserTesting()ut.test_service()


Step 5: 运行测试案例获取契约文件
运行上面的invoice_tax_pact.py文件后,会在对应pacts目录生成契约文件
Step 6: 运行服务和测试案例
先启动第三步创建的服务oltp_service.py
然后打开终端,进入契约文件目录,运行命令
pact-verifier --provider-base-url=http://127.0.0.1:8080 --pact-url=customer_success-oltp_service.json

这篇关于【Python】pact-python模块进行契约测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/384625

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为