Merge "rename artifact's name" into main
diff --git a/android/TerminalApp/java/com/android/virtualization/terminal/MainActivity.java b/android/TerminalApp/java/com/android/virtualization/terminal/MainActivity.java
index 0e2a7d1..c232e37 100644
--- a/android/TerminalApp/java/com/android/virtualization/terminal/MainActivity.java
+++ b/android/TerminalApp/java/com/android/virtualization/terminal/MainActivity.java
@@ -22,6 +22,7 @@
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
+import android.view.accessibility.AccessibilityManager;
import android.webkit.WebChromeClient;
import android.webkit.WebView;
import android.webkit.WebViewClient;
@@ -34,8 +35,9 @@
import com.google.android.material.appbar.MaterialToolbar;
-public class MainActivity extends AppCompatActivity implements
- VmLauncherServices.VmLauncherServiceCallback {
+public class MainActivity extends AppCompatActivity
+ implements VmLauncherServices.VmLauncherServiceCallback,
+ AccessibilityManager.TouchExplorationStateChangeListener {
private static final String TAG = "VmTerminalApp";
private String mVmIpAddr;
private WebView mWebView;
@@ -63,38 +65,58 @@
return true;
}
});
+
+ getSystemService(AccessibilityManager.class).addTouchExplorationStateChangeListener(this);
}
@Override
protected void onDestroy() {
+ getSystemService(AccessibilityManager.class).removeTouchExplorationStateChangeListener(this);
VmLauncherServices.stopVmLauncherService(this);
super.onDestroy();
}
- private void gotoURL(String url) {
+ private void gotoTerminalURL() {
+ if (mVmIpAddr == null) {
+ Log.d(TAG, "ip addr is not set yet");
+ return;
+ }
+
+ boolean isTouchExplorationEnabled =
+ getSystemService(AccessibilityManager.class).isTouchExplorationEnabled();
+
+ String url =
+ "http://"
+ + mVmIpAddr
+ + ":7681/"
+ + (isTouchExplorationEnabled ? "?screenReaderMode=true" : "");
runOnUiThread(() -> mWebView.loadUrl(url));
}
+ @Override
public void onVmStart() {
Log.i(TAG, "onVmStart()");
}
+ @Override
public void onVmStop() {
Toast.makeText(this, R.string.vm_stop_message, Toast.LENGTH_SHORT).show();
Log.i(TAG, "onVmStop()");
finish();
}
+ @Override
public void onVmError() {
Toast.makeText(this, R.string.vm_error_message, Toast.LENGTH_SHORT).show();
Log.i(TAG, "onVmError()");
finish();
}
+ @Override
public void onIpAddrAvailable(String ipAddr) {
mVmIpAddr = ipAddr;
((TextView) findViewById(R.id.ip_addr_textview)).setText(mVmIpAddr);
- gotoURL("http://" + mVmIpAddr + ":7681");
+ gotoTerminalURL();
}
@Override
@@ -122,4 +144,9 @@
}
return super.onOptionsItemSelected(item);
}
+
+ @Override
+ public void onTouchExplorationStateChanged(boolean enabled) {
+ gotoTerminalURL();
+ }
}
diff --git a/build/debian/kokoro/gcp_ubuntu_docker/build.sh b/build/debian/kokoro/gcp_ubuntu_docker/build.sh
index f664403..8125ad8 100644
--- a/build/debian/kokoro/gcp_ubuntu_docker/build.sh
+++ b/build/debian/kokoro/gcp_ubuntu_docker/build.sh
@@ -9,4 +9,5 @@
tar czvS -f ${KOKORO_ARTIFACTS_DIR}/images.tar.gz image.raw
mkdir -p ${KOKORO_ARTIFACTS_DIR}/logs
-cp -r /var/log/fai/*/last/* ${KOKORO_ARTIFACTS_DIR}/logs
+# TODO(b/372162211): Find exact location of log without breaking kokoro build.
+cp -r /var/log/fai/*/last/* ${KOKORO_ARTIFACTS_DIR}/logs || true