網站首頁 編程語言 正文
代碼為例進行說明
實踐環境
Python 3.6.5
pluggy 0.13.0
例1 注冊類函數為插件函數
#!/usr/bin/env python # -*- coding:utf-8 -*- import pluggy hookspec = pluggy.HookspecMarker("myproject") # hook 標簽 用于標記hook hookimpl = pluggy.HookimplMarker("myproject") # hook 實現標簽 用于標記hook的一個或多個實現 class MySpec(object): """hook 集合""" @hookspec def myhook(self, arg1, arg2): pass @hookspec def my_hook_func1(self, arg1, arg2): pass @hookspec def my_hook_func2(self, arg1, arg2): pass # 插件類 class Plugin_1(object): """hook實現類1""" @hookimpl def myhook(self, arg1, arg2): print("Plugin_1.myhook called") return arg1 + arg2 @hookimpl def my_hook_func2(self, arg1, arg2): print("Plugin_1.my_hook_func2 called, args:", arg1, arg2) def my_hook_func3(self, arg1, arg2): print("Plugin_1.my_hook_func3 called, args:", arg1, arg2) class Plugin_2(object): """hook實現類2""" @hookimpl def myhook(self, arg1, arg2): print("Plugin_2.myhook called") return arg1 - arg2 @hookimpl def my_hook_func2(self, arg1, arg2): print("Plugin_2.my_hook_func2, args:", arg1, arg2) # 初始化 PluginManager pm = pluggy.PluginManager("myproject") # 登記hook集合(hook函數聲明) pm.add_hookspecs(MySpec) # 注冊插件(hook函數實現) pm.register(Plugin_1()) pm.register(Plugin_2()) # 調用自定義hook results = pm.hook.myhook(arg1=1, arg2=2) # 調用兩個插件類中的同名hook函數 # 后注冊的插件中的函數會先被調用 print(results) # 輸出 [-1, 3] results = pm.hook.my_hook_func1(arg1="name", arg2="shouke") print(results) pm.hook.my_hook_func2(arg1="addr", arg2="sz")
運行結果
Plugin_2.myhook called
Plugin_1.myhook called
[-1, 3]
[]
Plugin_2.my_hook_func2, args: addr sz
Plugin_1.my_hook_func2 called, args: addr sz
例2 注冊模塊函數為插件函數
myhookspec.py
, myhookimpl.py
, other.py
, example.py
位于同一包目錄下
myhookspec.py
import pluggy hookspec = pluggy.HookspecMarker("myproject") # hook 標簽 用于標記hook hookimpl = pluggy.HookimplMarker("myproject") # hook 實現標簽 用于標記hook的一個或多個實現 @hookspec def global_hook_func1(arg1, arg2): pass
myhookimpl.py
import pluggy from myhookspec import hookimpl @hookimpl def global_hook_func1(arg1, arg2): print("global_hook_func1 in myhookimpl.py, args:", arg1, arg2) return "myhookimpl.py"
other.py
from myhookspec import hookimpl @hookimpl def global_hook_func1(arg1, arg2): print("global_hook_func1 in other.py, args:", arg1, arg2) return "other.py"
example.py
#!/usr/bin/env python # -*- coding:utf-8 -*- import sys import pluggy import myhookspec import myhookimpl import other # 初始化 PluginManager pm = pluggy.PluginManager("myproject") # 登記hook集合 pm.add_hookspecs(myhookspec) # 登記hook的實現 pm.register(myhookimpl) # 插件也可以是模塊 pm.register(other) print(pm.hook.global_hook_func1(arg1="name", arg2="shouke"))
example.py運行結果如下
global_hook_func1 in other.py, args: name shouke
global_hook_func1 in myhookimpl.py, args: name shouke
['other.py', 'myhookimpl.py']
例3:自定義插件類實現hook函數免@hookimpl裝飾器
myhookspec.py
import pluggy hookspec = pluggy.HookspecMarker("myproject") @hookspec def mytest_hook_func1(arg1, arg2): pass
other.py
def mytest_hook_func1(arg1, arg2): print("global_hook_func1 in other.py, args:", arg1, arg2) return "other.py"
example.py
#!/usr/bin/env python # -*- coding:utf-8 -*- import inspect import pluggy import myhookspec import other class PytestPluginManager(pluggy.PluginManager): """ 插件類,實現不用@HookimplMarkerInstance裝飾的函數也可以當做函數體 """ def parse_hookimpl_opts(self, plugin, name): # 規定免@hookimpl裝飾的 hooks 函數總是以 mytest_打頭,這樣以避免訪問非可讀屬性 if not name.startswith("mytest_"): return method = getattr(plugin, name) opts = super().parse_hookimpl_opts(plugin, name) # 考慮hook只能為函數(consider only actual functions for hooks) if not inspect.isroutine(method): return # 收集未被標記的,以mytest打頭的hook函數,(collect unmarked hooks as long as they have the `pytest_' prefix) if opts is None and name.startswith("mytest_"): opts = {} return opts # 初始化 PluginManager pm = PytestPluginManager("myproject") # 登記hook集合 pm.add_hookspecs(myhookspec) # 登記hook的實現 pm.register(other) pm.hook.mytest_hook_func1(arg1="addr", arg2="sz")
參考連接
https://pypi.org/project/pluggy/
原文鏈接:https://www.cnblogs.com/shouke/p/14940707.html
相關推薦
- 2022-09-30 關于react中列表渲染的局部刷新問題_React
- 2021-12-07 關于postman上傳文件執行成功而使用collection?runner執行失敗的問題_相關技巧
- 2023-04-08 c#?線程定時器?System.Threading.Timer的使用_C#教程
- 2022-03-14 Maven項目中遇見的一些問題(maven項目報錯)
- 2022-10-12 sql中exists的基本用法示例_MsSql
- 2022-05-02 Python?私有屬性與私有方法_python
- 2022-10-29 SQL?Server主鍵約束(PRIMARY?KEY)_MsSql
- 2022-07-18 Maven快照更新策略
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支