Rémi Doolaeghe
Rémi Doolaeghe

Reputation: 2322

JUnit4 : Test a shutdown hook is called

I have a method which adds a shutdown hook. I need to test (via JUnit) that the code executed in the hook is called :

public void myMethod(){
    Runtime.getRuntime().addShutdownHook(new Thread() {

        @Override
        public void run() {
            ... code to test ...
        }
    });
}

How can I simulate a shutdown in my unit test ?

Upvotes: 15

Views: 8746

Answers (3)

Danon
Danon

Reputation: 2973

You should try and spawn that process in your test, and verify its output somehow, confirming that the shutdown hook executed.

It would be nice to simulate it in test, but I don't think that's possible.

Remember that writing tests that spawn the process would actually be the best for a lot of usages, except maybe speed - that's why we write tests that work right from within the code itself.

Upvotes: 0

khituras
khituras

Reputation: 1091

In addition to Duncans answer I'd like to point out the Runtime.getRuntime().removeShutdownHook(Thread) method. Its boolean return value indicates if the respective thread was a registered hook previously.

Thus, one can test if the hook' run() method performs correctly as one part of a test. As a second part one can call Runtime.getRuntime().removeShutdownHook(Thread)` and assert that the thread was actually registered as a hook.

Together, the two tests assure the overall functioning of the shutdown hook.

Upvotes: 0

Duncan Jones
Duncan Jones

Reputation: 69339

I don't think you'll be able to test that. Instead, just test that your code behaves correctly when invoked (by unit testing it separately). Then, trust that Java will invoke your code at the right time.

I.e. extract your code into a separate class that extends Thread and test the behaviour by executing run() in a unit test.

Upvotes: 11

Related Questions