use of org.jbehave.core.embedder.EmbedderMonitor in project serenity-jbehave by serenity-bdd.
the class CompositeEmbedderMonitor method embeddableNotConfigurable.
@Override
public void embeddableNotConfigurable(final String name) {
logger.debug("embeddableNotConfigurable" + name);
final LinkedList<Exception> exceptions = new LinkedList<>();
for (final EmbedderMonitor monitor : this.monitors) {
try {
monitor.embeddableNotConfigurable(name);
} catch (final Exception suppressed) {
logger.error("exception during calling " + monitor.getClass() + "#embeddableNotConfigurable", suppressed);
exceptions.add(suppressed);
}
}
processSuppressed(exceptions);
}
use of org.jbehave.core.embedder.EmbedderMonitor in project serenity-jbehave by serenity-bdd.
the class CompositeEmbedderMonitor method storiesNotAllowed.
@Override
@Deprecated
public void storiesNotAllowed(final List<Story> notAllowed, final MetaFilter filter, final boolean verbose) {
logger.debug("storiesNotAllowed" + notAllowed + filter + verbose);
final LinkedList<Exception> exceptions = new LinkedList<>();
for (final EmbedderMonitor monitor : this.monitors) {
try {
monitor.storiesNotAllowed(notAllowed, filter, verbose);
} catch (final Exception suppressed) {
logger.error("exception during calling " + monitor.getClass() + "#storiesNotAllowed", suppressed);
exceptions.add(suppressed);
}
}
processSuppressed(exceptions);
}
use of org.jbehave.core.embedder.EmbedderMonitor in project jbehave-core by jbehave.
the class EmbedderTaskBehaviour method shouldCreateNewEmbedderWithAntMonitor.
@Test
public void shouldCreateNewEmbedderWithAntMonitor() {
// Given
Project project = mock(Project.class);
AbstractEmbedderTask task = new AbstractEmbedderTask() {
};
task.setProject(project);
// When
Embedder embedder = task.newEmbedder();
// Then
EmbedderMonitor embedderMonitor = embedder.embedderMonitor();
assertThat(embedderMonitor.toString(), equalTo("AntEmbedderMonitor"));
// and verify monitor calls are propagated to Project log
BatchFailures failures = new BatchFailures();
embedderMonitor.batchFailed(failures);
verify(project).log(task, "Failed to run batch " + failures, MSG_WARN);
String name = "name";
Throwable cause = new RuntimeException();
embedderMonitor.embeddableFailed(name, cause);
verify(project).log(task, "Failed to run embeddable " + name, cause, MSG_WARN);
List<String> classNames = asList("name1", "name2");
embedderMonitor.embeddablesSkipped(classNames);
verify(project).log(task, "Skipped embeddables " + classNames, MSG_INFO);
embedderMonitor.runningEmbeddable(name);
verify(project).log(task, "Running embeddable " + name, MSG_INFO);
List<String> storyPaths = asList("/path1", "/path2");
embedderMonitor.storiesSkipped(storyPaths);
verify(project).log(task, "Skipped stories " + storyPaths, MSG_INFO);
String path = "/path";
embedderMonitor.storyFailed(path, cause);
verify(project).log(task, "Failed to run story " + path, cause, MSG_WARN);
embedderMonitor.runningStory(path);
verify(project).log(task, "Running story " + path, MSG_INFO);
Object annotatedInstance = new Object();
Class<?> type = Object.class;
embedderMonitor.annotatedInstanceNotOfType(annotatedInstance, type);
verify(project).log(task, "Annotated instance " + annotatedInstance + " not of type " + type, MSG_WARN);
File outputDirectory = new File("/dir");
List<String> formats = asList(Format.CONSOLE.name(), Format.HTML.name());
Properties viewProperties = new Properties();
embedderMonitor.generatingReportsView(outputDirectory, formats, viewProperties);
verify(project).log(task, "Generating reports view to '" + outputDirectory + "' using formats '" + formats + "'" + " and view properties '" + viewProperties + "'", MSG_INFO);
embedderMonitor.reportsViewGenerationFailed(outputDirectory, formats, viewProperties, cause);
verify(project).log(task, "Failed to generate reports view to '" + outputDirectory + "' using formats '" + formats + "'" + " and view properties '" + viewProperties + "'", cause, MSG_WARN);
int stories = 2;
int storiesNotAllowed = 1;
int storiesPending = 1;
int scenarios = 4;
int scenariosFailed = 1;
int scenariosNotAllowed = 0;
int scenariosPending = 1;
int stepsFailed = 1;
embedderMonitor.reportsViewGenerated(new ReportsCount(stories, storiesNotAllowed, storiesPending, scenarios, scenariosFailed, scenariosNotAllowed, scenariosPending, stepsFailed));
verify(project).log(task, "Reports view generated with " + stories + " stories (of which " + storiesPending + " pending) containing " + scenarios + " scenarios (of which " + scenariosPending + " pending)", MSG_INFO);
verify(project).log(task, "Meta filters excluded " + storiesNotAllowed + " stories and " + scenariosNotAllowed + " scenarios", MSG_INFO);
embedderMonitor.reportsViewNotGenerated();
verify(project).log(task, "Reports view not generated", MSG_INFO);
}
use of org.jbehave.core.embedder.EmbedderMonitor in project serenity-jbehave by serenity-bdd.
the class CompositeEmbedderMonitor method batchFailed.
@Override
public void batchFailed(final BatchFailures failures) {
logger.debug("batchFailed" + failures);
final LinkedList<Exception> exceptions = new LinkedList<>();
for (final EmbedderMonitor monitor : this.monitors) {
try {
monitor.batchFailed(failures);
} catch (final Exception suppressed) {
logger.error("exception during calling " + monitor.getClass() + "#batchFailed", suppressed);
exceptions.add(suppressed);
}
}
processSuppressed(exceptions);
}
use of org.jbehave.core.embedder.EmbedderMonitor in project serenity-jbehave by serenity-bdd.
the class CompositeEmbedderMonitor method storyFailed.
@Override
public void storyFailed(final String path, final Throwable cause) {
logger.debug("storyFailed" + path);
final LinkedList<Exception> exceptions = new LinkedList<>();
for (final EmbedderMonitor monitor : this.monitors) {
try {
monitor.storyFailed(path, cause);
} catch (final Exception suppressed) {
logger.error("exception during calling " + monitor.getClass() + "#storyFailed", suppressed);
exceptions.add(suppressed);
}
}
processSuppressed(exceptions);
}
Aggregations