Lab 2

Write a listener, named LongestPath, that keeps track of the length of a longest path in the state space. The method getDepth of the class Search might be helpful (see JPF's API). To make it a little easier, you do not have to consider state spaces with cycles. A sample run can be found below. It shows what type of output your listener should produce.

To compile your listener, use

javac -cp /cs/fac/packages/jpf/jpf-core/build/jpf.jar:. LongestPath.java

or add /cs/fac/packages/jpf/jpf-core/build/jpf.jar as an external library to Eclipse.

Also write an app, named Path, to test your listener. Finally, write an application properties file to run JPF with your listener on the app.

To receive feedback, submit your listener, your app, and your application properties file using the submit command before Tuesday January 28:

submit 4315 lab2 LongestPath.java Path.java Path.jpf

Sample output:

JavaPathfinder core system v8.0 (rev d772dfa80ea692f916aa6718d04c4f7bfb2a746b) -
 (C) 2005-2014 United States Government. All rights reserved.


====================================================== system under test
Path.main()

====================================================== search started: 1/19/20 4:08 PM
0
1
3
5
6
4
2
Longest path has length 4

====================================================== results
no errors detected

====================================================== statistics
elapsed time:       00:00:00
states:             new=4,visited=3,backtracked=7,end=4
search:             maxDepth=4,constraints=0
choice generators:  thread=1 (signal=0,lock=1,sharedRef=0,threadApi=0,reschedule=0), data=3
heap:               new=368,released=42,maxLive=358,gcCycles=7
instructions:       3247
max memory:         57MB
loaded code:        classes=62,methods=1341

====================================================== search finished: 1/19/20 4:08 PM