- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我刚刚在一个项目中发现一些测试方法没有所需的“test_”前缀来确保它们实际运行。应该可以通过一些 linting 来避免这种情况:
TestCase
断言调用。我想知道如何解决前两个问题,这基本上可以归结为一个问题:如何在我的代码库中找到对特定方法的所有调用?
Grepping 或其他文本搜索行不通,因为我需要反省结果并找到父方法等,直到我找到测试方法或没有更多调用者为止。我需要获取方法的引用,以避免匹配的方法恰好与我要查找的方法同名。
最佳答案
这里有两种可能的方法。
静态方法:
您可以使用 ast 模块解析代码库以识别所有函数调用并一致地存储调用的来源和目标。您将必须识别所有类和函数定义以跟踪每个调用的当前上下文。这里的限制是,如果调用实例方法,则没有简单的方法来识别该方法实际属于哪个类。如果您使用引用模块的变量也是如此
这里有一个 Visitor 子类,可以读取 Python 源文件并构建一个字典 {caller: callee}:
class CallMapper(ast.NodeVisitor):
def __init__(self):
self.ctx = []
self.funcs = []
self.calls = collections.defaultdict(set)
def process(self, filename):
self.ctx = [('M', os.path.basename(filename)[:-3])]
tree = ast.parse(open(filename).read(), filename)
self.visit(tree)
self.ctx.pop()
def visit_ClassDef(self, node):
print('ClassDef', node.name, node.lineno, self.ctx)
self.ctx.append(('C', node.name))
self.generic_visit(node)
self.ctx.pop()
def visit_FunctionDef(self, node):
print('FunctionDef', node.name, node.lineno, self.ctx)
self.ctx.append(('F', node.name))
self.funcs.append('.'.join([elt[1] for elt in self.ctx]))
self.generic_visit(node)
self.ctx.pop()
def visit_Call(self, node):
print('Call', vars(node.func), node.lineno, self.ctx)
try:
id = node.func.id
except AttributeError:
id = '*.' + node.func.attr
self.calls['.'.join([elt[1] for elt in self.ctx])].add(id)
self.generic_visit(node)
动态方法:
如果你真的想确定调用的是什么方法,当多个方法可以共享相同的名称时,你将不得不使用动态方法。您可以装饰类中的单个函数或所有方法,以计算它们被调用的次数,以及它们被调用的位置(可选)。然后您将开始测试并检查实际发生的情况。
这是一个函数,它将装饰一个类中的所有方法,以便所有调用的次数都将存储在字典中:
def tracemethods(cls, track):
def tracker(func, track):
def inner(*args, **kwargs):
if func.__qualname__ in track:
track[func.__qualname__] += 1
else:
track[func.__qualname__] = 1
return func(*args, *kwargs)
inner.__doc__ = func.__doc__
inner.__signature__ = inspect.signature(func)
return inner
for name, func in inspect.getmembers(cls, inspect.isfunction):
setattr(cls, name, tracker(func, track))
您可以调整该代码以浏览解释器堆栈以识别每次调用的调用者,但这并不容易,因为您获得了调用者函数的非限定名称并且必须使用文件名和行号来唯一识别来电者。
关于python - 如何使用 Python 自省(introspection)查找对方法的调用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55368638/
有没有办法自省(introspection)变量以直接找出它声明的子集?在这里,我创建了一个子集,但自省(introspection)将我指向它的基本类型: > subset Prime of Int
我正在尝试使用泛型动态创建一个基于 class 实例的类型,但是我在类自省(introspection)方面遇到了困难。 问题如下: 是否有与 Obj-C 的 self.class 等效的 Swift
首先,一些上下文:我是一名 Python 开发人员,他使用 PyGObject 编写了一个中型应用程序,利用 GObject Introspection 来访问 GSettings 等内容。我的一些
当 API 使用 Introspection 进行 HTTP token 身份验证时,如果 Introspection 服务器关闭或返回 500,它应该返回什么? 我正在编写 API 并希望遵守 Ht
调用子例程 Capture 后访问它的语法是什么? self仅适用于对象和 &?ROUTINE 指的是静态例程,而不是其一旦被调用的状态。那么首先,是否可以访问例程的 Capture从内部?如果是这样
我有一个关于 Java 方法内省(introspection)的问题,特别是关于异常的问题。假设我有以下代码: private String getCustomReportResponse(Https
给定 D 中的函数声明,是否可以在编译时内省(introspection)任何函数参数名称的字符串表示形式,以用于自动函数反射。 例如。 void foo(int a, double b, strin
在 Julia 中,有没有办法获取传递给函数的名称? x = 10 function myfunc(a) # do something here end assert(myfunc(x) == "x"
D语言有没有类似lint之类的东西,或者有没有什么框架可以快速搭建检查器? 编辑 1 回想起来,我记得一周前我看过工具 DScanner。该工具只能返回类名和一些其他内容,但它包含完整的 Lexer
是否有一些自省(introspection)方法允许可靠地获取对象实例的底层数据结构,不受任何自定义的影响? 在 Python 3 中,对象的低级实现可能会被深深地掩盖:可以自定义属性查找,甚至可以自
我正在草拟一些东西的设计(函数的机器学习),它最好需要一种函数式编程语言,还有内省(introspection),特别是能够以某种易于处理的格式检查程序自己的代码的能力,最好还有获得机器的能力生成在运
我有一个由 apollo-server 提供支持的 node.js 项目。我使用自定义@admin对查询、突变和对象字段进行权限检查的指令。对于查询和突变,该指令会引发错误,对于字段,它返回 null
我正在尝试通过 Object 对象的名称 memberName 访问其属性。 我尝试过: new PropertyDescriptor(memberName,object.getClass()).ge
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在为以下相当微不足道的问题寻找 OOP 设计建议。我想避免在不采用访问者模式的情况下使用类型自省(introspection)(例如 Java instanceof 运算符),这是典型的建议。我目
一段时间以来,我一直在尝试解决这个问题,到目前为止,每个人都告诉我这在我身边是不可能的,所以我想尝试一下。 这就是问题所在:人们使用环境变量,但没有正确地测试结果或默默地使用硬编码替代方案。 我想做的
大家好, 我目前正在开发一个 python 模块,为同事提供使用工具,我试图提供的一些功能可以返回相当多的有用信息(比如 5 个返回值),但在大多数用例中,只需要前两个。 我知道 python 非常适
我正在玩自省(introspection),想在运行时提取参数计数和参数名称。是否有可能实现这样的东西? class Greeter def self.greet(name, weekday =
假设我有一个从类方法中调用的自由函数。有没有办法让我在自由函数中反省调用堆栈并确定调用我的对象? def foo(arg1) : s = ? #Introspect call stack and
我希望有人可以帮助我解决以下问题: 我对 java 堆栈自省(introspection)的理解(这里可能有点过于简单化)是一个进程生成一个堆栈帧,然后将其添加到堆栈中。现在,当进程需要进行系统调用时
我是一名优秀的程序员,十分优秀!