com.seleniumtests.core.aspects.SoftAssert.aj Maven / Gradle / Ivy
/**
* Orignal work: Copyright 2015 www.seleniumtests.com
* Modified work: Copyright 2016 www.infotel.com
* Copyright 2017-2019 B.Hecquet
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.seleniumtests.core.aspects;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.testng.Reporter;
import com.seleniumtests.core.SeleniumTestsContextManager;
import com.seleniumtests.core.TestStepManager;
import com.seleniumtests.core.TestTasks;
import com.seleniumtests.reporter.logger.TestStep;
import com.seleniumtests.util.logging.ScenarioLogger;
@Aspect
public class SoftAssert {
private static ScenarioLogger logger = ScenarioLogger.getScenarioLogger(SoftAssert.class);
@Around("(call(public * org.testng.Assert..* (..)) " +
"|| call(public * org.hamcrest.MatcherAssert..* (..))) " +
"&& !call(public * org.testng.Assert.fail (..)) "
)
public Object interceptAssertException(ProceedingJoinPoint joinPoint) throws Throwable {
try {
return joinPoint.proceed(joinPoint.getArgs());
} catch (AssertionError e) {
return logAssertion(e);
}
}
private Object logAssertion(Throwable e) throws Throwable {
// we need a root step to log, the current one if it exists, or the previous one
TestStep currentTestStep = TestStepManager.getCurrentOrPreviousStep();
try {
if (SeleniumTestsContextManager.hasThreadContext() &&
SeleniumTestsContextManager.getThreadContext().isSoftAssertEnabled()) {
SeleniumTestsContextManager.getThreadContext().addVerificationFailures(Reporter.getCurrentTestResult(), e);
logger.error("!!!FAILURE ALERT!!! - Assertion Failure: " + e.getMessage());
TestTasks.capturePageSnapshot();
return null;
} else {
logger.error("Assertion Failure: " + e.getMessage());
throw e;
}
} finally {
if (currentTestStep != null) {
// assertion should be clearly seen in report
currentTestStep.setFailed(true);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy