Difference between junit-vintage-engine and junit-jupiter-engine?
Answer : 1. Based on reading i found some difference like,
junit-vintage-engine :
- Used in Junit-4 Testing.
- Used to call core classes and annotations.
- 'Assert' which provide assertion methods for performing test.
- 'Assume' used to place assumptions.
- Use annotation like, @Ignore, @Before, etc...
junit-jupiter-engine :
- Used in Junit-5 Testing
- Provide some API which helpful to write test cases.
- 'Assertions' provides utility methods of assertion condition for testing.
- 'Assumptions' - utility method provide condition based on assumption.
- Change the bit of annotation name like, @Disable, @BeforeAll, @BeforeEach, etc...
Answer : 2. I'm also amazed they are still providing older vintage library probably there is some reason which i don't know till now but based on current usage we'll see that in next update.
Have a nice day!!! :)
First question is also related with the version of JDK. To be able to use jupiter engine, you must have Java 8 or higher. For second question; since the vintage engine is for JUnit4 and JUnit4 is greater than 10 years old, it is not recommended to be used. As far as I know, it has not been updated along this time although java has been evolved so much. I think that is why spring initializers enforce the use of junit-jupiter-engine.
junit-vintage-engine
is used for running JUnit 4 tests; junit-jupiter-engine
for JUnit 5 tests.
Presumably since you'll be writing only JUnit 5 tests for a new Spring Boot project, the vintage engine won't be needed, hence the default dependency exclusion in the POM.
Reference:
https://junit.org/junit5/docs/current/user-guide