wiki:ProblemsWithJunitTests

Version 2 (modified by anonymous, 18 years ago) (diff)

--

The LuceneSail and SesameJenaAdapter something create cases where your junit tests will not terminate. The usual cause of this is a deadlocking problem with the sesame repositories. Some tips for diagnosing and fixing this:

Diagnose:

  • To check if this is indeed the case, you can "debug" the stopping junit test ...
  • ... then pause the main thread. If it's waiting in Object.wait() and the MultiReadSingleWriteLockManager:getWriteLock is just above it in the stack trace, you know your problem.
  • The problem often happens when some code that uses an iterator throws an error, JUnit catches this, but will call the tearDown method first - and there it hangs.

Fixing:

  • In gnowsis-server there is a jar called DEBUG-openrdf-utils.jar - change your project to use this jar instead of the normal one.
  • Make sure you also check the export box for this jar in the ordering/exports tab of gnowsis-server
  • this jar adds a _locks vector to MultiRead..Manager, which keeps track of all unreleased locks, and each lock object has a stacktrace object that stores the stacktrace from when the lock was created.

All in all though - these problems suck, and debugging them sucks even more.