FitNesse
.
DebuggingFitNesseTables
Edit Page:
So, you'd like to debug your fixtures? Remember that fixtures are run in a ''completely'' different process from !-FitNesse-! It's not easy to set a breakpoint in a fixture and then hope to trap there when the fixture is going to be run in a different process. But don't worry too much. You can still use print statements. Anything you print to standard ''error'' will be placed in the error log page for your test run. This is true whether the test fails or succeeds. The error log page is created whenever you run a test. The name of the error log page is !-.ErrorLogs.-!''yourPageName''. So, for example, if you just pushed the test button on a page named !-TestTheDravnitzTarget-! then the error log page will be at !-.ErrorLogs.TestTheDravnitzTarget-! Debugging your fixtures should be something you rarely need to do. After all, the code in your fixtures shouldn't be doing very much. At most it should be simply wiring and piping to get the data from your tables into your application and back. An error log page looks like this: ----- |'''Date: '''|!-6:49:19 PM (CST) on Thursday, February 26, 2004-!| |'''Command: '''|!-java -cp fitnesse.jar;classes fit.FitServer-!| |'''Exit code: '''|!-0-!| |'''Time elapsed: '''|!-0.28 seconds-!| ----'''Standard Error:''' {{{ This is an error }}} ----- Notice that you can see the command that was used to run your test. This is very useful if you are concerned that your fixtures aren't running with the right classpaths. You can see the classpaths sent to the test in the ''-cp'' argument of the ''java'' command.
Hints:
Use alt+s (Windows) or control+s (Mac OS X) to save your changes. Or, tab from the text area to the "Save" button!
Grab the lower-right corner of the text area to increase its size (works with some browsers).