Skip to content

Commit

Permalink
Rust: improve modules test case
Browse files Browse the repository at this point in the history
  • Loading branch information
aibaars committed Feb 28, 2025
1 parent ae082a2 commit e97fe89
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 11 deletions.
13 changes: 5 additions & 8 deletions rust/ql/test/extractor-tests/crate_graph/modules.expected
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,6 @@

#-----| fn length

#-----| fn write

#-----| fn as_string

#-----| fn fmt
Expand All @@ -13,15 +11,14 @@
#-----| Static

#-----| mod module
#-----| -> Const
#-----| -> Static
#-----| -> enum X
#-----| -> fn length
#-----| -> fn write
#-----| -> impl ...::Display for ...::X { ... }
#-----| -> impl AsString for ...::X { ... }
#-----| -> struct X_List
#-----| -> Static
#-----| -> trait AsString
#-----| -> Const
#-----| -> impl AsString for ...::X { ... }
#-----| -> impl ...::Display for ...::X { ... }
#-----| -> enum X

#-----| mod crate
#-----| -> mod module
Expand Down
24 changes: 21 additions & 3 deletions rust/ql/test/extractor-tests/crate_graph/modules.ql
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,30 @@

import rust

query predicate nodes(Item i) {
i.getParentNode*() = any(Crate m | m.getName() = "test" and m.getVersion() = "0.0.1").getModule()
query predicate nodes(Item i) { i instanceof RelevantNode }

class RelevantNode extends Item {
RelevantNode() {
this.getParentNode*() =
any(Crate m | m.getName() = "test" and m.getVersion() = "0.0.1").getModule()
}
}

query predicate edges(Item container, Item element) {
predicate edges(RelevantNode container, RelevantNode element) {
element = container.(Module).getItemList().getAnItem() or
element = container.(Impl).getAssocItemList().getAnAssocItem() or
element = container.(Trait).getAssocItemList().getAnAssocItem()
}

query predicate edges(RelevantNode pred, RelevantNode succ, string attr, string val) {
edges(pred, succ) and
(
attr = "semmle.label" and
val = ""
or
attr = "semmle.order" and
val =
any(int i | succ = rank[i](Item s, Location l | edges(pred, s) | s order by s.toString()))
.toString()
)
}

0 comments on commit e97fe89

Please sign in to comment.