测试开发技术网站
博客
设计
设计
开发
Python
测试
unittest
运维
Linux基础应用
CI/CD
CI/CD
数据库
数据库
云计算
云计算
云原生
云原生
爬虫
爬虫
数据分析
数据分析
人工智能
人工智能
登录
注册
Pluggy源码解读----pluggy源码解读基础准备
收藏本文
作者:redrose2100 类别: 日期:2022-12-09 09:04:42 阅读:1140 次 消耗积分:0 分
[TOC] ![](https://redrose2100.oss-cn-hangzhou.aliyuncs.com/img/7cd47362-951c-11ee-986a-0242ac110004.png) 解读pluggy源码,直接使用pytest环境中安装的pluggy即可,比如这里安装的pluggy版本是1.0.0,为了更好的理解源码,这里首先使用如下应用代码作为应用实例,从如下代码中可以分析出,pluggy的使用步骤主要包括一下几个步骤: 1) HookspecMarker类实例化 2) HookimplMarker类实例化 3) 定义一个接口类,接口类中的函数上使用1)中的实例化作为装饰器装饰 4) 定义一个实现类,实现类中的函数上使用2)中的实例化作为装饰器装饰 5) PluginManager类实例化 6) 对5)中的实例调用 add_hookspecs方法 7) 使用5)中的实例调用注册方法 8) 通过5)中实例的hook属性调用接口方法。 ```python import pluggy hookspec = pluggy.HookspecMarker("myproject") hookimpl = pluggy.HookimplMarker("myproject") class MySpec: @hookspec def myhook(self, arg1, arg2): pass class Plugin_1: @hookimpl() def myhook(self, arg1, arg2): print("in Plugin_1.myhook()") return arg1 + arg2 class Plugin_2: @hookimpl(hookwrapper=True) def myhook(self, arg1, arg2): print("in Plugin_2.myhook() before yield...") output=yield result=output.get_result() print("in Plugin_2.myhook() after yield...") print(result) class Plugin_3: @hookimpl def myhook(self, arg1, arg2): print("inside Plugin_3.myhook()") return arg1 - arg2+10 pm = pluggy.PluginManager("myproject") pm.add_hookspecs(MySpec) pm.register(Plugin_1()) pm.register(Plugin_2()) pm.register(Plugin_3()) results = pm.hook.myhook(arg1=1, arg2=2) print("after all run ...") print(results) ``` 为更好的定位跳转,可以在pycharm中打开上述测试代码,并配置解释器,然后即可在External Library中找到pluggy的源码了,如下图所示。 ![](https://redrose2100.oss-cn-hangzhou.aliyuncs.com/img/3b1de95c-77a0-11ed-81f3-0242ac110002.png) pluggy 源码只有以下7个文件 ```bash pluggy |--------__init__.py |--------_caller.py |--------_hooks.py |--------_manager.py |--------_result.py |--------_tracing.py |--------_version.py ``` 其中__init__.py文件代码如下,即这里通过__all__限定了pluggy外部只允许使用PluginManager、PluginValidationError、HookCallError、HookspecMarker、HookimplMarker这五个类。 ```python try: from ._version import version as __version__ except ImportError: # broken installation, we don't even try # unknown only works because we do poor mans version compare __version__ = "unknown" __all__ = [ "PluginManager", "PluginValidationError", "HookCallError", "HookspecMarker", "HookimplMarker", ] from ._manager import PluginManager, PluginValidationError from ._callers import HookCallError from ._hooks import HookspecMarker, HookimplMarker ``` 而_version.py中的内容如下,这里是设置pluggy版本号的。 ```python # coding: utf-8 # file generated by setuptools_scm # don't change, don't track in version control version = '1.0.0' version_tuple = (1, 0, 0) ``` 然后就可以在pycharm中对pluggy应用实例脚本中通过按住Ctrl键,然后鼠标点击即可跳转到对应的函数定义了,比如如下图所示 ![](https://redrose2100.oss-cn-hangzhou.aliyuncs.com/img/78da4a7e-77a0-11ed-81f3-0242ac110002.png) 然后就可以根据pluggy的应用实例代码对pluggy源码进行解析了。
始终坚持开源开放共享精神,同时感谢您的充电鼓励和支持!
版权所有,转载本站文章请注明出处:redrose2100, http://blog.redrose2100.com/article/489
上一篇:
Pluggy源码解读----Pluggy模块的应用
下一篇:
Pluggy源码解读----HookspecMarker类和HookimplMarker类源码分析
搜索
个人成就
出版书籍
《Pytest企业级应用实战》
测试开发技术全栈公众号
测试开发技术全栈公众号
DevOps技术交流微信群
加微信邀请进群
常用网站链接
开源软件洞察
云原生技术栈全景图
Python语言官方文档
Golang官方文档
Docker官方文档
Jenkins中文用户手册
Scrapy官方文档
VUE官方文档
Harbor官方文档
openQA官方文档
云原生开源社区
开源中国
Kubernetes中文文档
Markdown语法官方教程
Kubernetes中文社区
Kubersphere官方文档
BootStrap中文网站
JavaScript中文网
NumPy官方文档
Pandas官方文档
GitLink确实开源网站
数据库排名网站
编程语言排名网站
SEO综合查询网站
数学加减法练习自动生成网站
Kickstart Generator
文章分类
最新文章
最多阅读
特别推荐
×
Close
登录
注册
找回密码
登录邮箱:
登录密码:
图片验证码:
注册邮箱:
注册密码:
邮箱验证码:
发送邮件
注册邮箱:
新的密码:
邮箱验证码:
发送邮件