Igor Kromin |   Consultant. Coder. Blogger. Tinkerer. Gamer.

In a big code porting project recently I had to move a number of unit tests from one class over to another. I didn't give it a second thought beyond that until it came to running the build. Compilation was successful, however JUnit execution failed on the tests I moved. Odd. At first I thought maybe I accidentally changed some code, but no, all the code was the same. Then I realised what the problem was.

The class that I moved these tests from was written for JUnit 4.x and used the @Test annotation. However the class that originally had these tests was written for JUnit 3.x and was extending the TestCase class and no annotations.

This meant that my perfectly legitimate test case like that looked like this...
 JUnit 4.x test case
@Test(expected = MyException.class)
public void test_myExceptionThrowsTest1() throws MyException {
/* some code here that throws MyException */
}


...would always cause my build to fail when executed inside a test case designed for use with JUnit 3.x like this...
 JUnit 3.x test case
public class MyTest extends TestCase {
...
}




The solution was of course not to mix the two approaches. In my case, I removed the 'extends TestCase' from the class and added @Test annotations to every other test case inside it. Once that was done, all my tests were passing again.

I've come across this article while debugging the issue above, it's worth a read when migrating from JUnit 3.x to 4.x - Junit 3 vs Junit 4 Comparison.

-i

Please leave your comments or feedback below!
comments powered by Disqus
Other posts you may like...
Hi! You can search my blog here ⤵
Or browse the recent top tags...

Recent Blog Posts

How to stop macOS adding shadows to window screenshots

How to run Atari Lynx games on the SNES Classic Mini

Maven dependency scopes with relation to WAR file packaging and the WEB-INF/lib directory

Hacking the Sonoff B1 WiFi LED bulb to run custom firmware

What does an idle WebLogic server run on the hour to cause a CPU spike

How to open the Sonoff B1 wifi LED bulb to access its internal circuitry

Australian release SNES mini classic unboxing and a quick play through

Troubleshooting high CPU usage for JVM threads

How to fix WebLogic high CPU usage due to a corrupted file store

Mini review of the Sonoff B1 WiFi light bulb

Recent Galleries

Atari Lynx repair - Part 5 - McWill LED screen mod installation

Atari Lynx repair - Part 4 - screen cover replacement

Atari Lynx repair - Part 2 - re-capping the motherboard

Atari Lynx repair - Part 3 - broken speaker replacement

Atari Lynx repair - Part 1 - introduction and case disassembly

Building a custom Atari Lynx game box storage shelf unit in a day

Protecting old Atari Lynx game boxes with snug fit plastic sleeves

Monument Valley 2 is released and does not disappoint

Space Food - Chocolate Ice Cream with Chocolate Chips

Legeod Star Wars AT-DP kit

Blogs and Friends

Matt Moores Blog
Georgi's FlatPress Guide
Perplexing Permutations
The Security Sleuth
Ilia Rogatchevski
Travelling Fairy

Blog Activity

Blog Activity