Skip to content
Java Ranger is a path-merging extension of Symbolic PathFinder
Java Other
  1. Java 99.3%
  2. Other 0.7%
Branch: default
Clone or download
Pull request Compare This branch is 99 commits ahead, 5 commits behind SymbolicPathFinder:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.externalToolBuilders
bin
doc
eclipse
launch
lib
nbproject
prettyprint
runConfigurations
src
tools
.classpath
.gitignore
.project
LICENSE-2.0.txt
README.md
Readme
ReadmeMultipleDecisionProcedures
build.xml
dreal.readme
jpf.load
jpf.properties
notes

README.md

Java Ranger

Java Ranger is a path-merging extension of Symbolic PathFinder (SPF). In this tool, we've extended the veritesting technique by Avgerinos et al. (see paper here) for symbolic execution of Java bytecode.

The setup of Java Ranger is very similar to the setup used by SPF. The only difference in setup is, since Java Ranger is simply an extension of SPF, the Java Ranger directory can be specified as a valid jpf-symbc extension of JPF. The example configuration required by Java Ranger is exactly the same as the configuration that is required by SPF with the following additions.

veritestingMode = <1-5>

veritestingMode specifies the path-merging features to be enabled with each higher number adding a new feature to the set of features enabled by the previous number. Setting veritestingMode to 1 runs vanilla SPF. Setting it to 2 enables path-merging for multi-path regions with no method calls and a single exit point. Setting it to 3 adds path-merging for multi-path regions that make method calls where the method can be summarized by Java Ranger. Setting it to 4 adds path-merging for multi-path regions with more than one exit point caused due to exceptional behavior and unsummarized method calls. Setting it to 5 adds path-merging for summarizing return instructions in multi-path regions by treating them as an additional exit point.

performanceMode = <true or false>

Setting performanceMode to true causes Java Ranger to minimize the number of solver calls to check the feasibility of the path condition when summarizing a multi-path region with multiple exit points.

TARGET_CLASSPATH_WALA=<classpath of target code>

Java Ranger needs this variable to be set up as environment variable. It is not part of the .jpf configuration file. This environment variable tells Java Ranger where it should be expecting to find code that needs to be statically summarized

People

The following people have contributed to Java Ranger

  1. Soha Hussein
  2. Vaibhav Sharma
  3. Michael Whalen
  4. Stephen McCamant
  5. Willem Visser
You can’t perform that action at this time.