三十三、实战演练之接口自动化平台的项目接口管理接口设计
创始人
2025-06-01 01:53:36

一、接口创建

接口名称: /interfaces/

请求方式: POST

参数格式: JSON

请求参数:

参数

变量名

类型

说明

是否必传

接口名称

name

字符串

项目接口名称

接口地址

url

字符串

接口地址

请求方法

method

字符串

请求方法

接口类型

type

字符串

接口类型

所属项目

project

整数

所属项目id

请求示例:

json格式参数

{
"name": "登录",
"url": "/users/login/",
"method": "post", 	
"type": "1",	
"project": 1
}

返回示例

响应状态码:201 响应数据:

{"id": 1,"steps": [],"name": "登录","url": "/users/login/","method": "post","type": "1","project": 1}

二、 删除接口

接口名称:/interfaces/接口ID/

请求方式: DELETE

参数格式: 路径参数

请求参数:

返回示例

响应状态码:204 响应数据:无

三、修改接口

接口名称:/interfaces/接口ID/

请求方式: PUT/PATCH

参数格式: JSON

请求参数:

参数

变量名

类型

说明

是否必传

接口名称

name

字符串

项目接口名称

put请求必传

接口地址

url

字符串

接口地址

put请求必传

请求方法

method

字符串

请求方法

put请求必传

接口类型

type

字符串

接口类型

put请求必传

所属项目

project

整数

所属项目id

put请求必传

请求示例:

json格式参数

{
"name": "登录",
"url": "/users/login/",
"method": "post", 	
"type": "1",	
"project": 1
}

返回示例

响应状态码:200 响应数据:

{"id": 1,"steps": [],"name": "登录","url": "/users/login/","method": "post","type": "1","project": 1}

四、查看接口列表

接口名称:/interfaces/

请求方式: GET

参数格式: URL参数

请求参数:

参数

变量名

类型

说明

是否必传

项目id

project

整数

所属项目id

类型

type

字符串

接口类型

返回示例

响应状态码:200 响应数据:

[{"id": 1,"steps": [],"name": "登录","url": "/users/login/", "method": "post","type": "1","project": 1}]

五、查看接口

接口名称:/interfaces/接口ID/

请求方式: GET

参数格式: 路径参数

请求参数:

返回示例

响应状态码:200 响应数据:

{"id": 1,"steps": [],"name": "登录","url": "/users/login/","method": "post","type": "1","project": 1}

六、后端代码

1.  序列化器

在projects/serializers.py 模块中添加如下序列化器:

在接口详情中,需要嵌套测试步骤,所以先定义了一个测试步骤的序列化器

class NestTestStepSerializer(serializers.ModelSerializer):"""嵌套测试步骤序列化器"""class Meta:model = TestStepfields = ['id', 'title']class InterfaceSerializer(serializers.ModelSerializer):"""接口序列化器"""steps = NestTestStepSerializer(source='teststep_set', many=True, read_only=True)class Meta:model = Interfacefields = '__all__'

 2. 视图(手动实现过滤功能)

class InterfaceViewSet(ModelViewSet):serializer_class = InterfaceSerializerqueryset = Interface.objects.all()permission_classes = [IsAuthenticated, IsLeaderOrReadOnly]# filterset_fields = ['project', 'type']filterset_class = InterFaceFilter# 手动实现过滤功能# 复写get_queryset# def get_queryset(self):#     queryset = super().get_queryset()#     # 获取参数#     project = self.request.query_params.get('project')#     type_ = self.request.query_params.get('type')#     # 过滤#     if project:#         queryset = queryset.filter(project=project)#     if type_:#         queryset = queryset.filter(type=type_)#     return queryset

3.路由

from rest_framework.routers import DefaultRouterfrom . import viewsrouter = DefaultRouter()
router.register('interfaces', views.InterfaceViewSet)
urlpatterns = router.urls

七、期间遇到的一些问题

1.  在写接口序列化器的时候,我想要拿到每个接口的用例信息,也就是steps参数

目前是这样子:

 

 

 改造: (嵌套序列化器)

2. 手动过滤(代码在上面)

相关内容

热门资讯

2026 CES 霞光社&qu... 合作伙伴 & 招募持续进行中无论您是希望登上Panel畅谈前沿观点的思想者,还是希望成为我们探展镜头...
快手开盘股价直线下跌,黑灰产攻... 12月23日,港股开盘,快手(1024.HK)股价直线下跌。截至发稿,股价62.9港元,跌5.7%。...
你们四川人的嘴太严了 你究竟还藏了多少秘密?听说斯基在乐山,波旁斯基张口就来:乐山美食经济三驾马车:甜皮鸭、跷脚牛肉和钵钵...
海南板块大幅高开 12月23日早盘,海南板块大幅高开,海峡股份、海汽集团、海南发展、海南瑞泽涨停,康芝药业、海南机场、...
化工品轮番涨价 高端产能有序扩... 近期MDI、碳酸锂等化工品轮番涨价,涨价潮驱动化工板块表现活跃。其中,在能源成本、运输成本与环保压力...