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.verify;
|
||||
import static org.mockito.Mockito.when;
|
||||
import static com.android.internal.util.TestUtils.waitForIdleHandler;
|
||||
|
||||
import android.os.HandlerThread;
|
||||
import android.os.Handler;
|
||||
@@ -38,6 +39,7 @@ import android.support.test.runner.AndroidJUnit4;
|
||||
import android.os.Message;
|
||||
import android.os.Messenger;
|
||||
import com.android.internal.util.AsyncChannel;
|
||||
import org.junit.After;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
@@ -56,6 +58,8 @@ public class NsdManagerTest {
|
||||
@Mock INsdManager mService;
|
||||
MockServiceHandler mServiceHandler;
|
||||
|
||||
NsdManager mManager;
|
||||
|
||||
long mTimeoutMs = 100; // non-final so that tests can adjust the value.
|
||||
|
||||
@Before
|
||||
@@ -64,11 +68,23 @@ public class NsdManagerTest {
|
||||
|
||||
mServiceHandler = spy(MockServiceHandler.create(mContext));
|
||||
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
|
||||
public void testResolveService() {
|
||||
NsdManager manager = makeManager();
|
||||
NsdManager manager = mManager;
|
||||
|
||||
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
||||
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
||||
@@ -88,7 +104,7 @@ public class NsdManagerTest {
|
||||
|
||||
@Test
|
||||
public void testParallelResolveService() {
|
||||
NsdManager manager = makeManager();
|
||||
NsdManager manager = mManager;
|
||||
|
||||
NsdServiceInfo request = new NsdServiceInfo("a_name", "a_type");
|
||||
NsdServiceInfo reply = new NsdServiceInfo("resolved_name", "resolved_type");
|
||||
@@ -111,7 +127,7 @@ public class NsdManagerTest {
|
||||
|
||||
@Test
|
||||
public void testRegisterService() {
|
||||
NsdManager manager = makeManager();
|
||||
NsdManager manager = mManager;
|
||||
|
||||
NsdServiceInfo request1 = new NsdServiceInfo("a_name", "a_type");
|
||||
NsdServiceInfo request2 = new NsdServiceInfo("another_name", "another_type");
|
||||
@@ -170,7 +186,7 @@ public class NsdManagerTest {
|
||||
|
||||
@Test
|
||||
public void testDiscoverService() {
|
||||
NsdManager manager = makeManager();
|
||||
NsdManager manager = mManager;
|
||||
|
||||
NsdServiceInfo reply1 = new NsdServiceInfo("a_name", "a_type");
|
||||
NsdServiceInfo reply2 = new NsdServiceInfo("another_name", "a_type");
|
||||
@@ -248,7 +264,7 @@ public class NsdManagerTest {
|
||||
|
||||
@Test
|
||||
public void testInvalidCalls() {
|
||||
NsdManager manager = new NsdManager(mContext, mService);
|
||||
NsdManager manager = mManager;
|
||||
|
||||
NsdManager.RegistrationListener listener1 = mock(NsdManager.RegistrationListener.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) {
|
||||
HandlerThread t = new HandlerThread("mock-service-handler");
|
||||
t.start();
|
||||
|
||||
@@ -95,6 +95,9 @@ public class NsdServiceTest {
|
||||
client2.disconnect();
|
||||
|
||||
verify(mDaemon, timeout(mTimeoutMs).times(1)).stop();
|
||||
|
||||
client1.disconnect();
|
||||
client2.disconnect();
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -131,6 +134,8 @@ public class NsdServiceTest {
|
||||
|
||||
// checks that request are cleaned
|
||||
verifyDaemonCommands("stop-register 2", "stop-discover 3", "stop-resolve 4");
|
||||
|
||||
client.disconnect();
|
||||
}
|
||||
|
||||
NsdService makeService() {
|
||||
|
||||
Reference in New Issue
Block a user