Best Mockito code snippet using org.mockitousage.bugs.ShouldNotDeadlockAnswerExecutionTest
Source:ShouldNotDeadlockAnswerExecutionTest.java
...12import org.mockito.Mockito;13import org.mockito.invocation.InvocationOnMock;14import org.mockito.stubbing.Answer;15// see bug 19016public class ShouldNotDeadlockAnswerExecutionTest {17 @Test18 public void failIfMockIsSharedBetweenThreads() throws Exception {19 ShouldNotDeadlockAnswerExecutionTest.Service service = Mockito.mock(ShouldNotDeadlockAnswerExecutionTest.Service.class);20 ExecutorService threads = Executors.newCachedThreadPool();21 AtomicInteger counter = new AtomicInteger(2);22 // registed answer on verySlowMethod23 Mockito.when(service.verySlowMethod()).thenAnswer(new ShouldNotDeadlockAnswerExecutionTest.LockingAnswer(counter));24 // execute verySlowMethod twice in separate threads25 threads.execute(new ShouldNotDeadlockAnswerExecutionTest.ServiceRunner(service));26 threads.execute(new ShouldNotDeadlockAnswerExecutionTest.ServiceRunner(service));27 // waiting for threads to finish28 threads.shutdown();29 if (!(threads.awaitTermination(1000, TimeUnit.MILLISECONDS))) {30 // threads were timed-out31 Assert.fail();32 }33 }34 @Test35 public void successIfEveryThreadHasItsOwnMock() throws Exception {36 ShouldNotDeadlockAnswerExecutionTest.Service service1 = Mockito.mock(ShouldNotDeadlockAnswerExecutionTest.Service.class);37 ShouldNotDeadlockAnswerExecutionTest.Service service2 = Mockito.mock(ShouldNotDeadlockAnswerExecutionTest.Service.class);38 ExecutorService threads = Executors.newCachedThreadPool();39 AtomicInteger counter = new AtomicInteger(2);40 // registed answer on verySlowMethod41 Mockito.when(service1.verySlowMethod()).thenAnswer(new ShouldNotDeadlockAnswerExecutionTest.LockingAnswer(counter));42 Mockito.when(service2.verySlowMethod()).thenAnswer(new ShouldNotDeadlockAnswerExecutionTest.LockingAnswer(counter));43 // execute verySlowMethod twice in separate threads44 threads.execute(new ShouldNotDeadlockAnswerExecutionTest.ServiceRunner(service1));45 threads.execute(new ShouldNotDeadlockAnswerExecutionTest.ServiceRunner(service2));46 // waiting for threads to finish47 threads.shutdown();48 if (!(threads.awaitTermination(500, TimeUnit.MILLISECONDS))) {49 // threads were timed-out50 Assert.fail();51 }52 }53 static class LockingAnswer implements Answer<String> {54 private AtomicInteger counter;55 public LockingAnswer(AtomicInteger counter) {56 this.counter = counter;57 }58 /**59 * Decrement counter and wait until counter has value 060 */61 public String answer(InvocationOnMock invocation) throws Throwable {62 counter.decrementAndGet();63 while ((counter.get()) != 0) {64 Thread.sleep(10);65 } 66 return null;67 }68 }69 static class ServiceRunner implements Runnable {70 private ShouldNotDeadlockAnswerExecutionTest.Service service;71 public ServiceRunner(ShouldNotDeadlockAnswerExecutionTest.Service service) {72 this.service = service;73 }74 public void run() {75 service.verySlowMethod();76 }77 }78 interface Service {79 String verySlowMethod();80 }81}...
ShouldNotDeadlockAnswerExecutionTest
Using AI Code Generation
1package org.mockitousage.bugs;2import org.junit.Test;3import org.mockito.Mockito;4import org.mockito.exceptions.verification.junit.ArgumentsAreDifferent;5import org.mockito.exceptions.verification.junit.TooFewActualInvocations;6import org.mockito.exceptions.verification.junit.TooManyActualInvocations;7import org.mockitousage.IMethods;8import org.mockitoutil.TestBase;9import java.util.concurrent.CountDownLatch;10import static org.junit.Assert.fail;11import static org.mockito.Mockito.*;12public class ShouldNotDeadlockAnswerExecutionTest extends TestBase {13 public void should_not_deadlock_when_answer_executes_the_same_method() throws InterruptedException {14 IMethods mock = mock(IMethods.class, new AnswerThatExecutesSameMethod());15 final CountDownLatch latch = new CountDownLatch(1);16 Thread t = new Thread(new Runnable() {17 public void run() {18 mock.simpleMethod(1);19 latch.countDown();20 }21 });22 t.start();23 t.join();24 latch.await();25 verify(mock).simpleMethod(1);26 }27 public void should_not_deadlock_when_answer_executes_another_method() throws InterruptedException {28 IMethods mock = mock(IMethods.class, new AnswerThatExecutesAnotherMethod());29 final CountDownLatch latch = new CountDownLatch(1);30 Thread t = new Thread(new Runnable() {31 public void run() {32 mock.simpleMethod(1);33 latch.countDown();34 }35 });36 t.start();37 t.join();38 latch.await();39 verify(mock).simpleMethod(1);40 }41 public void should_not_deadlock_when_answer_executes_another_mock() throws InterruptedException {42 IMethods mock = mock(IMethods.class, new AnswerThatExecutesAnotherMock());43 final CountDownLatch latch = new CountDownLatch(1);44 Thread t = new Thread(new Runnable() {45 public void run() {46 mock.simpleMethod(1);47 latch.countDown();48 }49 });50 t.start();51 t.join();52 latch.await();53 verify(mock).simpleMethod(1);54 }55 public void should_not_deadlock_when_answer_executes_another_mock_in_another_thread() throws InterruptedException {56 IMethods mock = mock(IMethods.class, new AnswerThatExecutesAnotherMockInAnotherThread());
Why does mockito report error on thenReturn() in java 7 but not in java 6
How to do a JUnit assert on a message in a logger
Matching multiple properties in one Matcher
How to tell a Mockito mock object to return something different the next time it is called?
Are there alternatives to cglib?
Is it possible to use Mockito in Kotlin?
MockClassLoader cannot access jdk/internal/reflect superclass jdk.internal.reflect.MagicAccessorImpl
Mockito ArgumentMatcher saying Arguments are Different
Spring Controller Testing using Mockito , Null Pointer Exception
How to verify mocked method not called with any combination of parameters using Mockito
I believe that what is really happening here is more than one mock method invocation in single when(...).then(...)
statement.
Consider following example:
when(program.getName()).thenReturn(String.valueOf(program.compareTo(null)));
It returns the same exception that You have. It is because there are two methods invoked on mock: getName()
and compareTo()
in single when(...).thenReturn(...)
statement.
Also in this page (the mockito documentation) You can read that:
By default, for all methods that return value, mock returns null, an empty collection or appropriate primitive/primitive wrapper value (e.g: 0, false, ... for int/Integer, boolean/Boolean, ...).
Therefore mockito has to have some mechanism for detecting what to do (return) for which invocation on some mocked object.
In Your example second invocation is made by new TreeSet<>(Collections.singleton(program))
statement, because TreeSet constructor is using compareTo()
method of Your mock.
It seems that implementation of TreeSet changed from java 6 to java 7. That is why it could have worked earlier.
Check out the latest blogs from LambdaTest on this topic:
The web development industry is growing, and many Best Automated UI Testing Tools are available to test your web-based project to ensure it is bug-free and easily accessible for every user. These tools help you test your web project and make it fully compatible with user-end requirements and needs.
This article is a part of our Content Hub. For more in-depth resources, check out our content hub on Mobile App Testing Tutorial.
We launched LT Browser in 2020, and we were overwhelmed by the response as it was awarded as the #5 product of the day on the ProductHunt platform. Today, after 74,585 downloads and 7,000 total test runs with an average of 100 test runs each day, the LT Browser has continued to help developers build responsive web designs in a jiffy.
Mobile devices and mobile applications – both are booming in the world today. The idea of having the power of a computer in your pocket is revolutionary. As per Statista, mobile accounts for more than half of the web traffic worldwide. Mobile devices (excluding tablets) contributed to 54.4 percent of global website traffic in the fourth quarter of 2021, increasing consistently over the past couple of years.
The QA testing profession requires both educational and long-term or experience-based learning. One can learn the basics from certification courses and exams, boot camp courses, and college-level courses where available. However, developing instinctive and practical skills works best when built with work experience.
Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.
You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.
Get 100 minutes of automation test minutes FREE!!