nl.hsac.fitnesse.fixture.slim.FreemarkerFixture Maven / Gradle / Ivy
package nl.hsac.fitnesse.fixture.slim;
/**
* Fixture to generate strings using Freemarker templates. These strings can be stored in variables so the can
* be passed as arguments to methods of other fixtures.
* This fixture can be used using Slim's dynamic decision tables or using scripts (and scenarios).
*/
public class FreemarkerFixture extends SlimFixtureWithMap {
private final String defaultTemplate;
/**
* Creates new without default template.
*/
public FreemarkerFixture() {
this(null);
}
/**
* Creates new with a default template, this is used in dynamic decision tables to prevent having to specify
* the template in the header row (any output column just gets the result of applying this templates).
* @param defaultTemplate location (below /templates/) of Freemarker template.
*/
public FreemarkerFixture(String defaultTemplate) {
this.defaultTemplate = defaultTemplate;
}
/**
* Applies template to current values.
* @param aTemplate name of template file (relative to 'testdata' directory on classpath)
* @return template result.
*/
public String applyTemplate(String aTemplate) {
String result = getEnvironment().processTemplate(aTemplate, getCurrentValues());
try {
if (aTemplate.contains(".xml")) {
result = getEnvironment().getHtmlForXml(result);
} else if (aTemplate.contains(".json")) {
result = getEnvironment().getHtmlForJson(result);
}
} catch (Exception e) {
// can not be formatted, return raw result
}
return result;
}
//// methods to support usage in dynamic decision tables
public String get(String requestedValue) {
String result;
if (defaultTemplate == null) {
result = applyTemplate(requestedValue);
} else {
result = applyTemplate(defaultTemplate);
}
return result;
}
//// end: methods to support usage in dynamic decision tables
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy