diff --git a/core/citrus-base/src/main/java/org/citrusframework/DefaultTestCase.java b/core/citrus-base/src/main/java/org/citrusframework/DefaultTestCase.java index 8d2f69e8b0..b5b062920b 100644 --- a/core/citrus-base/src/main/java/org/citrusframework/DefaultTestCase.java +++ b/core/citrus-base/src/main/java/org/citrusframework/DefaultTestCase.java @@ -120,7 +120,7 @@ public void doExecute(final TestContext context) { } catch (final TestCaseFailedException e) { gracefullyStopTimer(); throw e; - } catch (final Exception | AssertionError e) { + } catch (final Exception | Error e) { testResult = getTestResultInstanceProvider(context).createFailed(this, e); throw new TestCaseFailedException(e); } @@ -143,7 +143,7 @@ public void start(final TestContext context) { debugVariables("Test", context); beforeTest(context); - } catch (final Exception | AssertionError e) { + } catch (final Exception | Error e) { testResult = getTestResultInstanceProvider(context).createFailed(this, e); throw new TestCaseFailedException(e); } @@ -171,7 +171,7 @@ public void afterTest(final TestContext context) { if (sequenceAfterTest.shouldExecute(getName(), packageName, groups)) { sequenceAfterTest.execute(context); } - } catch (final Exception | AssertionError e) { + } catch (final Exception | Error e) { logger.warn("After test failed with errors", e); } } @@ -194,7 +194,7 @@ public void executeAction(final TestAction action, final TestContext context) { } else { context.getTestActionListeners().onTestActionSkipped(this, action); } - } catch (final Exception | AssertionError e) { + } catch (final Exception | Error e) { testResult = getTestResultInstanceProvider(context).createFailed(this, e); throw new TestCaseFailedException(e); } finally { @@ -238,8 +238,11 @@ public void finish(final TestContext context) { throw new TestCaseFailedException(contextException); } } catch (final TestCaseFailedException e) { + if (isNull(testResult) || testResult.isSuccess()) { + testResult = getTestResultInstanceProvider(context).createFailed(this, e.getCause()); + } throw e; - } catch (final Exception | AssertionError e) { + } catch (final Exception | Error e) { testResult = getTestResultInstanceProvider(context).createFailed(this, e); throw new TestCaseFailedException(e); } finally { diff --git a/core/citrus-base/src/main/java/org/citrusframework/common/DefaultTestLoader.java b/core/citrus-base/src/main/java/org/citrusframework/common/DefaultTestLoader.java index fab4e795e2..248e836dd6 100644 --- a/core/citrus-base/src/main/java/org/citrusframework/common/DefaultTestLoader.java +++ b/core/citrus-base/src/main/java/org/citrusframework/common/DefaultTestLoader.java @@ -16,6 +16,10 @@ package org.citrusframework.common; +import java.util.ArrayList; +import java.util.List; +import java.util.function.Consumer; + import org.citrusframework.Citrus; import org.citrusframework.CitrusContext; import org.citrusframework.DefaultTestCase; @@ -28,10 +32,6 @@ import org.citrusframework.exceptions.CitrusRuntimeException; import org.citrusframework.exceptions.TestCaseFailedException; -import java.util.ArrayList; -import java.util.List; -import java.util.function.Consumer; - import static org.citrusframework.TestResult.failed; /** @@ -91,9 +91,17 @@ public final void load() { try { doLoad(); } catch (TestCaseFailedException e) { + if (testCase == null) { + testCase = runner.getTestCase(); + } + + if (testCase.getTestResult() == null || testCase.getTestResult().isSuccess()) { + testCase.setTestResult(failed(testCase.getName(), testCase.getTestClass().getName(), e)); + } + // This kind of exception indicates that the error has already been handled. Just throw and end test run. throw e; - } catch (Exception | AssertionError e) { + } catch (Exception | Error e) { if (testCase == null) { testCase = runner.getTestCase(); } diff --git a/core/citrus-base/src/main/java/org/citrusframework/container/Parallel.java b/core/citrus-base/src/main/java/org/citrusframework/container/Parallel.java index 01f2799cbe..3a5f7ed305 100644 --- a/core/citrus-base/src/main/java/org/citrusframework/container/Parallel.java +++ b/core/citrus-base/src/main/java/org/citrusframework/container/Parallel.java @@ -107,7 +107,7 @@ public void run() { } catch (CitrusRuntimeException e) { logger.error("Parallel test action raised error", e); exceptionHandler.accept(e); - } catch (Exception | AssertionError e) { + } catch (Exception | Error e) { logger.error("Parallel test action raised error", e); exceptionHandler.accept(new CitrusRuntimeException(e)); } diff --git a/core/citrus-spring/src/main/java/org/citrusframework/common/SpringXmlTestLoader.java b/core/citrus-spring/src/main/java/org/citrusframework/common/SpringXmlTestLoader.java index 74119db4b0..83ad7adf3d 100644 --- a/core/citrus-spring/src/main/java/org/citrusframework/common/SpringXmlTestLoader.java +++ b/core/citrus-spring/src/main/java/org/citrusframework/common/SpringXmlTestLoader.java @@ -57,8 +57,7 @@ protected void doLoad() { citrus.run(testCase, context); handler.forEach(handler -> handler.accept(testCase)); } catch (NoSuchBeanDefinitionException e) { - throw citrusContext.getTestContextFactory().getObject() - .handleError(testName, packageName, "Failed to load Spring XML test with name '" + testName + "'", e); + throw context.handleError(testName, packageName, "Failed to load Spring XML test with name '" + testName + "'", e); } } diff --git a/runtime/citrus-groovy/src/main/java/org/citrusframework/groovy/GroovyTestLoader.java b/runtime/citrus-groovy/src/main/java/org/citrusframework/groovy/GroovyTestLoader.java index 7c521cd8af..aced416b46 100644 --- a/runtime/citrus-groovy/src/main/java/org/citrusframework/groovy/GroovyTestLoader.java +++ b/runtime/citrus-groovy/src/main/java/org/citrusframework/groovy/GroovyTestLoader.java @@ -55,8 +55,7 @@ protected void doLoad() { handler.forEach(it -> it.accept(testCase)); } catch (IOException e) { - throw citrusContext.getTestContextFactory().getObject() - .handleError(testName, packageName, "Failed to load Groovy test source '" + testName + "'", e); + throw context.handleError(testName, packageName, "Failed to load Groovy test source '" + testName + "'", e); } } diff --git a/runtime/citrus-xml/src/main/java/org/citrusframework/xml/XmlTestLoader.java b/runtime/citrus-xml/src/main/java/org/citrusframework/xml/XmlTestLoader.java index fe7c71fa6a..e8d80f0522 100644 --- a/runtime/citrus-xml/src/main/java/org/citrusframework/xml/XmlTestLoader.java +++ b/runtime/citrus-xml/src/main/java/org/citrusframework/xml/XmlTestLoader.java @@ -90,8 +90,7 @@ public void doLoad() { citrus.run(testCase, context); handler.forEach(handler -> handler.accept(testCase)); } catch (JAXBException | IOException e) { - throw citrusContext.getTestContextFactory().getObject() - .handleError(testName, packageName, "Failed to load XML test with name '" + testName + "'", e); + throw context.handleError(testName, packageName, "Failed to load XML test with name '" + testName + "'", e); } } diff --git a/runtime/citrus-yaml/src/main/java/org/citrusframework/yaml/YamlTestLoader.java b/runtime/citrus-yaml/src/main/java/org/citrusframework/yaml/YamlTestLoader.java index 6b5297e469..4c2ac070c5 100644 --- a/runtime/citrus-yaml/src/main/java/org/citrusframework/yaml/YamlTestLoader.java +++ b/runtime/citrus-yaml/src/main/java/org/citrusframework/yaml/YamlTestLoader.java @@ -123,8 +123,7 @@ public void doLoad() { citrus.run(testCase, context); handler.forEach(handler -> handler.accept(testCase)); } catch (IOException e) { - throw citrusContext.getTestContextFactory().getObject() - .handleError(testName, packageName, "Failed to load YAML test with name '" + testName + "'", e); + throw context.handleError(testName, packageName, "Failed to load YAML test with name '" + testName + "'", e); } }