Skip to content
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

JUnit5: failed assumptions are handled like failed test cases in JGiven reports #1625

Closed
mtthsAtrv opened this issue May 22, 2024 · 18 comments · Fixed by #1645
Closed

JUnit5: failed assumptions are handled like failed test cases in JGiven reports #1625

mtthsAtrv opened this issue May 22, 2024 · 18 comments · Fixed by #1645

Comments

@mtthsAtrv
Copy link

Hi,

if we execute JGiven tests under JUnit5 and an assumption fails, this is still treated like the test case failed because of an exception.

There was a fix that has been delivered for #1465 , but we still observe that effect, even with JGiven version 1.3.1.

After debugging this we observed that method JGivenExtension#afterTestExecution(ExtensionContext) treats all Exceptions the same way and makes no difference whether there was a exception caused by assumptions or other reasons.

grafik

Also see similar Issue #185 for Junit 4.

@l-1squared
Copy link
Collaborator

@mtthsAtrv sorry for the slow progress. I have been swamped and did not yet find the time to look deeper into the matter

@mtthsAtrv
Copy link
Author

Hi @l-1squared ,

thanks for the information :-)

Might I ask you if you already have a raw guess when a solution might be available for this issue?

Thanks a lot

@l-1squared
Copy link
Collaborator

I will devote as much time to this as possible. The first thing I want to do is write some JGiven tests so that we have an end-to-end view on failing assumptions. I now want to eradicate this issue once and for all.
Then I'll start looking for the actual error.
I've linked the branch I'm working on.

@l-1squared l-1squared linked a pull request Jun 5, 2024 that will close this issue
@mtthsAtrv
Copy link
Author

Thanks a lot for your feedback @l-1squared :-)

We are looking forward to the solution ...

@l-1squared
Copy link
Collaborator

At least I now managed to reproduce the issue :)

@mtthsAtrv
Copy link
Author

mtthsAtrv commented Jun 6, 2024

As a quick hack I have locally tried this change in class com.tngtech.jgiven.junit5.JGivenExtension, at first sight it seemed to work.

grafik

But I can not really assess if this is the correct and clean solution to the problem, maybe there are some side effects I do not see.

@l-1squared
Copy link
Collaborator

Hi,
unfortunately this is taking forever. The reason so far was that I made some harmless looking changes in my testsetup, which turned out to produce a host of weird behavior and errors.

I think I by now drilled down to the actual issue, and thankfully you have already provided me with a pointer.
One interesting thing that is not covered by this is, however, that we, for Junit5 seem to record scenarios at a different place in the test lifecycle than we do for junit4 and testng.

Because in my current setup. If I fail for the first step, I will completely omit that the scenario existed (which also doesn't sound quite right) whereas for JUnit5 I don't.

@l-1squared
Copy link
Collaborator

Ah, so I think I've figured it out.

But, it appears as if previously, failed assumpitons would have just omitted the scenarios from the report. This does not sit quite right with me so I'm trying to make them behave like failing scenarios, but they will show up with a grey marker.

@mtthsAtrv
Copy link
Author

I think that would be fine for us, but could you please - in addition to using another colour - also replace the word "failed" by "skipped" or another description that is consistent with JUnit (surefire) test reports?

Currently ist looks like

grafik

and the word "failed" seems not be quite right on failed assumptions.

@l-1squared
Copy link
Collaborator

The plan right now is to introduce a new Step and Scenario status called "ABORTED" that will show up in grey like pending scenarios but will in its behavior be more akin to "failed" scenarios.

@mtthsAtrv
Copy link
Author

mtthsAtrv commented Jun 18, 2024

Thanks a lot for your feedback - that sounds good to us.

Could you please let us know as soon as a (preview) version is available?

@mtthsAtrv
Copy link
Author

mtthsAtrv commented Jul 16, 2024

Hi l-1squared,

I wanted to ask if maybe you could already give us a prediction when the JGiven version fixing this issue might be available?

Would be great, because we could need this information for our Sprint plannings ...

Kind regards

@l-1squared
Copy link
Collaborator

HI @mtthsAtrv as much as I would like to give you a date for this. I cannot. The time I can devote to this project depends on a multitude of factors that are in combination hard to obtain estimates from.
Just this month it turned out that I could not devote any time (Thus my late response). I can promise you that I keep this the top priority for JGiven.
I'm sorry that I cannot deliver a more positive answer for you.

@mtthsAtrv
Copy link
Author

Hi @l-1squared ,

thanks a lot for this information.

So we'll sadly have to come to terms with that effect for the next time.

We'll keep watching this issue and are looking forward to a solution ...

Kind regards

@l-1squared
Copy link
Collaborator

We're finally closing in on something that is releaseable :)

@mtthsAtrv
Copy link
Author

Hi @l-1squared ,

thanks a lot for fixing this issue.

I would like to ask whether the JGiven version containing this fix and related release date is already known?

Kind regards

@l-1squared
Copy link
Collaborator

l-1squared commented Dec 6, 2024

I think I can get to it on monday.
it will be v2.0.0, because we're going to require Java 17 and there is the hypothetical, theoretical potential that you have to adapt the usage of the gradle plugin. (I do think it is an absolute edge case though)

@mtthsAtrv
Copy link
Author

Thanks for the information, we are already on Java 17 and are using maven, so I suppose we can upgrade from 1.3.1 to 2.0.0-M1 without any problems or BREAKING CHANGE potential, right?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants