Merge "Adjust the notifyNetworkUnrequested on handleRegisterListener" am: bad235f4f9 am: 5d7547e05d
Original change: https://android-review.googlesource.com/c/platform/packages/modules/Connectivity/+/2618620 Change-Id: I7e4a764b159e3945c3052d65a32a633701a70369 Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
@@ -220,6 +220,9 @@ public class MdnsDiscoveryManager implements MdnsSocketClientBase.Callback {
|
||||
|
||||
private void handleUnregisterListener(
|
||||
@NonNull String serviceType, @NonNull MdnsServiceBrowserListener listener) {
|
||||
// Unrequested the network.
|
||||
socketClient.notifyNetworkUnrequested(listener);
|
||||
|
||||
final List<MdnsServiceTypeClient> serviceTypeClients =
|
||||
perNetworkServiceTypeClients.getByServiceType(serviceType);
|
||||
if (serviceTypeClients.isEmpty()) {
|
||||
@@ -237,8 +240,6 @@ public class MdnsDiscoveryManager implements MdnsSocketClientBase.Callback {
|
||||
// No discovery request. Stops the socket client.
|
||||
socketClient.stopDiscovery();
|
||||
}
|
||||
// Unrequested the network.
|
||||
socketClient.notifyNetworkUnrequested(listener);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
@@ -294,6 +294,47 @@ public class MdnsDiscoveryManagerTests {
|
||||
.processResponse(response, ifIndex, NETWORK_1);
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testUnregisterListenerAfterSocketDestroyed() throws IOException {
|
||||
// Create a ServiceTypeClient for SERVICE_TYPE_1
|
||||
final MdnsSearchOptions network1Options =
|
||||
MdnsSearchOptions.newBuilder().setNetwork(null /* network */).build();
|
||||
final SocketCreationCallback callback = expectSocketCreationCallback(
|
||||
SERVICE_TYPE_1, mockListenerOne, network1Options);
|
||||
runOnHandler(() -> callback.onSocketCreated(null /* network */));
|
||||
verify(mockServiceTypeClientType1NullNetwork).startSendAndReceive(
|
||||
mockListenerOne, network1Options);
|
||||
|
||||
// Receive a response, it should be processed on the client.
|
||||
final MdnsPacket response = createMdnsPacket(SERVICE_TYPE_1);
|
||||
final int ifIndex = 1;
|
||||
runOnHandler(() -> discoveryManager.onResponseReceived(
|
||||
response, ifIndex, null /* network */));
|
||||
verify(mockServiceTypeClientType1NullNetwork).processResponse(
|
||||
response, ifIndex, null /* network */);
|
||||
|
||||
runOnHandler(() -> callback.onAllSocketsDestroyed(null /* network */));
|
||||
verify(mockServiceTypeClientType1NullNetwork).notifySocketDestroyed();
|
||||
|
||||
// Receive a response again, it should not be processed.
|
||||
runOnHandler(() -> discoveryManager.onResponseReceived(
|
||||
response, ifIndex, null /* network */));
|
||||
// Still times(1) as a response was received once previously
|
||||
verify(mockServiceTypeClientType1NullNetwork, times(1))
|
||||
.processResponse(response, ifIndex, null /* network */);
|
||||
|
||||
// Unregister the listener, notifyNetworkUnrequested should be called but other stop methods
|
||||
// won't be call because the service type client was unregistered and destroyed. But those
|
||||
// cleanups were done in notifySocketDestroyed when the socket was destroyed.
|
||||
runOnHandler(() -> discoveryManager.unregisterListener(SERVICE_TYPE_1, mockListenerOne));
|
||||
verify(socketClient).notifyNetworkUnrequested(mockListenerOne);
|
||||
verify(mockServiceTypeClientType1NullNetwork, never()).stopSendAndReceive(any());
|
||||
// The stopDiscovery() is only used by MdnsSocketClient, which doesn't send
|
||||
// onAllSocketsDestroyed(). So the socket clients that send onAllSocketsDestroyed() do not
|
||||
// need to call stopDiscovery().
|
||||
verify(socketClient, never()).stopDiscovery();
|
||||
}
|
||||
|
||||
private MdnsPacket createMdnsPacket(String serviceType) {
|
||||
final String[] type = TextUtils.split(serviceType, "\\.");
|
||||
final ArrayList<String> name = new ArrayList<>(type.length + 1);
|
||||
|
||||
Reference in New Issue
Block a user