-
Notifications
You must be signed in to change notification settings - Fork 228
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for soft assertions #19
Comments
Hi @baev. Any plans to get it implemented? 💡 |
@scripnichenko we are not using soft assertions in our code and you are the first one who are asking for such issue during last few years. Seems like everyone uses AssertJ instead of TestNG assertions this days. But I'm understand that issue is important for people who support old projects written years ago and have no possibility for refactoring. BTW I have no idea how to fix this, some research work is required. Probably the easiest way to fix the issue add an aspect. If you have any ideas feel free to share. |
I'll be the second one. |
I'll be the third one. |
Hello there. ..because now the bahavior is : current step, which has failed soft assert in it, does not fail. The case fails when assertAll method is called. |
Yep, that's an important feature. |
I use it too. |
Can anyone explain the expected behavior and attach the minimal code to reproduce the issue? As I don't really understand what kind of SA support is required. |
I will try from my point of usage: I hope it helped :) |
@guterscooter I know how SA works. I wonder what do you expect to see in Allure while using SA? |
@sskorol To see all parts where it failed. |
@sskorol mark each failed step (and each of its ancestors) with red color, add assertion message within failed step content, add stack-trace within assertion error content, add summary error-message as test result, e.g. 'N assertions failed: <error 1> (expandable with stack-trace), <error 2> (expandable) ... |
@sskorol: I think in #529 everything is explained quite well: What is the current behavior? What is the expected behavior? Example + Expectation: On a very general level an example would be: public class MyTestClass {
private SoftAssert softAssert;
@BeforeMethod(alwaysRun = true)
public void initialize(Method method) {
softAssert = new SoftAssert();
}
@Test
public void myComplexTest_1() {
reusableTestcasePart_1();
reusableTestcasePart_2();
softAssert.assertAll();
}
@Step("...")
protected void reusableTestcasePart_1() {
// do something directly ...
// use reusable Steps:
testStep_1();
testStep_2();
}
@Step("...")
protected void reusableTestcasePart_2() {
// do something directly ...
// use reusable Steps:
testStep_3();
testStep_4();
}
@Step("...")
protected void testStep_1() {
boolean stepResult = true;// in real case check some sophisticated ui part
// soft assertion
softAssert.assertTrue(stepResult);
}
@Step("...")
protected void testStep_2() {
boolean stepResult = false;// in real case check some sophisticated ui part
// soft assertion
softAssert.assertTrue(stepResult);
}
@Step("...")
protected void testStep_3() {
boolean stepResult = false;// in real case check some sophisticated ui part
// soft assertion
softAssert.assertTrue(stepResult);
}
@Step("...")
protected void testStep_4() {
boolean stepResult = true;// in real case check some sophisticated ui part
// soft assertion
softAssert.assertTrue(stepResult);
}
} One would expect in this case the following report result:
But it is currently:
Which is misleading and hard to review for the test team which evaluates the allure report details |
@sskorol : if I can I would try to support the feature enhancement. Can you give me some advise about entry points where to start? I guess there is a kind of post-processing for the final test / step state (updating the TestResult information). |
What is the status on implementing Soft Assertion support as described above? |
Hi guys. A little workaround here I created long time ago, this could be helpful for your own ideas, probably with aspects :) public class StepUtil {
private final List<Throwable> troubles = new ArrayList<>();
private final List<String> causes = new ArrayList<>();
public void runStep(Object name, Runnable runnable) {
final String uuid = UUID.randomUUID().toString();
final List<String> localCauses = new ArrayList<>();
final List<Throwable> localExceptions = new ArrayList<>();
try {
Allure.getLifecycle().startStep(uuid, new StepResult().setName(name.toString()));
runnable.run();
} catch (Throwable e) {
localCauses.add(String.format("\r\nFailed step name: %s", name.toString()));
localExceptions.add(e);
}
if (!localExceptions.isEmpty()) {
Allure.getLifecycle().updateStep(uuid, (step) -> step.setStatus(Status.FAILED));
troubles.addAll(localExceptions);
causes.addAll(localCauses);
} else {
Allure.getLifecycle().updateStep(uuid, (step) -> step.setStatus(Status.PASSED));
}
Allure.getLifecycle().updateStep(step -> {
List<StepResult> stepResults = step.getSteps();
if (stepResults.stream().anyMatch(stepResult -> stepResult.getStatus().equals(Status.FAILED))) {
step.setStatus(Status.FAILED);
} else if (stepResults.stream().anyMatch(stepResult -> stepResult.getStatus().equals(Status.BROKEN))) {
step.setStatus(Status.BROKEN);
}
});
Allure.getLifecycle().stopStep(uuid);
}
public void checkTroubles() {
if (!troubles.isEmpty()) {
throw new AssertJMultipleFailuresError(causes.toString(), troubles);
}
} |
Maybe I'm wrong, but it looks like the |
I did this for my needs:
The bad new is you should pass to this method |
No description provided.
The text was updated successfully, but these errors were encountered: