In this blog post, I’m gonna explain what is the main difference between in these methods. First of all why do we use this methods. This method will be useful when we test our methods performance or we want to know how much time takes our method to complete.
First we have to give time our test method , after that these tests execute operations in the test. If this operations takes longer time than specified and then this test will be fail.
Okay now we know what these methods are, why we use them in our testing methods. Then we must know the difference.
Let me explain briefly. assertTimeout method counts the time we give, if our test method takes longer than specified, this test will fail after all operations are completed. However, if the assertTimeoutPreemptively method takes longer than specified, this method will fail immediately. And it won’t wait for all the processes to be completed, we will test this in the project in the next step.
First open your favorite IDE. I open Intellij Idea because this IDE is very popular among Java developers. Of course you can use favorite IDE such as Eclipse, Netbeans which one you prefer.
Now create a new Maven project and add these 2 dependencies to your pom.xml file.
<dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-api</artifactId> <version>5.3.1</version> <scope>test</scope> </dependency> <dependency> <groupId>org.junit.jupiter</groupId> <artifactId>junit-jupiter-engine</artifactId> <version>5.3.1</version> <scope>test</scope> </dependency>
After add these open the src/test/java folder and
Create new class and give the name whatever you want I’ll give TimeoutTest.
Create 2 test method, one of them tests assertTimeout and the other one tests assertTimeoutPreemptively.
After that I give the duration and add simple print message.
I add the Thread.sleep() method and Thread sleeps 8000 ms ( 8 seconds). But these 2 methods will be fail because these methods takes longer than 3 seconds. Let me test these methods to understand better.
And you see testAssertTimeout method takes 8s 3ms because this method wait to complete all operations , but the other one takes 3s 45ms, and it doesn’t wait to complete other process, it fails immediately.
You can see the message testAssertTimeout method prints the message but assertTimeoutPreemptively method doesn’t print the message, it ignored other operations.
In this post we talked about the main difference between assertTimeout and assertTimeoutPreemptively.
At last, code is available on the Github.
Take care of yourself, see you soon.
The above is the detailed content of What is the main difference between assertTimeout and assertTimeoutPreemptively?. For more information, please follow other related articles on the PHP Chinese website!