mirror of
https://github.com/github/codeql.git
synced 2025-12-22 03:36:30 +01:00
JS: Port Arrays test
This commit is contained in:
@@ -1,3 +1,5 @@
|
|||||||
|
legacyDataFlowDifference
|
||||||
|
flow
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:5:8:5:14 | obj.foo |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:5:8:5:14 | obj.foo |
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:11:10:11:15 | arr[i] |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:11:10:11:15 | arr[i] |
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:15:27:15:27 | e |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:15:27:15:27 | e |
|
||||||
|
|||||||
@@ -1,15 +1,23 @@
|
|||||||
import javascript
|
import javascript
|
||||||
|
|
||||||
class ArrayFlowConfig extends DataFlow::Configuration {
|
module TestConfig implements DataFlow::ConfigSig {
|
||||||
ArrayFlowConfig() { this = "ArrayFlowConfig" }
|
predicate isSource(DataFlow::Node source) { source.asExpr().getStringValue() = "source" }
|
||||||
|
|
||||||
override predicate isSource(DataFlow::Node source) { source.asExpr().getStringValue() = "source" }
|
predicate isSink(DataFlow::Node sink) {
|
||||||
|
|
||||||
override predicate isSink(DataFlow::Node sink) {
|
|
||||||
sink = any(DataFlow::CallNode call | call.getCalleeName() = "sink").getAnArgument()
|
sink = any(DataFlow::CallNode call | call.getCalleeName() = "sink").getAnArgument()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
from ArrayFlowConfig config, DataFlow::Node src, DataFlow::Node snk
|
module TestFlow = DataFlow::Global<TestConfig>;
|
||||||
where config.hasFlow(src, snk)
|
|
||||||
select src, snk
|
class LegacyConfig extends DataFlow::Configuration {
|
||||||
|
LegacyConfig() { this = "LegacyConfig" }
|
||||||
|
|
||||||
|
override predicate isSource(DataFlow::Node source) { TestConfig::isSource(source) }
|
||||||
|
|
||||||
|
override predicate isSink(DataFlow::Node sink) { TestConfig::isSink(sink) }
|
||||||
|
}
|
||||||
|
|
||||||
|
import testUtilities.LegacyDataFlowDiff::DataFlowDiff<TestFlow, LegacyConfig>
|
||||||
|
|
||||||
|
query predicate flow = TestFlow::flow/2;
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
legacyDataFlowDifference
|
||||||
|
flow
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:5:8:5:14 | obj.foo |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:5:8:5:14 | obj.foo |
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:11:10:11:15 | arr[i] |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:11:10:11:15 | arr[i] |
|
||||||
| arrays.js:2:16:2:23 | "source" | arrays.js:15:27:15:27 | e |
|
| arrays.js:2:16:2:23 | "source" | arrays.js:15:27:15:27 | e |
|
||||||
|
|||||||
@@ -1,15 +1,23 @@
|
|||||||
import javascript
|
import javascript
|
||||||
|
|
||||||
class ArrayTaintFlowConfig extends TaintTracking::Configuration {
|
module TestConfig implements DataFlow::ConfigSig {
|
||||||
ArrayTaintFlowConfig() { this = "ArrayTaintFlowConfig" }
|
predicate isSource(DataFlow::Node source) { source.asExpr().getStringValue() = "source" }
|
||||||
|
|
||||||
override predicate isSource(DataFlow::Node source) { source.asExpr().getStringValue() = "source" }
|
predicate isSink(DataFlow::Node sink) {
|
||||||
|
|
||||||
override predicate isSink(DataFlow::Node sink) {
|
|
||||||
sink = any(DataFlow::CallNode call | call.getCalleeName() = "sink").getAnArgument()
|
sink = any(DataFlow::CallNode call | call.getCalleeName() = "sink").getAnArgument()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
from ArrayTaintFlowConfig config, DataFlow::Node src, DataFlow::Node snk
|
module TestFlow = TaintTracking::Global<TestConfig>;
|
||||||
where config.hasFlow(src, snk)
|
|
||||||
select src, snk
|
class LegacyConfig extends TaintTracking::Configuration {
|
||||||
|
LegacyConfig() { this = "LegacyConfig" }
|
||||||
|
|
||||||
|
override predicate isSource(DataFlow::Node source) { TestConfig::isSource(source) }
|
||||||
|
|
||||||
|
override predicate isSink(DataFlow::Node sink) { TestConfig::isSink(sink) }
|
||||||
|
}
|
||||||
|
|
||||||
|
import testUtilities.LegacyDataFlowDiff::DataFlowDiff<TestFlow, LegacyConfig>
|
||||||
|
|
||||||
|
query predicate flow = TestFlow::flow/2;
|
||||||
|
|||||||
Reference in New Issue
Block a user