源码网_python源码从哪下载

源码网_python源码从哪下载源码目录结构我们首先来看下models.py的代码结构我们可以看到这个模块中定义了12个属性和22个模型类,我们依次来看属性源码分析importosfromenumimportEnu

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

源码目录结构

我们首先来看下models.py的代码结构
源码网_python源码从哪下载
我们可以看到这个模块中定义了12个属性和22个模型类,我们依次来看
 

属性源码分析

import os
from enum import Enum
from typing import Any
from typing import Dict, Text, Union, Callable
from typing import List

from pydantic import BaseModel, Field
from pydantic import HttpUrl

Name = Text
Url = Text
BaseUrl = Union[HttpUrl, Text]
VariablesMapping = Dict[Text, Any]
FunctionsMapping = Dict[Text, Callable]
Headers = Dict[Text, Text]
Cookies = Dict[Text, Text]
Verify = bool
Hooks = List[Union[Text, Dict[Text, Text]]]
Export = List[Text]
Validators = List[Dict]
Env = Dict[Text, Any]

一句话总结:用到了typingpydantic模块,目的是告诉读者我这些属性是什么类型的
 

模型类源码分析

这里以代码注解的方式讲解
 

MethodEnum

class MethodEnum(Text, Enum):
    """
    枚举请求方法,定义了常用的http请求方法
    """
    GET = "GET"
    POST = "POST"
    PUT = "PUT"
    DELETE = "DELETE"
    HEAD = "HEAD"
    OPTIONS = "OPTIONS"
    PATCH = "PATCH

 

TConfig

class TConfig(BaseModel):
    """
    定义配置信息,包含如下:
    1.name      (str)
    2.verify    (bool)
    3.base_url  (http/https开头的str类型)
    4.variables (dict)
    5.parameters(dict)
    6.export    (list[str])
    7.path      (str)
    8.weight    (int)
    """
    name: Name  # str类型
    verify: Verify = False  
    base_url: BaseUrl = ""
    # Text: prepare variables in debugtalk.py, ${gen_variables()}
    variables: Union[VariablesMapping, Text] = {}
    parameters: Union[VariablesMapping, Text] = {}
    # setup_hooks: Hooks = []
    # teardown_hooks: Hooks = []
    export: Export = []
    path: Text = None
    weight: int = 1

 

TRequest

class TRequest(BaseModel):
    """
    requests.Request model
    
    1.method  (枚举类型)
    2.url     (str)
    3.params  (dict)
    4.headers (dict)
    5.req_json(dict/list/str)
    6.data    (dict/str)
    7.cookie  (dict)
    8.timeout (float)
    9.allow_redirects (bool)
    10.verify (bool)
    11.upload (dict)
    """
    
    method: MethodEnum
    url: Url
    params: Dict[Text, Text] = {}
    headers: Headers = {}
    req_json: Union[Dict, List, Text] = Field(None, alias="json")
    data: Union[Text, Dict[Text, Any]] = None
    cookies: Cookies = {}
    timeout: float = 120
    allow_redirects: bool = True
    verify: Verify = False
    upload: Dict = {}  # used for upload files

 

TStep

class TStep(BaseModel):
    """
    测试步骤,里面包含了request请求

    1.name              (str)
    2.request           (TRequest)
    3.testcase          (str/Callable)
    4.variables         (dict)
    5.setup_hooks       (list(dict))
    6.teardown_hooks    (list(dict))
    7.extract           (dict)
    8.export            (list)
    9.validators        (list(dict))
    10.validate_script  (list[str])
    """
    name: Name
    request: Union[TRequest, None] = None
    testcase: Union[Text, Callable, None] = None
    variables: VariablesMapping = {}
    setup_hooks: Hooks = []
    teardown_hooks: Hooks = []
    # used to extract request's response field
    extract: VariablesMapping = {}
    # used to export session variables from referenced testcase
    export: Export = []
    validators: Validators = Field([], alias="validate")
    validate_script: List[Text] = []

 

TestCase

class TestCase(BaseModel):
    """
    测试用例,包含了测试步骤和配置信息
    """
    config: TConfig
    teststeps: List[TStep]

 

ProjectMeta

class ProjectMeta(BaseModel):
    """
    项目结构
    1.debugtalk_py   (str)                   debugtakl文件内容
    2.debugtalk_path (str)                   debugtalk文件路径
    3.dot_env_path   (str)                   env文件路径
    4.functions      (dict(Callable/str))    在debugtalk中定义的函数
    5.env            (dict)                  环境
    6.RootDir        (str)                   根路径(绝对路径),debugtalk位于的路径
    """
    debugtalk_py: Text = ""  # debugtalk.py file content
    debugtalk_path: Text = ""  # debugtalk.py file path
    dot_env_path: Text = ""  # .env file path
    functions: FunctionsMapping = {}  # functions defined in debugtalk.py
    env: Env = {}
    RootDir: Text = os.getcwd()  # project root directory (ensure absolute), the path debugtalk.py located

 

TestsMapping

class TestsMapping(BaseModel):
    """
    测试映射
    1.project_meta
    2.testcases 测试用例集,list下有多个用例
    """
    project_meta: ProjectMeta
    testcases: List[TestCase]

 

TestCaseTime

class TestCaseTime(BaseModel):
    """
    测试用例时间

    1.start_at:开始时间默认为0
    2.start_at_iso_format:以iso格式启动
    3.duration:持续时间
    """
    start_at: float = 0
    start_at_iso_format: Text = ""
    duration: float = 0

 

TestCaseInOut

class TestCaseInOut(BaseModel):
    """
    测试用例的输入输出:

    config_vars:配置变量
    export_vars:导出变量
    """
    config_vars: VariablesMapping = {}
    export_vars: Dict = {}

 

RequestStat

class RequestStat(BaseModel):
    """
    请求指标:

    content_size:内容大小
    response_time_ms:响应时间(ms)
    elapsed_ms:逝去的时间(ms)
    """
    content_size: float = 0
    response_time_ms: float = 0
    elapsed_ms: float = 0

 

AddressData

class AddressData(BaseModel):
    """
    客户端与服务器地址数据

    client_ip:客户端ip地址
    client_port:客户端端口号
    server_ip:服务器ip地址
    server_port:服务器端口号
    """
    client_ip: Text = "N/A"
    client_port: int = 0
    server_ip: Text = "N/A"
    server_port: int = 0

 

RequestData

class RequestData(BaseModel):
    """
    请求数据

    method:请求方法,默认为GET
    url:url地址
    headers:请求头
    cookies:cookie信息
    body:请求体
    """
    method: MethodEnum = MethodEnum.GET
    url: Url
    headers: Headers = {}
    cookies: Cookies = {}
    body: Union[Text, bytes, List, Dict, None] = {}

 

ResponseData

class ResponseData(BaseModel):
    """
    响应数据

    status_code:状态码
    headers:响应头
    cookies:cookie信息
    encoding:编码格式
    content_type:内容类型
    body:响应体
    """
    status_code: int
    headers: Dict
    cookies: Cookies
    encoding: Union[Text, None] = None
    content_type: Text
    body: Union[Text, bytes, List, Dict]

 

ReqRespData

class ReqRespData(BaseModel):
    """
    请求响应数据
    request:RequestData
    response:ResponseData
    """
    request: RequestData
    response: ResponseData

 

SessionData

class SessionData(BaseModel):
    """
    request session data, including request, response, validators and stat data
    """

    success: bool = False
    # in most cases, req_resps only contains one request & response
    # while when 30X redirect occurs, req_resps will contain multiple request & response
    req_resps: List[ReqRespData] = []
    stat: RequestStat = RequestStat()
    address: AddressData = AddressData()
    validators: Dict = {}

 

StepData

class StepData(BaseModel):
    """
    teststep data, each step maybe corresponding to one request or one testcase
    测试步骤数据,每个步骤可能对应一个请求或一个测试用例
    """

    success: bool = False
    name: Text = ""  # teststep name
    data: Union[SessionData, List['StepData']] = None
    export_vars: VariablesMapping = {}

 

TestCaseSummary

class TestCaseSummary(BaseModel):
    """
    测试用例结果

    name:测试用例名字
    success:测试用例成功的状态
    case_id:测试用例的id
    time:测试用例的时间
    in_out:测试用例的导入导出数据
    log:测试用例的日志
    step_datas:测试步骤的数据
    """
    name: Text
    success: bool
    case_id: Text
    time: TestCaseTime
    in_out: TestCaseInOut = {}
    log: Text = ""
    step_datas: List[StepData] = []

 

PlatformInfo

class PlatformInfo(BaseModel):
    """
    平台信息

    httprunner_version:httprunner版本号
    python_version:python版本
    platform:平台
    """
    httprunner_version: Text
    python_version: Text
    platform: Text

 

TestCaseRef

class TestCaseRef(BaseModel):
    """
    包含testcase
    """
    name: Text
    base_url: Text = ""
    testcase: Text
    variables: VariablesMapping = {}

 

TestSuite

class TestSuite(BaseModel):
    """
    测试套件
    TestSuite包含TestCaseRef
    TestCaseRef包含testcase
    """
    config: TConfig
    testcases: List[TestCaseRef]

 

Stat

class Stat(BaseModel):
    """
    统计信息

    total:总数
    success:成功的用例数
    fail:失败的用例数
    """
    total: int = 0
    success: int = 0
    fail: int = 0

 

TestSuiteSummary

class TestSuiteSummary(BaseModel):
    """
    测试套件结果

    success:成功的状态
    stat:统计信息
    time:测试用例花费的时间
    platform:平台信息
    testcases:测试用例集
    """
    success: bool = False
    stat: Stat = Stat()
    time: TestCaseTime = TestCaseTime()
    platform: PlatformInfo
    testcases: List[TestCaseSummary]
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/165356.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • idea maven设置本地仓库_maven更新本地仓库

    idea maven设置本地仓库_maven更新本地仓库1.file->settings2.在(1)选择Maven,在(2)加入本地Maven位置,在(3)加入到本地settings.xml下,在(4)下添加本地仓库,默认在c盘,更改本地仓库请移步3.完毕

    2022年10月3日
    1
  • navicat激活码最新(最新序列号破解)

    navicat激活码最新(最新序列号破解),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    88
  • matlab创建控件失败win7,Win7系统无法安装ActiveX控件的解决方法

    matlab创建控件失败win7,Win7系统无法安装ActiveX控件的解决方法Win7系统无法安装ActiveX控件怎么办?ActiveX控件是网站常用的一款网页辅助工具,有时候我们可能需要安装它,但是却发现浏览器阻止了它安装,那么当你遇到这种情况该怎么办呢?下面小编就给大家带来Win7系统无法安装ActiveX控件的解决方法,一起来看看吧!以下从多种角度出发分析,并非仅仅针对截图所示及以上提示。方法/步骤:1、首先建议将相应网站加入可信站点。2、其次建议选中可信站点。自定…

    2022年5月14日
    52
  • 锁屏时钟APP_linux时钟同步服务器设置

    锁屏时钟APP_linux时钟同步服务器设置桌面锁屏时钟里的桌面美化功能非常多,并且也都很实用,不仅可以帮助用户把手机桌面设置的更加简洁,查找东西变得更方便,而且用户还能够使用自定义设置的方式来将自己手机桌面的内容,进行不同的展示,桌面锁屏时钟app就算在锁屏的状态下也能够显示当前的时间,非常便捷。桌面锁屏时钟优势1.一款极简实用时钟,适合每一个喜欢简约的你。2.主界面是自带时间、日期、天气温度的LED电子数字时钟。3.经典的动态翻页效果,…

    2022年9月29日
    1
  • js中join方法

    js中join方法js中的join方法join方法用于把数组中的所有元素放入一个字符串。元素是通过指定的分隔符进行分隔的。大白话:join方法可以用符不同的分隔符来构建这个字串。join方法值接受一个参数,即用作分隔符的字符串,然后返回所有数组项的字符串。vararr=["red","yellow","blue"];vararray=[];下面开始调用join方法1a…

    2022年4月29日
    81
  • java锁升级过程

    java锁升级过程java中对象锁有4种状态:(级别从低到高)1.无锁状态2.偏向锁状态3.轻量级锁状态4.重量级锁状态对象头分两部分信息,第一部分用于存储哈希码、GC分代年龄等,这部分数据被称为”MarkWord”。在32位的HotSpot虚拟机中对象未被锁定的状态下,MarkWord的32bit空间中的25bit用于存储对象哈希码,4bit用于存储对象分代年龄,2bit用于存储锁标志位,1bit固…

    2022年7月18日
    14

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号