Network Service Discovery test: properly release resources
Bug: 32561414 Bug: 62918393 Bug: 62044295 Test: runtest frameworks-net Change-Id: If23993b5e391947ecbdc01677f0a643144794b2b
This commit is contained in:
@@ -28,6 +28,7 @@ import static org.mockito.Mockito.timeout;
|
|||||||
import static org.mockito.Mockito.times;
|
import static org.mockito.Mockito.times;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
import static com.android.internal.util.TestUtils.waitForIdleHandler;
|
||||||
|
|
||||||
import android.os.HandlerThread;
|
import android.os.HandlerThread;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
@@ -38,6 +39,7 @@ import android.support.test.runner.AndroidJUnit4;
|
|||||||
import android.os.Message;
|
import android.os.Message;
|
||||||
import android.os.Messenger;
|
import android.os.Messenger;
|
||||||
import com.android.internal.util.AsyncChannel;
|
import com.android.internal.util.AsyncChannel;
|
||||||
|
import org.junit.After;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -56,6 +58,8 @@ public class NsdManagerTest {
|
|||||||
@Mock INsdManager mService;
|
@Mock INsdManager mService;
|
||||||
MockServiceHandler mServiceHandler;
|
MockServiceHandler mServiceHandler;
|
||||||
|
|
||||||
|
NsdManager mManager;
|
||||||
|
|
||||||
long mTimeoutMs = 100; // non-final so that tests can adjust the value.
|
long mTimeoutMs = 100; // non-final so that tests can adjust the value.
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
@@ -64,11 +68,23 @@ public class NsdManagerTest {
|
|||||||
|
|
||||||
mServiceHandler = spy(MockServiceHandler.create(mContext));
|
mServiceHandler = spy(MockServiceHandler.create(mContext));
|
||||||
when(mService.getMessenger()).thenReturn(new Messenger(mServiceHandler));
|
when(mService.getMessenger()).thenReturn(new Messenger(mServiceHandler));
|
||||||
|
|
||||||
|
mManager = makeManager();
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void tearDown() throws Exception {
|
||||||
|
waitForIdleHandler(mServiceHandler, mTimeoutMs);
|
||||||
|
mServiceHandler.chan.disconnect();
|
||||||
|
mServiceHandler.stop();
|
||||||
|
if (mManager != null) {
|
||||||
|
mManager.disconnect();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testResolveService() {
|
public void testResolveService() {
|
||||||
NsdManager manager = makeManager();
|
NsdManager manager = mManager;
|
||||||
|
|
||||||
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
||||||
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
||||||
@@ -88,7 +104,7 @@ public class NsdManagerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testParallelResolveService() {
|
public void testParallelResolveService() {
|
||||||
NsdManager manager = makeManager();
|
NsdManager manager = mManager;
|
||||||
|
|
||||||
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
||||||
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
||||||
@@ -111,7 +127,7 @@ public class NsdManagerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testRegisterService() {
|
public void testRegisterService() {
|
||||||
NsdManager manager = makeManager();
|
NsdManager manager = mManager;
|
||||||
|
|
||||||
NsdServiceInfo request1 = new NsdServiceInfo("a_name", "a_type");
|
NsdServiceInfo request1 = new NsdServiceInfo("a_name", "a_type");
|
||||||
NsdServiceInfo request2 = new NsdServiceInfo("another_name", "another_type");
|
NsdServiceInfo request2 = new NsdServiceInfo("another_name", "another_type");
|
||||||
@@ -170,7 +186,7 @@ public class NsdManagerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testDiscoverService() {
|
public void testDiscoverService() {
|
||||||
NsdManager manager = makeManager();
|
NsdManager manager = mManager;
|
||||||
|
|
||||||
NsdServiceInfo reply1 = new NsdServiceInfo("a_name", "a_type");
|
NsdServiceInfo reply1 = new NsdServiceInfo("a_name", "a_type");
|
||||||
NsdServiceInfo reply2 = new NsdServiceInfo("another_name", "a_type");
|
NsdServiceInfo reply2 = new NsdServiceInfo("another_name", "a_type");
|
||||||
@@ -248,7 +264,7 @@ public class NsdManagerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInvalidCalls() {
|
public void testInvalidCalls() {
|
||||||
NsdManager manager = new NsdManager(mContext, mService);
|
NsdManager manager = mManager;
|
||||||
|
|
||||||
NsdManager.RegistrationListener listener1 = mock(NsdManager.RegistrationListener.class);
|
NsdManager.RegistrationListener listener1 = mock(NsdManager.RegistrationListener.class);
|
||||||
NsdManager.DiscoveryListener listener2 = mock(NsdManager.DiscoveryListener.class);
|
NsdManager.DiscoveryListener listener2 = mock(NsdManager.DiscoveryListener.class);
|
||||||
@@ -351,6 +367,10 @@ public class NsdManagerTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void stop() {
|
||||||
|
getLooper().quitSafely();
|
||||||
|
}
|
||||||
|
|
||||||
public static MockServiceHandler create(Context context) {
|
public static MockServiceHandler create(Context context) {
|
||||||
HandlerThread t = new HandlerThread("mock-service-handler");
|
HandlerThread t = new HandlerThread("mock-service-handler");
|
||||||
t.start();
|
t.start();
|
||||||
|
|||||||
@@ -95,6 +95,9 @@ public class NsdServiceTest {
|
|||||||
client2.disconnect();
|
client2.disconnect();
|
||||||
|
|
||||||
verify(mDaemon, timeout(mTimeoutMs).times(1)).stop();
|
verify(mDaemon, timeout(mTimeoutMs).times(1)).stop();
|
||||||
|
|
||||||
|
client1.disconnect();
|
||||||
|
client2.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -131,6 +134,8 @@ public class NsdServiceTest {
|
|||||||
|
|
||||||
// checks that request are cleaned
|
// checks that request are cleaned
|
||||||
verifyDaemonCommands("stop-register 2", "stop-discover 3", "stop-resolve 4");
|
verifyDaemonCommands("stop-register 2", "stop-discover 3", "stop-resolve 4");
|
||||||
|
|
||||||
|
client.disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
NsdService makeService() {
|
NsdService makeService() {
|
||||||
|
|||||||
Reference in New Issue
Block a user