The Configurable Service simplifies testing client applications by allowing you to change the response that's returned without redeploying the service.
How to use the Configurable service:
-
Build and deploy the dummy/webapp module's war file at the root application context (i.e., "/").
-
Go to http://localhost:8080/config/list to view the list of configurable handlers. There are four handlers available by default when deployed:
- NCIPRequestItemService - always returns a successful response, as if the request succeeded.
- NCIPLookupUserService - always returns a successful response, with no user data.
- NCIPUnsupportedService - always returns an NCIP Problem response indicating the requested service is unsupported.
- ISO18626DynamicResponder - can be configured to respond with an "OK" status for whatever incoming message is received, or with any of the standard error types, or with an exception.
The source for these handlers is in the dummy/web/src/main/resources folder.
-
To test it:
- Load the URL http://localhost:8080/ncip/ or http://localhost:8080/iso18626/.
- You can click the button in the "Sample Documents" to load a pre-defined message, or paste one of your own into the top text box.
- Click the Submit button; this should result in a handler being called and the response message being displayed in the lower text box.
-
To use it:
- Configure your NCIP or ISO 18626 client application to send messages to this Configurable Service.
- Test, modify the handlers, repeat until done.
-
To add a handler to the deployed service, select the "Add handler" option from the main configuration menu, and paste in a Groovy class to handle incoming messages.
- The class must implement ConfigurableServiceHandler, i.e. have a canHandle and handle methods. See that class' Javadoc for details.
- You can add multiple handlers; they're added to the front of the list. When a message is received the ConfigurableService calls canHandle in this order until one of the handlers returns true, it then calls that handler.
- You can remove (and replace it with a new version) and reorder handlers, all without redploying the service.
This has been tested on Tomcat 8, although it should work on other versions with little or no adjustment.