mirror of
https://github.com/github/codeql.git
synced 2025-12-19 18:33:16 +01:00
Notice the strange thing with treating `mypkg.foo(42)` as a ClassCall, but completely ignoring `mypkg.subpkg.bar(43)` -- due to having the two `ClassValue`s: - `Missing module attribute mypkg.foo` - `Missing module attribute mypkg.subpkg` But not `Missing module attribute mypkg.subpkg` with the current import structure.
35 lines
1017 B
Plaintext
35 lines
1017 B
Plaintext
import python
|
|
import semmle.python.dataflow.new.DataFlow
|
|
import semmle.python.dataflow.new.internal.DataFlowPrivate
|
|
import TestUtilities.InlineExpectationsTest
|
|
private import semmle.python.dataflow.new.internal.PrintNode
|
|
|
|
class DataFlowCallTest extends InlineExpectationsTest {
|
|
DataFlowCallTest() { this = "DataFlowCallTest" }
|
|
|
|
override string getARelevantTag() {
|
|
result in ["call", "qlclass"]
|
|
or
|
|
result = "arg_" + [0 .. 10]
|
|
}
|
|
|
|
override predicate hasActualResult(Location location, string element, string tag, string value) {
|
|
exists(location.getFile().getRelativePath()) and
|
|
exists(DataFlowCall call |
|
|
location = call.getLocation() and
|
|
element = call.toString()
|
|
|
|
|
value = prettyExpr(call.getNode().getNode()) and
|
|
tag = "call"
|
|
or
|
|
value = call.getAQlClass() and
|
|
tag = "qlclass"
|
|
or
|
|
exists(int n, DataFlow::Node arg | arg = call.getArg(n) |
|
|
value = prettyNodeForInlineTest(arg) and
|
|
tag = "arg_" + n
|
|
)
|
|
)
|
|
}
|
|
}
|