net.masterthought.cucumber.json.Hook Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of cucumber-reporting Show documentation
Show all versions of cucumber-reporting Show documentation
Provides pretty html reports for Cucumber (Behaviour-Driven Development). It works by generating html from the
cucumber json report formatter. So can be used anywhere a json report is generated. Current use is in the
cucumber jenkins plugin and a maven mojo to generate the same report from mvn command line when running locally.
package net.masterthought.cucumber.json;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import org.apache.commons.lang.StringUtils;
import net.masterthought.cucumber.json.deserializers.OutputsDeserializer;
import net.masterthought.cucumber.json.support.Resultsable;
public class Hook implements Resultsable {
// Start: attributes from JSON file report
private final Result result = null;
private final Match match = null;
@JsonDeserialize(using = OutputsDeserializer.class)
@JsonProperty("output")
private final Output[] outputs = new Output[0];
// foe Ruby reports
private final Embedding[] embeddings = new Embedding[0];
// End: attributes from JSON file report
@Override
public Result getResult() {
return result;
}
@Override
public Match getMatch() {
return match;
}
@Override
public Output[] getOutputs() {
return outputs;
}
public Embedding[] getEmbeddings() {
return embeddings;
}
/**
* Checks if the hook has content meaning as it has at least attachment or result with error message.
*
* @return true
if the hook has content otherwise false
*/
public boolean hasContent() {
if (embeddings.length > 0) {
// assuming that if the embedding exists then it is not empty
return true;
}
if (StringUtils.isNotBlank(result.getErrorMessage())) {
return true;
}
// TODO: hook with 'output' should be treated as empty or not?
return false;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy