Merge "Merge "Fixing NetworkWatchlistTest#testGetWatchlistConfigHash for secondary users." into pie-cts-dev am: 4e9043b8cf"
This commit is contained in:
@@ -25,6 +25,7 @@ import android.content.Context;
|
|||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.platform.test.annotations.AppModeFull;
|
import android.platform.test.annotations.AppModeFull;
|
||||||
import android.os.FileUtils;
|
import android.os.FileUtils;
|
||||||
|
import android.os.ParcelFileDescriptor;
|
||||||
|
|
||||||
import androidx.test.InstrumentationRegistry;
|
import androidx.test.InstrumentationRegistry;
|
||||||
import androidx.test.filters.SmallTest;
|
import androidx.test.filters.SmallTest;
|
||||||
@@ -39,7 +40,7 @@ import org.junit.Before;
|
|||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.FileOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.util.Formatter;
|
import java.util.Formatter;
|
||||||
@@ -51,8 +52,6 @@ public class NetworkWatchlistTest {
|
|||||||
private static final String TEST_WATCHLIST_XML = "assets/network_watchlist_config_for_test.xml";
|
private static final String TEST_WATCHLIST_XML = "assets/network_watchlist_config_for_test.xml";
|
||||||
private static final String TEST_EMPTY_WATCHLIST_XML =
|
private static final String TEST_EMPTY_WATCHLIST_XML =
|
||||||
"assets/network_watchlist_config_empty_for_test.xml";
|
"assets/network_watchlist_config_empty_for_test.xml";
|
||||||
private static final String SDCARD_CONFIG_PATH =
|
|
||||||
"/sdcard/network_watchlist_config_for_test.xml";
|
|
||||||
private static final String TMP_CONFIG_PATH =
|
private static final String TMP_CONFIG_PATH =
|
||||||
"/data/local/tmp/network_watchlist_config_for_test.xml";
|
"/data/local/tmp/network_watchlist_config_for_test.xml";
|
||||||
// Generated from sha256sum network_watchlist_config_for_test.xml
|
// Generated from sha256sum network_watchlist_config_for_test.xml
|
||||||
@@ -84,8 +83,7 @@ public class NetworkWatchlistTest {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void cleanup() throws Exception {
|
private void cleanup() throws IOException {
|
||||||
runCommand("rm " + SDCARD_CONFIG_PATH);
|
|
||||||
runCommand("rm " + TMP_CONFIG_PATH);
|
runCommand("rm " + TMP_CONFIG_PATH);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -118,22 +116,43 @@ public class NetworkWatchlistTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void saveResourceToFile(String res, String filePath) throws IOException {
|
private void saveResourceToFile(String res, String filePath) throws IOException {
|
||||||
InputStream in = getClass().getClassLoader().getResourceAsStream(res);
|
// App can't access /data/local/tmp directly, so we pipe resource to file through stdin.
|
||||||
FileUtils.copyToFileOrThrow(in, new File(filePath));
|
ParcelFileDescriptor stdin = pipeFromStdin(filePath);
|
||||||
|
pipeResourceToFileDescriptor(res, stdin);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Pipe stdin to a file in filePath. Returns PFD for stdin. */
|
||||||
|
private ParcelFileDescriptor pipeFromStdin(String filePath) {
|
||||||
|
// Not all devices have symlink for /dev/stdin, so use /proc/self/fd/0 directly.
|
||||||
|
// /dev/stdin maps to /proc/self/fd/0.
|
||||||
|
return runRwCommand("cp /proc/self/fd/0 " + filePath)[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
private void pipeResourceToFileDescriptor(String res, ParcelFileDescriptor pfd)
|
||||||
|
throws IOException {
|
||||||
|
InputStream resStream = getClass().getClassLoader().getResourceAsStream(res);
|
||||||
|
FileOutputStream fdStream = new ParcelFileDescriptor.AutoCloseOutputStream(pfd);
|
||||||
|
|
||||||
|
FileUtils.copy(resStream, fdStream);
|
||||||
|
|
||||||
|
try {
|
||||||
|
fdStream.close();
|
||||||
|
} catch (IOException e) {
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static String runCommand(String command) throws IOException {
|
private static String runCommand(String command) throws IOException {
|
||||||
return SystemUtil.runShellCommand(InstrumentationRegistry.getInstrumentation(), command);
|
return SystemUtil.runShellCommand(InstrumentationRegistry.getInstrumentation(), command);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static ParcelFileDescriptor[] runRwCommand(String command) {
|
||||||
|
return InstrumentationRegistry.getInstrumentation()
|
||||||
|
.getUiAutomation().executeShellCommandRw(command);
|
||||||
|
}
|
||||||
|
|
||||||
private void setWatchlistConfig(String watchlistConfigFile) throws Exception {
|
private void setWatchlistConfig(String watchlistConfigFile) throws Exception {
|
||||||
cleanup();
|
cleanup();
|
||||||
// Save test watchlist config to sdcard as app can't access /data/local/tmp
|
saveResourceToFile(watchlistConfigFile, TMP_CONFIG_PATH);
|
||||||
saveResourceToFile(watchlistConfigFile, SDCARD_CONFIG_PATH);
|
|
||||||
// Copy test watchlist config from sdcard to /data/local/tmp as system service
|
|
||||||
// can't access /sdcard
|
|
||||||
runCommand("cp " + SDCARD_CONFIG_PATH + " " + TMP_CONFIG_PATH);
|
|
||||||
// Set test watchlist config to system
|
|
||||||
final String cmdResult = runCommand(
|
final String cmdResult = runCommand(
|
||||||
"cmd network_watchlist set-test-config " + TMP_CONFIG_PATH).trim();
|
"cmd network_watchlist set-test-config " + TMP_CONFIG_PATH).trim();
|
||||||
assertThat(cmdResult).contains("Success");
|
assertThat(cmdResult).contains("Success");
|
||||||
|
|||||||
Reference in New Issue
Block a user