NsdService: test coverage for client requests.
Adding coverage for: - NsdManager client disconnection - in-flight request GC Test: new test passes Bug: 37013369, 33298084 Change-Id: I92039f297cf99352bbf4196797933d89c0b819ff
This commit is contained in:
@@ -273,6 +273,14 @@ public final class NsdManager {
|
|||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @hide
|
||||||
|
*/
|
||||||
|
@VisibleForTesting
|
||||||
|
public void disconnect() {
|
||||||
|
mAsyncChannel.disconnect();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Failures are passed with {@link RegistrationListener#onRegistrationFailed},
|
* Failures are passed with {@link RegistrationListener#onRegistrationFailed},
|
||||||
* {@link RegistrationListener#onUnregistrationFailed},
|
* {@link RegistrationListener#onUnregistrationFailed},
|
||||||
|
|||||||
@@ -48,7 +48,6 @@ import com.android.internal.util.AsyncChannel;
|
|||||||
import com.android.internal.util.Protocol;
|
import com.android.internal.util.Protocol;
|
||||||
import com.android.internal.util.State;
|
import com.android.internal.util.State;
|
||||||
import com.android.internal.util.StateMachine;
|
import com.android.internal.util.StateMachine;
|
||||||
import com.android.server.NativeDaemonConnector.Command;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Network Service Discovery Service handles remote service discovery operation requests by
|
* Network Service Discovery Service handles remote service discovery operation requests by
|
||||||
@@ -161,7 +160,7 @@ public class NsdService extends INsdManager.Stub {
|
|||||||
}
|
}
|
||||||
//Last client
|
//Last client
|
||||||
if (mClients.size() == 0) {
|
if (mClients.size() == 0) {
|
||||||
stopMDnsDaemon();
|
mDaemon.stop();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case AsyncChannel.CMD_CHANNEL_FULL_CONNECTION:
|
case AsyncChannel.CMD_CHANNEL_FULL_CONNECTION:
|
||||||
@@ -221,14 +220,14 @@ public class NsdService extends INsdManager.Stub {
|
|||||||
public void enter() {
|
public void enter() {
|
||||||
sendNsdStateChangeBroadcast(true);
|
sendNsdStateChangeBroadcast(true);
|
||||||
if (mClients.size() > 0) {
|
if (mClients.size() > 0) {
|
||||||
startMDnsDaemon();
|
mDaemon.start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void exit() {
|
public void exit() {
|
||||||
if (mClients.size() > 0) {
|
if (mClients.size() > 0) {
|
||||||
stopMDnsDaemon();
|
mDaemon.stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -262,7 +261,7 @@ public class NsdService extends INsdManager.Stub {
|
|||||||
//First client
|
//First client
|
||||||
if (msg.arg1 == AsyncChannel.STATUS_SUCCESSFUL &&
|
if (msg.arg1 == AsyncChannel.STATUS_SUCCESSFUL &&
|
||||||
mClients.size() == 0) {
|
mClients.size() == 0) {
|
||||||
startMDnsDaemon();
|
mDaemon.start();
|
||||||
}
|
}
|
||||||
return NOT_HANDLED;
|
return NOT_HANDLED;
|
||||||
case AsyncChannel.CMD_CHANNEL_DISCONNECTED:
|
case AsyncChannel.CMD_CHANNEL_DISCONNECTED:
|
||||||
@@ -712,26 +711,13 @@ public class NsdService extends INsdManager.Stub {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean execute(Command cmd) {
|
public void start() {
|
||||||
if (DBG) {
|
execute("start-service");
|
||||||
Slog.d(TAG, cmd.toString());
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
mNativeConnector.execute(cmd);
|
|
||||||
} catch (NativeDaemonConnectorException e) {
|
|
||||||
Slog.e(TAG, "Failed to execute " + cmd, e);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private boolean startMDnsDaemon() {
|
public void stop() {
|
||||||
return mDaemon.execute("start-service");
|
execute("stop-service");
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean stopMDnsDaemon() {
|
|
||||||
return mDaemon.execute("stop-service");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean registerService(int regId, NsdServiceInfo service) {
|
private boolean registerService(int regId, NsdServiceInfo service) {
|
||||||
@@ -743,8 +729,7 @@ public class NsdService extends INsdManager.Stub {
|
|||||||
int port = service.getPort();
|
int port = service.getPort();
|
||||||
byte[] textRecord = service.getTxtRecord();
|
byte[] textRecord = service.getTxtRecord();
|
||||||
String record = Base64.encodeToString(textRecord, Base64.DEFAULT).replace("\n", "");
|
String record = Base64.encodeToString(textRecord, Base64.DEFAULT).replace("\n", "");
|
||||||
Command cmd = new Command("mdnssd", "register", regId, name, type, port, record);
|
return mDaemon.execute("register", regId, name, type, port, record);
|
||||||
return mDaemon.execute(cmd);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean unregisterService(int regId) {
|
private boolean unregisterService(int regId) {
|
||||||
|
|||||||
Reference in New Issue
Block a user