variable defined: TEST_SYSTEM=slim

The SLIM Test System

Slim (Simple List Invocation Method) is an alternative to Fit. Rather than running all the HTML processing, comparisons, and colorizing in the System Under Test (SUT), Slim keeps all that behavior on in Fit Nesse. What executes in the SUT is a very tiny kernel that implements the Slim Protocol. This protocol is a bare bones RPC system that allows Fit Nesse to call functions in the SUT.

This strategy has a number of advantages:


Using the SLIM Test System

If you want a test page to be run under SLIM, you simply set the TEST_SYSTEM variable to "slim" instead of "fit".
!define TEST_SYSTEM {slim} 
If this variable is set on your page, (as it is on this page!) or on any parent page, then your page will be run with Slim. That's all there is to it.

The Slim Tables

The first cell of a slim table tells you what kind of table it is. Here are the table types so far:

Decision Table Supplies the inputs and outputs for decisions. This is similar to the Fit Column Fixture
Query Table Supplies the expected results of a query. This is similar to the Fit Row Fixture
Subset Query Table Supplies a subset of the expected results of a query.
Ordered query Table Supplies the expected results of a query. The rows are expected to be in order. This is similar to the Fit Row Fixture
Script Table A series of actions and checks. Similar to Do Fixture.
Table Table Whatever you want it to be!
Import Add a path to the fixture search path.
Comment A table that does nothing.
Scenario Table A table that can be called from other tables.
Library Table A table that installs fixtures available for all test pages
Define Table Type A helper table that defines the default table type for named fixtures.

Data Types.

The data in your tables is all Strings. However your fixtures don't want to be constrained to Strings. So Slim comes with several standard data type converters that will automatically convert the strings in the tables into the data types expected by your fixtures.
See: >Data Types

You can also create your own custom type converters if you like.
See: >Custom Types

Content returned from the SUT will be escaped by default, so your fixture can return a piece of output without the need to transform it to HTML compatible output. On the other hand, if you're returning HTML content (e.g. a <table>..</table>), FitNesse will try to detect that (based on a valid HTML start and end tag) and will render the HTML in-line.

Configure SLIM


The Slim test system can be configured using the following properties:

slim.port 8085 Base port for SLIM.
slim.pool.size 10 The size of the pool of ports to cycle through. By default the ports 8085 up to 8095 are used (slim.port + slim.pool.size).
slim.host localhost The host the SLIM server will be running on. This is mostly useful if you're running a remote SLIM server.
slim.flags Extra flags to provide to the SLIM server.
manually.start.test.runner.on.debug false Do not launch a SLIM server if the test is ran in debug mode.

Those properties can be either provided on the command line (e.g. -Dslim.port=9000) or in the plugins.properties file.

Extra Goodies that are consistent throughout all Slim tables and ports.

Exception Handling
Symbols in tables
Constructor arguments
Value comparisons
Graceful names

New goodies

System Under Test

Keyboard Shortcuts ?

×
  • t Test
  • e Edit page
  • a Add new page
  • p Properties
  • w Where used?
  • / Focus on search bar
  • s Open search page
  • g u Go to User Guide