Django实现接口自动化平台(十二)自定义函数模块DebugTalks 序列化器及视图【持续更新中】

news2024/11/25 4:27:19

上一章:

Django实现接口自动化平台(十一)项目模块Projects序列化器及视图【持续更新中】_做测试的喵酱的博客-CSDN博客

本章是项目的一个分解,查看本章内容时,要结合整体项目代码来看:

python django vue httprunner 实现接口自动化平台(最终版)_python+vue自动化测试平台_做测试的喵酱的博客-CSDN博客

一、DebugTalks 背景及相关接口

1.1 DebugTalks 应用

接口自动化,驱动使用的是httprunner==1.0版本。

httprunner 中,有一个debugtalks.py 文件,来编写自定义函数。

所以我们在创建项目时,会自动创建一个debugtalks.py 文件。一个项目对应一个debugtalks.py文件。

1.2 DebugTalks 接口

请求方式URI对应action实现功能
GET/debugtalks/.list()查询debugtalk列表
GET/debugtalks/{id}/.retrieve()检索一条debugtalk的详细数据
PUT/debugtalks/{id}/update()更新一条数据中的全部字段
PATCH/debugtalks/{id}/.partial_update()更新一条数据中的部分字段

二、DebugTalks 接口

debugtalks 就是一个python文件

2.1 内置函数文件的列表 .list()

 内置函数文件,是伴随的项目产生的。创建一个项目,自动创建一个debugtalk.py文件。删除一个项目,自动删除对应的debugtalk.py文件。

GET/debugtalks/.list()查询debugtalk列表

2.2  查看内置函数文件 .retrieve()

GET/debugtalks/{id}/.retrieve()检索一条debugtalk的详细数据

点击文件

 

 

2.3 更新内置函数文件 

PUT/debugtalks/{id}/update()更新一条数据中的全部字段

点击底部保存,更新文件。

2.4 创建与删除

创建与删除,是伴随项目 创建与删除的,所以内置文件的创建与删除,不是通过接口实现的。

三、模型类model

from django.db import models

from utils.base_models import BaseModel


class DebugTalks(BaseModel):
    id = models.AutoField(verbose_name='id主键', primary_key=True, help_text='id主键')
    name = models.CharField('debugtalk文件名称', max_length=200, default='debugtalk.py', help_text='debugtalk文件名称')
    debugtalk = models.TextField(null=True, default='#debugtalk.py', help_text='debugtalk.py文件')
    project = models.OneToOneField('projects.Projects', on_delete=models.CASCADE,
                                   related_name='debugtalks', help_text='所属项目')

    class Meta:
        db_table = 'tb_debugtalks'
        verbose_name = 'debugtalk.py文件'
        verbose_name_plural = verbose_name
        ordering = ('id',)

    def __str__(self):
        return self.name

这段代码定义了一个名为 DebugTalks 的 Django 模型(Model)类,表示一个 debugtalk.py 文件。

该模型类继承自 BaseModel,并包含以下字段:

  • id:自增的主键字段,类型为 AutoField。
  • name:debugtalk 文件的名称,类型为 CharField。
  • debugtalk:debugtalk.py 文件的内容,类型为 TextField。
  • project:与该 debugtalk.py 文件关联的项目,采用一对一(OneToOne)关系,类型为外键(ForeignKey)字段,关联到 projects.Projects 模型。

此外,该模型类还定义了以下元数据(Meta):

  • db_table:指定数据库中表的名称为 tb_debugtalks。
  • verbose_name:该模型在后台管理页面中显示的名称为 "debugtalk.py 文件"。
  • verbose_name_plural:该模型在后台管理页面中显示的复数名称也为 "debugtalk.py 文件"。
  • ordering:指定按照 id 字段进行升序排序。

通过这个模型类,可以在数据库中创建一个名为 tb_debugtalks 的表,存储 debugtalk.py 文件的信息,并与项目进行关联。

 

四、序列化器类

from rest_framework import serializers

from .models import DebugTalks


class DebugTalksModelSerializer(serializers.ModelSerializer):
    project = serializers.SlugRelatedField(slug_field='name', read_only=True)

    class Meta:
        model = DebugTalks
        exclude = ('create_datetime', 'update_datetime',)
        extra_kwargs = {
            'debugtalk': {
                'write_only': True
            }
        }


class DebugTalksSerializer(serializers.ModelSerializer):

    class Meta:
        model = DebugTalks
        fields = ('id', 'debugtalk')

定义了两个序列化器类:

1、DebugTalksModelSerializer 类继承自 DRF 的 ModelSerializer。其中:

  • project 字段使用 SlugRelatedField,将关联到 DebugTalks 模型的 project 字段以 name 属性的形式进行展示,且只读(read_only=True)。
  • Meta 内部类中指定了模型为 DebugTalks,并且排除了 create_datetime 和 update_datetime 字段。
  • extra_kwargs 定义了对于 debugtalk 字段的额外属性,此处设置为只写(write_only=True)。

2、DebugTalksSerializer 类也继承自 DRF 的 ModelSerializer。其中:

  • Meta 内部类中指定了模型为 DebugTalks,并且只包含 id 和 debugtalk 两个字段。

这些序列化器可以用于将 DebugTalks 模型实例转换为 JSON 格式的数据,或者将 JSON 数据反序列化为 DebugTalks 模型实例。通过定义不同的字段和属性,可以对数据进行验证、创建和更新操作,以满足特定的需求。

五、视图

from rest_framework import viewsets
from rest_framework.decorators import action
from rest_framework import permissions
from .models import DebugTalks
from rest_framework import mixins
from . import serializers


class DebugTalksViewSet(mixins.ListModelMixin,
                        mixins.RetrieveModelMixin,
                        mixins.UpdateModelMixin,
                        viewsets.GenericViewSet):

    queryset = DebugTalks.objects.all()
    serializer_class = serializers.DebugTalksModelSerializer
    permission_classes = [permissions.IsAuthenticated]

    def get_serializer_class(self):
        return serializers.DebugTalksSerializer if self.action == 'retrieve' else self.serializer_class

首先导入了必要的库和模块:

  • from rest_framework import viewsets 导入了 DRF 的视图集。
  • from rest_framework.decorators import action 导入了 DRF 的装饰器,用于定义自定义动作。
  • from rest_framework import permissions 导入了 DRF 的权限类。
  • from .models import DebugTalks 导入了当前项目中的 DebugTalks 模型类。
  • from rest_framework import mixins 导入了 DRF 的 Mixin 类。
  • from . import serializers 导入了当前项目中的序列化器。

然后定义了一个 DebugTalksViewSet 类,该类继承了 DRF 提供的各种 Mixin 类和 GenericViewSet 类。其中:

  • mixins.ListModelMixin 提供了列表展示功能。
  • mixins.RetrieveModelMixin 提供了详情展示功能。
  • mixins.UpdateModelMixin 提供了更新功能。
  • viewsets.GenericViewSet 是一个通用的视图集类。

在类中定义了以下属性和方法:

  • queryset 属性指定了视图集的查询集,即需要进行操作的数据集合,这里是 DebugTalks.objects.all(),表示获取 DebugTalks 模型的所有实例。
  • serializer_class 指定了默认使用的序列化器类为 serializers.DebugTalksModelSerializer。
  • permission_classes 指定了默认的权限类为 permissions.IsAuthenticated,表示只有认证的用户才能访问该视图集。

接下来定义了一个自定义方法 get_serializer_class(),用于根据不同的动作决定使用哪个序列化器类。如果动作是 retrieve(详情展示),则使用 serializers.DebugTalksSerializer,否则使用默认的序列化器类。

通过这些配置和定义,DebugTalksViewSet 类可以提供列表展示、详情展示和更新功能,并根据不同的动作选择合适的序列化器类进行数据的序列化和反序列化操作。同时,该视图集还具备权限控制,只有认证的用户才能访问。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/765185.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

AI:Illustrator 2023 for mac

illustrator是一款矢量图形编辑软件,用于创建和编辑排版、图标、标志、插图和其他类型的矢量图形。 以下是illustrator的几个特点: 矢量图形:illustrator创建的图形是矢量图形,可以无限放大而不失真,这与像素图形编辑…

Linux Lite 6.6发行版的候选版(RC)可供公众测试

导读Linux Lite的创建者Jerry Bezencon近日宣布,即将推出的Linux Lite 6.6发行版的候选版(RC)开发版本可供公众测试。 Linux Lite 6.6仍然基于Ubuntu 22.04.2 LTS(Jammy Jellyfish)长期支持的操作系统系列,…

数据结构0X-线性结构-链表栈队列

文章目录 参考:总结大纲要求线性结构-链表 参考: 总结 本系列为C数据结构系列,会介绍 线性结构,简单树,特殊树,简单图等。本文为线性结构部分。 大纲要求 线性结构 【 3 】链表:单链表、双向…

truffle 进行智能合约测试

0字 本方法使用了可视化软件Ganache 前两步与不使用可视化工具的步骤是一样的(有道云笔记),到第三步的时候需要注意: 在truffle插件下找到networks目录,提前打开Ganache软件 在Ganache中选择连接或者新建&#xff0…

动手学深度学习v2 p2 线性神经网络 线性回归

3. 线性神经网络 回归(regression)是能为一个或多个自变量与因变量之间关系建模的一类方法。 在自然科学和社会科学领域,回归经常用来表示输入和输出之间的关系。 在机器学习领域中的大多数任务通常都与预测(prediction&#xf…

科技云报道:数字化转型完成后,制造业如何走向“数智”时代?

科技云报道原创。 随着我国数字化转型行动的深入推进和智能制造工程的大力实施,制造业正朝着“数智”时代迈进,生成式AI被视为推动制造业智能化发展的关键驱动力。 据预测,到2027年,将有30%的制造业采用生成式AI来提升产品研发效…

前端Vue仿微信我的菜单栏组件按钮组件

随着技术的发展,开发的复杂度也越来越高,传统开发方式将一个系统做成了整块应用,经常出现的情况就是一个小小的改动或者一个小功能的增加可能会引起整体逻辑的修改,造成牵一发而动全身。 通过组件化开发,可以有效实现…

谷歌 Bard 深夜更新:支持中文、语音输入/播报、代码导出、对话分享

“ 降维打击:你永远想象不到自己的对手会是谁,干掉我们的不一定是同行。谷歌会被ChatGPT 打败吗?” 01 — 两天前,Bard!谷歌对 ChatGPT 的最强反击,悄咪咪的支持中文了!。今天谷歌官方公布了更新…

ModaHub魔搭社区:AI原生云向量数据库Zilliz Cloud设置运维窗口和设置时区

目录 概述 查看运维窗口 编辑运维窗口 相关文档 查看当前时区 编辑时区 相关文档 Zilliz Cloud 允许用户为集群设置运维窗口,以减少运维对工作负载的影响,增加可预测性。 概述 目前,运维窗口设置为全局设置,应用于 Zilliz Cloud 上的所有集群。 为避免在业务高峰期…

基于 rsync 像 macOS 的 Time Machine 一样备份您的 Linux 服务器

一、前言 Time Machine 这东西用过 macOS 的都知道,可以说是数据备份神器。 前几天我误删了几个文件,还好我有设置 Time Machine 自动备份,于是我打开 Time Machine,点几下鼠标,文件就回来了! 我想要是 …

【Docker】Docker镜像和Docker容器

文章目录 Docker镜像镜像基本概念为什么需要镜像?Union FS(联合文件挂载)docker镜像原理 Docker镜像命令docker rmidocker savedocker loaddocker historydocker image prune docker镜像实战离线迁移镜像镜像存储的压缩与共享 Docker容器容器…

npm link 实现全局运行package.json中的指令

packages.json "name":"testcli","bin": {"itRun": "index.js"},执行命令 npm link如果要解绑定 npm unlink testcli 现在你可以输入 itRun试一下

vue3使用下载附件功能

效果&#xff1a; 点击即可以下载打开。 代码&#xff1a; <div v-show"item.attachment.length > 0"><h3>下载附件</h3><divv-for"(doc, docIndex) in item.attachment":key"docIndex"><astyle"color: #41…

WebSocket集群解决方案,不用MQ

首先不了解WebSocket的可以先看看这篇文章&#xff0c;以及传统的WebSocket方案是怎么做的&#xff0c;https://www.cnblogs.com/jeremylai7/p/16875115.html 这是用MQ解决的版本&#xff0c;那么这种方案存在什么问题呢。 第一&#xff1a;增加MQ&#xff0c;可能造成消息挤压…

动态内存分配(3)——柔性数组

前言&#xff1a; 以前我们所学数组&#xff08;包括变长数组&#xff09;&#xff0c;在数组声明的时候&#xff0c;就必须指定数组的大小&#xff0c;它所需要的内存在编译时分配。但是有时候需要的数组大小在程序运行的时候才能知道&#xff0c;该怎么办呢&#xff1f;这就是…

Zookeeper+kafka的应用及部署

Zookeeperkafka的应用及部署 一、Zookeeper的概念1、Zookeeper 定义2、Zookeeper 工作机制3、Zookeeper 特点4、Zookeeper 数据结构5、Zookeeper 应用场景6、Zookeeper 选举机制&#xff08;1&#xff09;第一次启动选举机制&#xff08;2&#xff09;非第一次启动选举机制(1)、…

【Ajax】笔记-NodeMon 简介、安装、使用

NodeMon 简介、安装、使用 简介安装启动应用测试 简介 nodemon用来监视node.js应用程序中的任何更改并自动重启服务,非常适合用在开发环境中。以前&#xff0c;我们开发一个node后端服务时&#xff0c;每次更改文件&#xff0c;均需重启一下&#xff0c;服务才能生效。这使我们…

阿里云RocketMQ——高可用、高可靠的分布式消息处理系统

阿里云产品测评-RocketMQ 今天我对阿里的又一产品进行了深度测评&#xff08;RocketMQ&#xff09;&#xff0c;首先如果是新用户的话&#xff0c;可以先关注下面这个免费体验的活动。 一、上手实操 阿里云免费试用 1.付费或者免费开通RocketMQ 云消息队列 RocketMQ 版是阿…

容器云平台监控告警体系(四)—— Golang应用接入Prometheus

1、概述 目前容器云平台中的容器仅支持获取CPU使用率、内存使用率、网络流入速率和网络流出速率这4个指标&#xff0c;如果想监控应用程序的性能指标或者想更加细粒度的监控应用程序的运行状态指标的话&#xff0c;则需要在应用程序中内置对Prometheus的支持或者部署独立于应用…

悦数图数据库v3.5.0发布:查询性能大幅提升,为智能决策和 AI 大模型应用提速

近日&#xff0c;悦数图数据库最新版本&#xff08;v3.5.0&#xff09;正式发布&#xff0c;作为国内首个能够容纳千亿点、万亿边并保持毫秒级查询延时的企业级原生分布式图数据库&#xff0c;悦数图数据库 3.5.0 版本进一步强化了数据库内核的查询性能和稳定性&#xff0c;同时…