diff --git a/DEPS b/DEPS
index 744b71d..1289889 100644
--- a/DEPS
+++ b/DEPS
@@ -359,7 +359,7 @@
   # Three lines of non-changing comments so that
   # the commit queue can handle CLs rolling devtools-frontend
   # and whatever else without interference from each other.
-  'devtools_frontend_revision': '6972331010a288991a1544be4df7892e3bc8801a',
+  'devtools_frontend_revision': '8a1afd340d4cefeff093902107269a2483ed5a98',
   # Three lines of non-changing comments so that
   # the commit queue can handle CLs rolling libprotobuf-mutator
   # and whatever else without interference from each other.
@@ -395,7 +395,7 @@
   # Three lines of non-changing comments so that
   # the commit queue can handle CLs rolling feed
   # and whatever else without interference from each other.
-  'dawn_revision': 'c4f0232de2dc5901f6c13d7693964387a22b507e',
+  'dawn_revision': '0e414c57045668bf6343215a3fc7db6a5a76680b',
   # Three lines of non-changing comments so that
   # the commit queue can handle CLs rolling feed
   # and whatever else without interference from each other.
@@ -1554,7 +1554,7 @@
   },
 
   'src/third_party/perfetto':
-    Var('android_git') + '/platform/external/perfetto.git' + '@' + 'd86457ab539f83842f0e6c891c459bd764267b8d',
+    Var('android_git') + '/platform/external/perfetto.git' + '@' + 'dd682e48aa77446c4bec51af0f08421d1a2bac47',
 
   'src/third_party/perl': {
       'url': Var('chromium_git') + '/chromium/deps/perl.git' + '@' + '6f3e5028eb65d0b4c5fdd792106ac4c84eee1eb3',
@@ -1724,7 +1724,7 @@
     Var('chromium_git') + '/external/github.com/gpuweb/cts.git' + '@' + '6c0f3bab40dead9e205a95ef64ad8f912c694a1d',
 
   'src/third_party/webrtc':
-    Var('webrtc_git') + '/src.git' + '@' + 'c931f708967382050f111bfdd73ff689f7f3b190',
+    Var('webrtc_git') + '/src.git' + '@' + '1c5808145e8b151800b0320b8a7316a09b706488',
 
   'src/third_party/libgifcodec':
      Var('skia_git') + '/libgifcodec' + '@'+  Var('libgifcodec_revision'),
@@ -1797,7 +1797,7 @@
     Var('chromium_git') + '/v8/v8.git' + '@' +  Var('v8_revision'),
 
   'src-internal': {
-    'url': 'https://chrome-internal.googlesource.com/chrome/src-internal.git@f47334ee66859e1916d798d190153381efae888d',
+    'url': 'https://chrome-internal.googlesource.com/chrome/src-internal.git@28b82e7e8f39aa2ea2202676cc4c20d62bb23766',
     'condition': 'checkout_src_internal',
   },
 
@@ -1849,7 +1849,7 @@
     'packages': [
       {
         'package': 'chromeos_internal/apps/projector_app/app',
-        'version': 'T7kIh1oWOuKNns_uhf8PbXJ34OM3cOUXvKzTCxAIA6EC',
+        'version': 'C_W-d-5MCa4aXPlaRI94F399ZFFKha1JNPSQOh3p-IAC',
       },
     ],
     'condition': 'checkout_chromeos and checkout_src_internal',
diff --git a/ash/components/arc/net/always_on_vpn_manager.cc b/ash/components/arc/net/always_on_vpn_manager.cc
index a7782e3..dfd196a 100644
--- a/ash/components/arc/net/always_on_vpn_manager.cc
+++ b/ash/components/arc/net/always_on_vpn_manager.cc
@@ -10,7 +10,7 @@
 #include "base/bind.h"
 #include "base/callback_helpers.h"
 #include "base/values.h"
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "third_party/cros_system_api/dbus/service_constants.h"
 
diff --git a/ash/components/arc/net/arc_net_host_impl.cc b/ash/components/arc/net/arc_net_host_impl.cc
index 1b9bce841..43536be 100644
--- a/ash/components/arc/net/arc_net_host_impl.cc
+++ b/ash/components/arc/net/arc_net_host_impl.cc
@@ -25,11 +25,11 @@
 #include "chromeos/ash/components/network/client_cert_util.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
diff --git a/ash/components/arc/net/arc_net_host_impl.h b/ash/components/arc/net/arc_net_host_impl.h
index 241cd4c..216981a 100644
--- a/ash/components/arc/net/arc_net_host_impl.h
+++ b/ash/components/arc/net/arc_net_host_impl.h
@@ -20,7 +20,7 @@
 #include "base/threading/thread_checker.h"
 #include "base/values.h"
 #include "chromeos/ash/components/dbus/patchpanel/patchpanel_service.pb.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "components/keyed_service/core/keyed_service.h"
diff --git a/ash/components/tether/asynchronous_shutdown_object_container_impl.h b/ash/components/tether/asynchronous_shutdown_object_container_impl.h
index f911e34..fe5875c 100644
--- a/ash/components/tether/asynchronous_shutdown_object_container_impl.h
+++ b/ash/components/tether/asynchronous_shutdown_object_container_impl.h
@@ -16,7 +16,7 @@
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state_handler.h"
 
diff --git a/ash/components/tether/fake_tether_connector.h b/ash/components/tether/fake_tether_connector.h
index 93a00fa..705f7e34 100644
--- a/ash/components/tether/fake_tether_connector.h
+++ b/ash/components/tether/fake_tether_connector.h
@@ -7,7 +7,7 @@
 
 #include "ash/components/tether/tether_connector.h"
 #include "base/callback_forward.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/fake_tether_disconnector.h b/ash/components/tether/fake_tether_disconnector.h
index 4483401..338114a 100644
--- a/ash/components/tether/fake_tether_disconnector.h
+++ b/ash/components/tether/fake_tether_disconnector.h
@@ -8,7 +8,7 @@
 #include "ash/components/tether/tether_disconnector.h"
 #include "ash/components/tether/tether_session_completion_logger.h"
 #include "base/callback_forward.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/network_connection_handler_tether_delegate.h b/ash/components/tether/network_connection_handler_tether_delegate.h
index 136d81a..405a69ed 100644
--- a/ash/components/tether/network_connection_handler_tether_delegate.h
+++ b/ash/components/tether/network_connection_handler_tether_delegate.h
@@ -8,7 +8,7 @@
 #include <unordered_map>
 
 #include "base/memory/weak_ptr.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/network_connection_handler_tether_delegate_unittest.cc b/ash/components/tether/network_connection_handler_tether_delegate_unittest.cc
index d5aa15b..6e265f80 100644
--- a/ash/components/tether/network_connection_handler_tether_delegate_unittest.cc
+++ b/ash/components/tether/network_connection_handler_tether_delegate_unittest.cc
@@ -13,7 +13,7 @@
 #include "ash/components/tether/tether_session_completion_logger.h"
 #include "base/bind.h"
 #include "base/memory/ptr_util.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "testing/gtest/include/gtest/gtest.h"
 
 namespace ash {
diff --git a/ash/components/tether/synchronous_shutdown_object_container_impl.h b/ash/components/tether/synchronous_shutdown_object_container_impl.h
index 7c28d96..6e5faa7 100644
--- a/ash/components/tether/synchronous_shutdown_object_container_impl.h
+++ b/ash/components/tether/synchronous_shutdown_object_container_impl.h
@@ -11,11 +11,11 @@
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "ash/services/secure_channel/public/cpp/client/secure_channel_client.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 class PrefService;
 
diff --git a/ash/components/tether/tether_component_impl.h b/ash/components/tether/tether_component_impl.h
index a0a42ce..56e2f86 100644
--- a/ash/components/tether/tether_component_impl.h
+++ b/ash/components/tether/tether_component_impl.h
@@ -15,9 +15,9 @@
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/pref_registry_simple.h"
diff --git a/ash/components/tether/tether_connector.h b/ash/components/tether/tether_connector.h
index 1bae209..d67a8a48 100644
--- a/ash/components/tether/tether_connector.h
+++ b/ash/components/tether/tether_connector.h
@@ -6,7 +6,7 @@
 #define ASH_COMPONENTS_TETHER_TETHER_CONNECTOR_H_
 
 #include "base/callback_forward.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/tether_connector_impl.h b/ash/components/tether/tether_connector_impl.h
index 4c5bd8c..54559f1f 100644
--- a/ash/components/tether/tether_connector_impl.h
+++ b/ash/components/tether/tether_connector_impl.h
@@ -12,7 +12,7 @@
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "ash/services/secure_channel/public/cpp/client/secure_channel_client.h"
 #include "base/memory/weak_ptr.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state_handler.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/ash/components/tether/tether_connector_impl_unittest.cc b/ash/components/tether/tether_connector_impl_unittest.cc
index 28f1833..814fceae 100644
--- a/ash/components/tether/tether_connector_impl_unittest.cc
+++ b/ash/components/tether/tether_connector_impl_unittest.cc
@@ -26,8 +26,8 @@
 #include "base/memory/ptr_util.h"
 #include "base/test/metrics/histogram_tester.h"
 #include "base/test/task_environment.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "testing/gmock/include/gmock/gmock.h"
diff --git a/ash/components/tether/tether_disconnector.h b/ash/components/tether/tether_disconnector.h
index dbd9c72..8d55b72 100644
--- a/ash/components/tether/tether_disconnector.h
+++ b/ash/components/tether/tether_disconnector.h
@@ -11,7 +11,7 @@
 #include "ash/components/tether/tether_session_completion_logger.h"
 #include "base/callback_forward.h"
 #include "base/memory/weak_ptr.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/tether_disconnector_impl.cc b/ash/components/tether/tether_disconnector_impl.cc
index c48a311..5b5ab18 100644
--- a/ash/components/tether/tether_disconnector_impl.cc
+++ b/ash/components/tether/tether_disconnector_impl.cc
@@ -13,7 +13,7 @@
 #include "ash/components/tether/wifi_hotspot_disconnector.h"
 #include "base/metrics/histogram_macros.h"
 #include "base/values.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 
diff --git a/ash/components/tether/wifi_hotspot_connector.cc b/ash/components/tether/wifi_hotspot_connector.cc
index 176e95a6..9adbd47 100644
--- a/ash/components/tether/wifi_hotspot_connector.cc
+++ b/ash/components/tether/wifi_hotspot_connector.cc
@@ -13,7 +13,7 @@
 #include "base/threading/thread_task_runner_handle.h"
 #include "base/time/default_clock.h"
 #include "chromeos/ash/components/network/device_state.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/components/tether/wifi_hotspot_connector.h b/ash/components/tether/wifi_hotspot_connector.h
index 55180b3..8755663 100644
--- a/ash/components/tether/wifi_hotspot_connector.h
+++ b/ash/components/tether/wifi_hotspot_connector.h
@@ -14,7 +14,7 @@
 #include "base/timer/timer.h"
 #include "base/values.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
diff --git a/ash/components/tether/wifi_hotspot_connector_unittest.cc b/ash/components/tether/wifi_hotspot_connector_unittest.cc
index 7e633bde..ad6bd88 100644
--- a/ash/components/tether/wifi_hotspot_connector_unittest.cc
+++ b/ash/components/tether/wifi_hotspot_connector_unittest.cc
@@ -17,8 +17,8 @@
 #include "base/test/test_simple_task_runner.h"
 #include "base/timer/mock_timer.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
-#include "chromeos/network/network_connect.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/shill_property_util.h"
diff --git a/ash/components/tether/wifi_hotspot_disconnector.h b/ash/components/tether/wifi_hotspot_disconnector.h
index 2198ec7..6ab4cfb 100644
--- a/ash/components/tether/wifi_hotspot_disconnector.h
+++ b/ash/components/tether/wifi_hotspot_disconnector.h
@@ -6,7 +6,7 @@
 #define ASH_COMPONENTS_TETHER_WIFI_HOTSPOT_DISCONNECTOR_H_
 
 #include "base/callback.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 namespace ash {
 
diff --git a/ash/components/tether/wifi_hotspot_disconnector_impl.cc b/ash/components/tether/wifi_hotspot_disconnector_impl.cc
index 7a29e38..2c386c76 100644
--- a/ash/components/tether/wifi_hotspot_disconnector_impl.cc
+++ b/ash/components/tether/wifi_hotspot_disconnector_impl.cc
@@ -10,7 +10,7 @@
 #include "base/bind.h"
 #include "base/callback.h"
 #include "base/callback_helpers.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/pref_registry_simple.h"
diff --git a/ash/components/tether/wifi_hotspot_disconnector_impl.h b/ash/components/tether/wifi_hotspot_disconnector_impl.h
index 82f2f00..fac897c 100644
--- a/ash/components/tether/wifi_hotspot_disconnector_impl.h
+++ b/ash/components/tether/wifi_hotspot_disconnector_impl.h
@@ -8,7 +8,7 @@
 #include "ash/components/tether/wifi_hotspot_disconnector.h"
 #include "base/memory/weak_ptr.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/network/network_state_handler.h"
 
diff --git a/ash/components/tether/wifi_hotspot_disconnector_impl_unittest.cc b/ash/components/tether/wifi_hotspot_disconnector_impl_unittest.cc
index c2b3a438..8c090f7 100644
--- a/ash/components/tether/wifi_hotspot_disconnector_impl_unittest.cc
+++ b/ash/components/tether/wifi_hotspot_disconnector_impl_unittest.cc
@@ -11,8 +11,8 @@
 #include "base/bind.h"
 #include "base/memory/ptr_util.h"
 #include "base/test/task_environment.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/sync_preferences/testing_pref_service_syncable.h"
diff --git a/ash/services/cellular_setup/esim_manager.h b/ash/services/cellular_setup/esim_manager.h
index f0dbbaf..b996096 100644
--- a/ash/services/cellular_setup/esim_manager.h
+++ b/ash/services/cellular_setup/esim_manager.h
@@ -20,7 +20,7 @@
 #include "chromeos/dbus/hermes/hermes_manager_client.h"
 #include "chromeos/dbus/hermes/hermes_profile_client.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chromeos/network/network_state_handler.h"
 #include "mojo/public/cpp/bindings/pending_remote.h"
diff --git a/ash/services/cellular_setup/esim_profile.cc b/ash/services/cellular_setup/esim_profile.cc
index 945030a..a2de3db 100644
--- a/ash/services/cellular_setup/esim_profile.cc
+++ b/ash/services/cellular_setup/esim_profile.cc
@@ -18,10 +18,10 @@
 #include "chromeos/ash/components/network/cellular_esim_uninstall_handler.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/hermes_metrics_util.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
 #include "chromeos/dbus/hermes/hermes_profile_client.h"
 #include "chromeos/dbus/hermes/hermes_response_status.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/services/cellular_setup/esim_test_base.cc b/ash/services/cellular_setup/esim_test_base.cc
index 25c1f61..3e0234fd 100644
--- a/ash/services/cellular_setup/esim_test_base.cc
+++ b/ash/services/cellular_setup/esim_test_base.cc
@@ -14,13 +14,13 @@
 #include "chromeos/ash/components/network/cellular_esim_uninstall_handler.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/fake_network_connection_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
 #include "chromeos/dbus/hermes/hermes_manager_client.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/services/cellular_setup/esim_test_base.h b/ash/services/cellular_setup/esim_test_base.h
index 9a11dcf..53a69121 100644
--- a/ash/services/cellular_setup/esim_test_base.h
+++ b/ash/services/cellular_setup/esim_test_base.h
@@ -21,7 +21,7 @@
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chromeos/network/network_device_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
diff --git a/ash/services/cellular_setup/euicc.cc b/ash/services/cellular_setup/euicc.cc
index d7609162..42c4717 100644
--- a/ash/services/cellular_setup/euicc.cc
+++ b/ash/services/cellular_setup/euicc.cc
@@ -20,7 +20,7 @@
 #include "chromeos/ash/components/network/cellular_esim_profile.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/hermes_metrics_util.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/device_event_log/device_event_log.h"
diff --git a/ash/services/cellular_setup/ota_activator_impl.cc b/ash/services/cellular_setup/ota_activator_impl.cc
index a0c550f..9cf6c5e 100644
--- a/ash/services/cellular_setup/ota_activator_impl.cc
+++ b/ash/services/cellular_setup/ota_activator_impl.cc
@@ -13,9 +13,9 @@
 #include "base/metrics/histogram_functions.h"
 #include "chromeos/ash/components/network/cellular_utils.h"
 #include "chromeos/ash/components/network/device_state.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
-#include "chromeos/network/network_activation_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/services/cellular_setup/ota_activator_impl.h b/ash/services/cellular_setup/ota_activator_impl.h
index c014afd5..729ca24 100644
--- a/ash/services/cellular_setup/ota_activator_impl.h
+++ b/ash/services/cellular_setup/ota_activator_impl.h
@@ -16,9 +16,9 @@
 #include "base/time/time.h"
 #include "base/timer/timer.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
-#include "chromeos/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chromeos/network/network_state.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
diff --git a/ash/services/cellular_setup/ota_activator_impl_unittest.cc b/ash/services/cellular_setup/ota_activator_impl_unittest.cc
index 2de61528..d724d41a 100644
--- a/ash/services/cellular_setup/ota_activator_impl_unittest.cc
+++ b/ash/services/cellular_setup/ota_activator_impl_unittest.cc
@@ -14,8 +14,8 @@
 #include "base/test/test_simple_task_runner.h"
 #include "chromeos/ash/components/network/fake_network_activation_handler.h"
 #include "chromeos/ash/components/network/fake_network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "mojo/public/cpp/bindings/remote.h"
 #include "testing/gtest/include/gtest/gtest.h"
diff --git a/ash/strings/ash_strings_km.xtb b/ash/strings/ash_strings_km.xtb
index 6532901..2f115a6 100644
--- a/ash/strings/ash_strings_km.xtb
+++ b/ash/strings/ash_strings_km.xtb
@@ -152,6 +152,7 @@
 <translation id="1771761307086386028">រំកិល​ទៅស្តាំ</translation>
 <translation id="1774796056689732716">ប្រតិទិន, <ph name="CURRENT_MONTH_YEAR" />, បច្ចុប្បន្នបានជ្រើសរើសថ្ងៃទី <ph name="DATE" />។</translation>
 <translation id="1787955149152357925">បិទ</translation>
+<translation id="1797271123677381264">ភ្លេចពាក្យសម្ងាត់</translation>
 <translation id="181103072419391116">កម្លាំង​រលកសញ្ញា <ph name="SIGNAL_STRENGTH" />, គ្រប់គ្រងដោយ​អ្នកគ្រប់គ្រង​របស់អ្នក</translation>
 <translation id="1812997170047690955">តើ​មាន​អ្វី​នៅលើ​អេក្រង់​របស់ខ្ញុំ?</translation>
 <translation id="1823873187264960516">អ៊ីសឺរណិត៖ <ph name="ADDRESS" /></translation>
@@ -609,6 +610,7 @@
 <translation id="4479639480957787382">ខ្សែអ៊ីនធឺណិត</translation>
 <translation id="4481530544597605423">ឧបករណ៍​ដែល​ឈប់​ផ្គូផ្គង</translation>
 <translation id="4505050298327493054">តុសកម្ម។</translation>
+<translation id="450584155212756404">បណ្តាញអ្នកអភិវឌ្ឍន៍</translation>
 <translation id="4513946894732546136">មតិ</translation>
 <translation id="4518404433291145981">ដើម្បី​ដោះសោ Chromebook របស់អ្នក សូមដោះសោទូរសព្ទ​របស់អ្នកជាមុនសិន</translation>
 <translation id="4527045527269911712">ឧបករណ៍ប៊្លូធូស "<ph name="DEVICE_NAME" />" ចង់សុំការអនុញ្ញាតដើម្បីភ្ជាប់។</translation>
@@ -876,6 +878,7 @@
 <translation id="6062360702481658777">អ្នកនឹងចាកចេញដោយស្វ័យប្រវត្តិក្នុង <ph name="LOGOUT_TIME_LEFT" />។</translation>
 <translation id="6064463340679478396">ប្រើឯកសារនេះរួចហើយ</translation>
 <translation id="6073451960410192870">បញ្ឈប់ការថត</translation>
+<translation id="6074087755403037157">បណ្ដាញបេតា</translation>
 <translation id="6099678161144790572">បានកែ​កាលពីខែមុន</translation>
 <translation id="6103838137565245112">ប្រព័ន្ធ</translation>
 <translation id="6114505516289286752">បានទាញយក​ឯកសារនៃការនិយាយ​ជាភាសា<ph name="LANGUAGE" /></translation>
@@ -1226,6 +1229,7 @@
 <translation id="8200772114523450471">បន្ត</translation>
 <translation id="8203795194971602413">ចុចកណ្ដុរខាងស្ដាំ</translation>
 <translation id="8209010265547628927">កំណត់​ឡើងវិញ</translation>
+<translation id="8214996719228530800">បណ្តាញ Canary</translation>
 <translation id="8219451629189078428">Chromebook របស់អ្នកត្រូវបន្តបើក និងភ្ជាប់ទៅថាមពលនៅអំឡុងពេលនេះ។ ត្រូវប្រាកដថា ខ្សែសាក ឬឆ្នាំងសាកត្រូវបានដោតត្រឹមត្រូវ ទាំងនៅលើ Chromebook របស់អ្នក និង​ព្រីភ្លើង។ សូមកុំបិទ Chromebook ​របស់អ្នក។</translation>
 <translation id="8236042855478648955">ដល់​ពេល​សម្រាក​ហើយ</translation>
 <translation id="8247060538831475781"><ph name="CONNECTION_STATUS" />, កម្លាំង​រលកសញ្ញា <ph name="SIGNAL_STRENGTH" />, ថ្មទូរសព្ទ <ph name="BATTERY_STATUS" /></translation>
diff --git a/ash/strings/ash_strings_ky.xtb b/ash/strings/ash_strings_ky.xtb
index 8098749..d2cc24d 100644
--- a/ash/strings/ash_strings_ky.xtb
+++ b/ash/strings/ash_strings_ky.xtb
@@ -713,7 +713,7 @@
 <translation id="5117590920725113268">Кийинки айды көрсөтүү</translation>
 <translation id="5136175204352732067">Башка баскычтоп туташтырылды</translation>
 <translation id="5147567197700016471">Кулпусу ачык</translation>
-<translation id="5150070631291639005">Купуялык жөндөөлөрү</translation>
+<translation id="5150070631291639005">Купуялык параметрлери</translation>
 <translation id="5155897006997040331">Окуу ылдамдыгы</translation>
 <translation id="5166007464919321363">Иш тактаны үлгү катары сактоо</translation>
 <translation id="5168181903108465623">Тышкы экранга чыгаруу түзмөктөрү жеткиликтүү</translation>
diff --git a/ash/strings/ash_strings_uz.xtb b/ash/strings/ash_strings_uz.xtb
index 718970e..269bdcf 100644
--- a/ash/strings/ash_strings_uz.xtb
+++ b/ash/strings/ash_strings_uz.xtb
@@ -152,6 +152,7 @@
 <translation id="1771761307086386028">Oʻngga aylantirish</translation>
 <translation id="1774796056689732716">Taqvim, <ph name="CURRENT_MONTH_YEAR" />, hozir <ph name="DATE" /> tanlangan.</translation>
 <translation id="1787955149152357925">Yoqilmagan</translation>
+<translation id="1797271123677381264">Parolni unutdim</translation>
 <translation id="181103072419391116">Signal darajasi: <ph name="SIGNAL_STRENGTH" />, Administrator boshqaruvida</translation>
 <translation id="1812997170047690955">Ekranda nimalar bor?</translation>
 <translation id="1823873187264960516">Ethernet: <ph name="ADDRESS" /></translation>
@@ -609,6 +610,7 @@
 <translation id="4479639480957787382">Ethernet</translation>
 <translation id="4481530544597605423">Uzilgan qurilmalar</translation>
 <translation id="4505050298327493054">Faol ish stoli.</translation>
+<translation id="450584155212756404">Dasturchilar kanali</translation>
 <translation id="4513946894732546136">Fikr-mulohaza</translation>
 <translation id="4518404433291145981">Chromebook qulfini ochish uchun telefon qulfini yeching</translation>
 <translation id="4527045527269911712">“<ph name="DEVICE_NAME" />” qurilmasi Bluetooth orqali bog‘lanishga ruxsat so‘ramoqda.</translation>
@@ -876,6 +878,7 @@
 <translation id="6062360702481658777"><ph name="LOGOUT_TIME_LEFT" />dan keyin tizimdan avtomatik ravishda chiqiladi.</translation>
 <translation id="6064463340679478396">Bu fayldan foydalanmayman</translation>
 <translation id="6073451960410192870">Yozuvni toʻxtatish</translation>
+<translation id="6074087755403037157">Beta kanal</translation>
 <translation id="6099678161144790572">Oxirgi oyda tahrirlangan</translation>
 <translation id="6103838137565245112">tizim</translation>
 <translation id="6114505516289286752"><ph name="LANGUAGE" /> nutq fayllari yuklab olindi</translation>
@@ -1226,6 +1229,7 @@
 <translation id="8200772114523450471">Davom ettirish</translation>
 <translation id="8203795194971602413">Oʻng klik</translation>
 <translation id="8209010265547628927">Asliga qaytarish</translation>
+<translation id="8214996719228530800">Canary kanali</translation>
 <translation id="8219451629189078428">Bu vaqt orasida Chromebook yoniq va quvvat manbasiga ulangan boʻlishi kerak. Quvvatlagich va kabel adapterlari Chromebook va rozetkaga ulanganini tekshiring. Chromebook qurilmasini oʻchirmang.</translation>
 <translation id="8236042855478648955">Tanaffus qilish vaqti keldi</translation>
 <translation id="8247060538831475781">Ulanish: <ph name="CONNECTION_STATUS" />, Signal darajasi: <ph name="SIGNAL_STRENGTH" />, Telefon quvvati: <ph name="BATTERY_STATUS" /></translation>
diff --git a/ash/strings/ash_strings_zh-HK.xtb b/ash/strings/ash_strings_zh-HK.xtb
index 437125e..9a9953c 100644
--- a/ash/strings/ash_strings_zh-HK.xtb
+++ b/ash/strings/ash_strings_zh-HK.xtb
@@ -612,7 +612,7 @@
 <translation id="4513946894732546136">意見反映</translation>
 <translation id="4518404433291145981">如要解鎖 Chromebook,請先解鎖手機</translation>
 <translation id="4527045527269911712">藍牙裝置「<ph name="DEVICE_NAME" />」要求配對權限。</translation>
-<translation id="4533343294786968049">延長電池續航力。電池電量將在<ph name="FULLY_CHARGE_TIME" /> 充飽。</translation>
+<translation id="4533343294786968049">正在延長電池壽命。電池將會在<ph name="FULLY_CHARGE_TIME" /> 時完全充滿。</translation>
 <translation id="453661520163887813">還有 <ph name="TIME" />便完成充電</translation>
 <translation id="4538824937723742295">擷取全螢幕截圖</translation>
 <translation id="4544483149666270818">選取要錄影的視窗</translation>
diff --git a/ash/system/network/auto_connect_notifier.cc b/ash/system/network/auto_connect_notifier.cc
index 5d2961b..2b4ca90d 100644
--- a/ash/system/network/auto_connect_notifier.cc
+++ b/ash/system/network/auto_connect_notifier.cc
@@ -14,7 +14,7 @@
 #include "base/logging.h"
 #include "base/time/time.h"
 #include "base/timer/timer.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/system/network/auto_connect_notifier.h b/ash/system/network/auto_connect_notifier.h
index 03d6edb..756b639 100644
--- a/ash/system/network/auto_connect_notifier.h
+++ b/ash/system/network/auto_connect_notifier.h
@@ -10,7 +10,7 @@
 
 #include "ash/ash_export.h"
 #include "chromeos/ash/components/network/auto_connect_handler.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler_observer.h"
 
 namespace base {
diff --git a/ash/system/network/auto_connect_notifier_unittest.cc b/ash/system/network/auto_connect_notifier_unittest.cc
index ceec050..1ea6737b 100644
--- a/ash/system/network/auto_connect_notifier_unittest.cc
+++ b/ash/system/network/auto_connect_notifier_unittest.cc
@@ -16,9 +16,9 @@
 #include "base/run_loop.h"
 #include "base/timer/mock_timer.h"
 #include "chromeos/ash/components/network/auto_connect_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_test_helper.h"
diff --git a/ash/system/network/cellular_setup_notifier_unittest.cc b/ash/system/network/cellular_setup_notifier_unittest.cc
index f667792..efb115e 100644
--- a/ash/system/network/cellular_setup_notifier_unittest.cc
+++ b/ash/system/network/cellular_setup_notifier_unittest.cc
@@ -12,9 +12,9 @@
 #include "base/bind.h"
 #include "base/run_loop.h"
 #include "base/timer/mock_timer.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/shill/shill_clients.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_test_helper.h"
diff --git a/ash/system/network/network_detailed_view_controller.cc b/ash/system/network/network_detailed_view_controller.cc
index b19d9aa8..0caeff45 100644
--- a/ash/system/network/network_detailed_view_controller.cc
+++ b/ash/system/network/network_detailed_view_controller.cc
@@ -16,7 +16,7 @@
 #include "ash/system/network/tray_network_state_model.h"
 #include "ash/system/tray/detailed_view_delegate.h"
 #include "base/metrics/user_metrics.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_util.h"
 #include "chromeos/services/network_config/public/mojom/cros_network_config.mojom.h"
 #include "ui/base/l10n/l10n_util.h"
diff --git a/ash/system/network/network_detailed_view_controller_unittest.cc b/ash/system/network/network_detailed_view_controller_unittest.cc
index 364543d..2dc00f1 100644
--- a/ash/system/network/network_detailed_view_controller_unittest.cc
+++ b/ash/system/network/network_detailed_view_controller_unittest.cc
@@ -13,7 +13,7 @@
 #include "ash/test/ash_test_helper.h"
 #include "base/test/metrics/user_action_tester.h"
 #include "base/test/scoped_feature_list.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/services/bluetooth_config/fake_adapter_state_controller.h"
diff --git a/ash/system/network/network_state_list_detailed_view.cc b/ash/system/network/network_state_list_detailed_view.cc
index dbce20d7..dff0366 100644
--- a/ash/system/network/network_state_list_detailed_view.cc
+++ b/ash/system/network/network_state_list_detailed_view.cc
@@ -20,7 +20,7 @@
 #include "base/strings/utf_string_conversions.h"
 #include "base/threading/thread_task_runner_handle.h"
 #include "base/time/time.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/services/network_config/public/mojom/cros_network_config.mojom.h"
 #include "net/base/ip_address.h"
 #include "third_party/cros_system_api/dbus/service_constants.h"
diff --git a/ash/system/network/vpn_list_view.cc b/ash/system/network/vpn_list_view.cc
index 02dc280..e86232f 100644
--- a/ash/system/network/vpn_list_view.cc
+++ b/ash/system/network/vpn_list_view.cc
@@ -30,7 +30,7 @@
 #include "base/bind.h"
 #include "base/metrics/user_metrics.h"
 #include "base/strings/utf_string_conversions.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_util.h"
 #include "chromeos/services/network_config/public/mojom/cros_network_config.mojom.h"
 #include "components/onc/onc_constants.h"
diff --git a/ash/webui/camera_app_ui/resources/strings/camera_strings_zh-HK.xtb b/ash/webui/camera_app_ui/resources/strings/camera_strings_zh-HK.xtb
index 32f1a827..4c872e6 100644
--- a/ash/webui/camera_app_ui/resources/strings/camera_strings_zh-HK.xtb
+++ b/ash/webui/camera_app_ui/resources/strings/camera_strings_zh-HK.xtb
@@ -72,7 +72,7 @@
 <translation id="3838931309141338733">掃描條碼</translation>
 <translation id="3892148308691398805">複製文字</translation>
 <translation id="4061162772429051350"><ph name="MAGAPIXELS_AMOUNT" /> 百萬像素</translation>
-<translation id="4096701159033358951">正在下載文件掃描功能</translation>
+<translation id="4096701159033358951">正在下載文件掃瞄功能</translation>
 <translation id="4118525110028899586">暫停錄影</translation>
 <translation id="4121305183798804752">偵測到文件</translation>
 <translation id="414641094616694804">此相機無法變更解像度</translation>
diff --git a/ash/webui/diagnostics_ui/backend/network_health_provider_unittest.cc b/ash/webui/diagnostics_ui/backend/network_health_provider_unittest.cc
index 59de623..431123d 100644
--- a/ash/webui/diagnostics_ui/backend/network_health_provider_unittest.cc
+++ b/ash/webui/diagnostics_ui/backend/network_health_provider_unittest.cc
@@ -13,11 +13,11 @@
 #include "base/test/task_environment.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/dbus/shill/shill_ipconfig_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/ash/webui/shimless_rma/DEPS b/ash/webui/shimless_rma/DEPS
index 34d10467..5db3523 100644
--- a/ash/webui/shimless_rma/DEPS
+++ b/ash/webui/shimless_rma/DEPS
@@ -2,7 +2,7 @@
   "+chromeos/dbus",
   "+chromeos/dbus/power",
   "+chromeos/ash/components/dbus/rmad",
-  "+chromeos/dbus/update_engine",
+  "+chromeos/ash/components/dbus/update_engine",
   "+chromeos/dbus/util",
   "+chromeos/login/login_state",
   "+chromeos/services/network_config",
diff --git a/ash/webui/shimless_rma/backend/BUILD.gn b/ash/webui/shimless_rma/backend/BUILD.gn
index 066fe666..c7a703ec 100644
--- a/ash/webui/shimless_rma/backend/BUILD.gn
+++ b/ash/webui/shimless_rma/backend/BUILD.gn
@@ -20,10 +20,10 @@
     "//ash/webui/shimless_rma/mojom",
     "//chromeos/ash/components/dbus/rmad",
     "//chromeos/ash/components/dbus/rmad:rmad_proto",
+    "//chromeos/ash/components/dbus/update_engine",
+    "//chromeos/ash/components/dbus/update_engine:proto",
     "//chromeos/dbus",
     "//chromeos/dbus/power",
-    "//chromeos/dbus/update_engine",
-    "//chromeos/dbus/update_engine:proto",
     "//chromeos/dbus/util",
     "//chromeos/network:network",
     "//chromeos/services/network_config:in_process_instance",
@@ -48,9 +48,9 @@
     "//base/test:test_support",
     "//chromeos/ash/components/dbus/rmad",
     "//chromeos/ash/components/dbus/rmad:rmad_proto",
+    "//chromeos/ash/components/dbus/update_engine:update_engine",
     "//chromeos/ash/components/network:test_support",
     "//chromeos/dbus:test_support",
-    "//chromeos/dbus/update_engine:update_engine",
     "//chromeos/login/login_state:login_state",
     "//chromeos/network:network",
     "//chromeos/services/network_config/public/cpp:test_support",
diff --git a/ash/webui/shimless_rma/backend/shimless_rma_service.h b/ash/webui/shimless_rma/backend/shimless_rma_service.h
index 01ca418..dddf80e5 100644
--- a/ash/webui/shimless_rma/backend/shimless_rma_service.h
+++ b/ash/webui/shimless_rma/backend/shimless_rma_service.h
@@ -14,7 +14,7 @@
 #include "base/containers/flat_set.h"
 #include "chromeos/ash/components/dbus/rmad/rmad.pb.h"
 #include "chromeos/ash/components/dbus/rmad/rmad_client.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
 #include "chromeos/services/network_config/public/mojom/cros_network_config.mojom.h"
 #include "mojo/public/cpp/bindings/pending_receiver.h"
 #include "mojo/public/cpp/bindings/receiver.h"
diff --git a/ash/webui/shimless_rma/backend/shimless_rma_service_unittest.cc b/ash/webui/shimless_rma/backend/shimless_rma_service_unittest.cc
index 94e2357..523117e 100644
--- a/ash/webui/shimless_rma/backend/shimless_rma_service_unittest.cc
+++ b/ash/webui/shimless_rma/backend/shimless_rma_service_unittest.cc
@@ -19,13 +19,13 @@
 #include "base/test/task_environment.h"
 #include "chromeos/ash/components/dbus/rmad/fake_rmad_client.h"
 #include "chromeos/ash/components/dbus/rmad/rmad_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_type_pattern.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_test_helper.h"
@@ -120,7 +120,7 @@
   void SetUp() override {
     chromeos::DBusThreadManager::Initialize();
     // VersionUpdater depends on UpdateEngineClient.
-    chromeos::UpdateEngineClient::InitializeFake();
+    UpdateEngineClient::InitializeFake();
 
     SetupFakeNetwork();
     FakeRmadClientForTest::Initialize();
@@ -145,7 +145,7 @@
     NetworkHandler::Shutdown();
     cros_network_config_test_helper_.reset();
     chromeos::LoginState::Shutdown();
-    chromeos::UpdateEngineClient::Shutdown();
+    UpdateEngineClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/ash/webui/shimless_rma/backend/version_updater.cc b/ash/webui/shimless_rma/backend/version_updater.cc
index f7065c0..eabe016 100644
--- a/ash/webui/shimless_rma/backend/version_updater.cc
+++ b/ash/webui/shimless_rma/backend/version_updater.cc
@@ -5,8 +5,8 @@
 #include "ash/webui/shimless_rma/backend/version_updater.h"
 
 #include "base/logging.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_type_pattern.h"
@@ -199,7 +199,7 @@
 
 void VersionUpdater::OnRequestUpdateCheck(
     UpdateEngineClient::UpdateCheckResult result) {
-  if (result != chromeos::UpdateEngineClient::UPDATE_RESULT_SUCCESS) {
+  if (result != UpdateEngineClient::UPDATE_RESULT_SUCCESS) {
     LOG(ERROR) << "OS update request failed.";
     ReportUpdateFailure(status_callback_, update_engine::REPORTING_ERROR_EVENT,
                         update_engine::ErrorCode::kDownloadTransferError);
diff --git a/ash/webui/shimless_rma/backend/version_updater.h b/ash/webui/shimless_rma/backend/version_updater.h
index ebfc008f..25aa389 100644
--- a/ash/webui/shimless_rma/backend/version_updater.h
+++ b/ash/webui/shimless_rma/backend/version_updater.h
@@ -8,8 +8,8 @@
 #include <string>
 
 #include "base/callback.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 namespace ash {
 namespace shimless_rma {
@@ -17,7 +17,7 @@
 // TODO(gavindodd): Consider if this can be shared with
 // chrome/browser/ash/login/version_updater/version_updater
 
-class VersionUpdater : public chromeos::UpdateEngineClient::Observer {
+class VersionUpdater : public UpdateEngineClient::Observer {
  public:
   typedef base::RepeatingCallback<void(update_engine::Operation operation,
                                        double progress,
@@ -44,8 +44,7 @@
 
  private:
   // Callback from UpdateEngineClient::RequestUpdateCheck().
-  void OnRequestUpdateCheck(
-      chromeos::UpdateEngineClient::UpdateCheckResult result);
+  void OnRequestUpdateCheck(UpdateEngineClient::UpdateCheckResult result);
 
   // UpdateEngineClient::Observer implementation.
   void UpdateStatusChanged(const update_engine::StatusResult& status) override;
diff --git a/ash/webui/shimless_rma/backend/version_updater_unittest.cc b/ash/webui/shimless_rma/backend/version_updater_unittest.cc
index c6f5fc4..6f876963 100644
--- a/ash/webui/shimless_rma/backend/version_updater_unittest.cc
+++ b/ash/webui/shimless_rma/backend/version_updater_unittest.cc
@@ -8,17 +8,17 @@
 
 #include "base/bind.h"
 #include "base/test/task_environment.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_certificate_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/ash/webui/shimless_rma/mojom/BUILD.gn b/ash/webui/shimless_rma/mojom/BUILD.gn
index 91f81c5..f08f8dbc 100644
--- a/ash/webui/shimless_rma/mojom/BUILD.gn
+++ b/ash/webui/shimless_rma/mojom/BUILD.gn
@@ -97,14 +97,14 @@
       traits_headers = [
         "shimless_rma_mojom_traits.h",
         "//chromeos/ash/components/dbus/rmad/rmad.pb.h",
-        "//chromeos/dbus/update_engine/update_engine.pb.h",
-        "//chromeos/dbus/update_engine/update_engine_client.h",
+        "//chromeos/ash/components/dbus/update_engine/update_engine.pb.h",
+        "//chromeos/ash/components/dbus/update_engine/update_engine_client.h",
       ]
       traits_sources = [ "shimless_rma_mojom_traits.cc" ]
       traits_public_deps = [
         "//chromeos/ash/components/dbus/rmad:rmad_proto",
-        "//chromeos/dbus/update_engine:proto",
-        "//chromeos/dbus/update_engine:update_engine",
+        "//chromeos/ash/components/dbus/update_engine:proto",
+        "//chromeos/ash/components/dbus/update_engine:update_engine",
         "//dbus",
       ]
     },
@@ -122,7 +122,7 @@
     "//base/test:test_support",
     "//chromeos/ash/components/dbus/rmad",
     "//chromeos/ash/components/dbus/rmad:rmad_proto",
-    "//chromeos/dbus/update_engine",
+    "//chromeos/ash/components/dbus/update_engine",
     "//content/test:test_support",
     "//services/data_decoder/public/cpp:test_support",
     "//services/device/public/cpp:test_support",
diff --git a/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.cc b/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.cc
index 4ff89ba..b1d4f1a 100644
--- a/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.cc
+++ b/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.cc
@@ -8,8 +8,8 @@
 
 #include "base/notreached.h"
 #include "chromeos/ash/components/dbus/rmad/rmad.pb.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "mojo/public/cpp/bindings/enum_traits.h"
 
 namespace mojo {
diff --git a/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.h b/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.h
index 87ceb83..9954df72 100644
--- a/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.h
+++ b/ash/webui/shimless_rma/mojom/shimless_rma_mojom_traits.h
@@ -7,8 +7,8 @@
 
 #include "ash/webui/shimless_rma/mojom/shimless_rma.mojom.h"
 #include "chromeos/ash/components/dbus/rmad/rmad.pb.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "mojo/public/cpp/bindings/enum_traits.h"
 
 namespace mojo {
diff --git a/base/allocator/partition_allocator/address_pool_manager.h b/base/allocator/partition_allocator/address_pool_manager.h
index b6871be7..ed674cc3 100644
--- a/base/allocator/partition_allocator/address_pool_manager.h
+++ b/base/allocator/partition_allocator/address_pool_manager.h
@@ -21,13 +21,6 @@
 #include "base/allocator/partition_allocator/partition_lock.h"
 #include "build/build_config.h"
 
-namespace base {
-
-template <typename Type>
-struct LazyInstanceTraitsBase;
-
-}  // namespace base
-
 namespace partition_alloc {
 
 class AddressSpaceStatsDumper;
@@ -166,8 +159,6 @@
 #endif  // defined(PA_HAS_64_BITS_POINTERS)
 
   static AddressPoolManager singleton_;
-
-  friend struct base::LazyInstanceTraitsBase<AddressPoolManager>;
 };
 
 PA_ALWAYS_INLINE pool_handle GetRegularPool() {
diff --git a/base/allocator/partition_allocator/partition_alloc_base/migration_adapter.h b/base/allocator/partition_allocator/partition_alloc_base/migration_adapter.h
index ee0cb382..695d977 100644
--- a/base/allocator/partition_allocator/partition_alloc_base/migration_adapter.h
+++ b/base/allocator/partition_allocator/partition_alloc_base/migration_adapter.h
@@ -9,12 +9,6 @@
 
 class LapTimer;
 
-template <typename Type, typename Traits>
-class LazyInstance;
-
-template <typename Type>
-struct LazyInstanceTraitsBase;
-
 }  // namespace base
 
 namespace partition_alloc::internal::base {
@@ -22,8 +16,6 @@
 // TODO(https://crbug.com/1288247): Remove these 'using' declarations once
 // the migration to the new namespaces gets done.
 using ::base::LapTimer;
-using ::base::LazyInstance;
-using ::base::LazyInstanceTraitsBase;
 
 }  // namespace partition_alloc::internal::base
 
diff --git a/base/allocator/partition_allocator/partition_alloc_base/time/time_win.cc b/base/allocator/partition_allocator/partition_alloc_base/time/time_win.cc
index e36aeb6..7deae93 100644
--- a/base/allocator/partition_allocator/partition_alloc_base/time/time_win.cc
+++ b/base/allocator/partition_allocator/partition_alloc_base/time/time_win.cc
@@ -327,7 +327,7 @@
 // "rollover" counter.
 union LastTimeAndRolloversState {
   // The state as a single 32-bit opaque value.
-  std::atomic<int32_t> as_opaque_32;
+  std::atomic<int32_t> as_opaque_32{0};
 
   // The state as usable values.
   struct {
diff --git a/base/third_party/libevent/BUILD.gn b/base/third_party/libevent/BUILD.gn
deleted file mode 100644
index c66c345..0000000
--- a/base/third_party/libevent/BUILD.gn
+++ /dev/null
@@ -1,8 +0,0 @@
-# Copyright (c) 2013 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-group("libevent") {
-  # TODO(https://crbug.com/1335194): Remove this when WebRTC migrates.
-  public_deps = [ "//third_party/libevent" ]
-}
diff --git a/base/third_party/libevent/event.h b/base/third_party/libevent/event.h
deleted file mode 100644
index 8f2a899..0000000
--- a/base/third_party/libevent/event.h
+++ /dev/null
@@ -1,11 +0,0 @@
-// Copyright 2022 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-// TODO(https://crbug.com/1335194): Remove this when WebRTC migrates.
-#ifndef BASE_THIRD_PARTY_LIBEVENT_EVENT_H_
-#define BASE_THIRD_PARTY_LIBEVENT_EVENT_H_
-
-#include "third_party/libevent/event.h"
-
-#endif  // BASE_THIRD_PARTY_LIBEVENT_EVENT_H_
diff --git a/cc/paint/oop_pixeltest.cc b/cc/paint/oop_pixeltest.cc
index 16ba3386..dc214fd 100644
--- a/cc/paint/oop_pixeltest.cc
+++ b/cc/paint/oop_pixeltest.cc
@@ -2236,13 +2236,24 @@
   SkBitmap expected_bitmap;
   expected_bitmap.allocN32Pixels(options.resource_size.width(),
                                  options.resource_size.height());
+
+  for (auto& backend : backend_textures) {
+    GrGLTextureInfo info;
+    if (backend.getGLTextureInfo(&info)) {
+      gl->BeginSharedImageAccessDirectCHROMIUM(
+          info.fID, GL_SHARED_IMAGE_ACCESS_MODE_READ_CHROMIUM);
+    }
+  }
+
   expected_image->readPixels(expected_bitmap.pixmap(), 0, 0);
   ExpectEquals(actual_bitmap, expected_bitmap);
 
   for (auto& backend : backend_textures) {
     GrGLTextureInfo info;
-    if (backend.getGLTextureInfo(&info))
+    if (backend.getGLTextureInfo(&info)) {
+      gl->EndSharedImageAccessDirectCHROMIUM(info.fID);
       gl->DeleteTextures(1, &info.fID);
+    }
   }
 
   gpu::SyncToken sync_token;
@@ -2356,13 +2367,24 @@
   SkBitmap expected_bitmap;
   expected_bitmap.allocN32Pixels(options.resource_size.width(),
                                  options.resource_size.height());
+
+  for (auto& backend : backend_textures) {
+    GrGLTextureInfo info;
+    if (backend.getGLTextureInfo(&info)) {
+      gl->BeginSharedImageAccessDirectCHROMIUM(
+          info.fID, GL_SHARED_IMAGE_ACCESS_MODE_READ_CHROMIUM);
+    }
+  }
+
   expected_image->readPixels(expected_bitmap.pixmap(), 0, 0);
   ExpectEquals(actual_bitmap, expected_bitmap);
 
   for (auto& backend : backend_textures) {
     GrGLTextureInfo info;
-    if (backend.getGLTextureInfo(&info))
+    if (backend.getGLTextureInfo(&info)) {
+      gl->EndSharedImageAccessDirectCHROMIUM(info.fID);
       gl->DeleteTextures(1, &info.fID);
+    }
   }
 
   gpu::SyncToken sync_token;
diff --git a/chrome/VERSION b/chrome/VERSION
index 4aedad7..522efe0 100644
--- a/chrome/VERSION
+++ b/chrome/VERSION
@@ -1,4 +1,4 @@
 MAJOR=105
 MINOR=0
-BUILD=5159
+BUILD=5160
 PATCH=0
diff --git a/chrome/android/features/tab_ui/BUILD.gn b/chrome/android/features/tab_ui/BUILD.gn
index da3f84f..ece1aaa2 100644
--- a/chrome/android/features/tab_ui/BUILD.gn
+++ b/chrome/android/features/tab_ui/BUILD.gn
@@ -105,6 +105,7 @@
     "java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardView.java",
     "java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewBinder.java",
     "java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewProperties.java",
+    "java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewUtils.java",
     "java/src/org/chromium/chrome/browser/tasks/tab_management/MessageService.java",
     "java/src/org/chromium/chrome/browser/tasks/tab_management/MultiThumbnailCardProvider.java",
     "java/src/org/chromium/chrome/browser/tasks/tab_management/NewTabTileCoordinator.java",
diff --git a/chrome/android/features/tab_ui/java/res/layout/large_message_card_item.xml b/chrome/android/features/tab_ui/java/res/layout/large_message_card_item.xml
index 7398459..967c636c 100644
--- a/chrome/android/features/tab_ui/java/res/layout/large_message_card_item.xml
+++ b/chrome/android/features/tab_ui/java/res/layout/large_message_card_item.xml
@@ -18,6 +18,7 @@
             android:id="@+id/large_message_linear_layout"
             android:layout_width="match_parent"
             android:layout_height="match_parent"
+            android:layout_marginBottom="16dp"
             android:orientation="vertical">
             <org.chromium.chrome.browser.tasks.tab_management.PriceCardView
                 android:id="@+id/price_info_box"
@@ -62,12 +63,19 @@
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
                 android:layout_marginTop="16dp"
-                android:layout_marginBottom="16dp"
                 android:layout_marginStart="24dp"
                 android:layout_marginEnd="24dp"
                 android:layout_gravity="center"
                 android:paddingTop="8dp"
                 android:paddingBottom="8dp" />
+            <org.chromium.ui.widget.ButtonCompat
+                android:id="@+id/secondary_action_button"
+                style="@style/TextButton"
+                android:layout_width="match_parent"
+                android:layout_height="wrap_content"
+                android:layout_gravity="center"
+                android:layout_marginTop="8dp"
+                android:visibility="gone" />
         </LinearLayout>
         <org.chromium.ui.widget.ChromeImageView
             android:id="@+id/close_button"
diff --git a/chrome/android/features/tab_ui/java/res/values/dimens.xml b/chrome/android/features/tab_ui/java/res/values/dimens.xml
index 14195a21..f085615 100644
--- a/chrome/android/features/tab_ui/java/res/values/dimens.xml
+++ b/chrome/android/features/tab_ui/java/res/values/dimens.xml
@@ -23,8 +23,8 @@
     <dimen name="tab_grid_iph_dialog_text_top_margin_landscape">8dp</dimen>
     <dimen name="tab_grid_iph_dialog_text_top_margin_portrait">16dp</dimen>
     <dimen name="tab_grid_iph_dialog_text_side_margin">32dp</dimen>
-    <dimen name="tab_grid_merge_threshold">45dp</dimen>
     <dimen name="tab_grid_large_message_side_padding_landscape">114dp</dimen>
+    <dimen name="tab_grid_merge_threshold">45dp</dimen>
     <dimen name="tab_grid_thumbnail_card_default_size">152dp</dimen>
     <dimen name="tab_grid_thumbnail_favicon_frame_corner_radius">7dp</dimen>
     <dimen name="tab_grid_thumbnail_favicon_frame_size">24dp</dimen>
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardView.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardView.java
index 8b0a449..11c6db3 100644
--- a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardView.java
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardView.java
@@ -5,6 +5,7 @@
 package org.chromium.chrome.browser.tasks.tab_management;
 
 import android.content.Context;
+import android.content.res.ColorStateList;
 import android.content.res.Configuration;
 import android.graphics.Bitmap;
 import android.graphics.BitmapFactory;
@@ -20,7 +21,10 @@
 import org.chromium.chrome.browser.tab.state.ShoppingPersistedTabData;
 import org.chromium.chrome.browser.util.ChromeAccessibilityUtil;
 import org.chromium.chrome.tab_ui.R;
+import org.chromium.components.browser_ui.styles.ChromeColors;
+import org.chromium.components.browser_ui.widget.MaterialCardViewNoShadow;
 import org.chromium.components.browser_ui.widget.textbubble.TextBubble;
+import org.chromium.ui.base.ViewUtils;
 import org.chromium.ui.widget.ButtonCompat;
 import org.chromium.ui.widget.ChromeImageView;
 import org.chromium.ui.widget.ViewRectProvider;
@@ -36,11 +40,13 @@
 
     private final Context mContext;
     private final int mLandscapeSidePadding;
+    private MaterialCardViewNoShadow mMaterialCardViewNoShadow;
     private PriceCardView mPriceInfoBox;
     private ChromeImageView mIcon;
     private TextView mTitle;
     private TextView mDescription;
     private ButtonCompat mActionButton;
+    private ButtonCompat mSecondaryActionButton;
     private ChromeImageView mCloseButton;
 
     public LargeMessageCardView(Context context, AttributeSet attrs) {
@@ -54,11 +60,13 @@
     protected void onFinishInflate() {
         super.onFinishInflate();
 
+        mMaterialCardViewNoShadow = findViewById(R.id.large_message_card_view);
         mPriceInfoBox = findViewById(R.id.price_info_box);
         mIcon = findViewById(R.id.icon);
         mTitle = findViewById(R.id.title);
         mDescription = findViewById(R.id.description);
         mActionButton = findViewById(R.id.action_button);
+        mSecondaryActionButton = findViewById(R.id.secondary_action_button);
         mCloseButton = findViewById(R.id.close_button);
 
         if (sCloseButtonBitmapWeakRef == null || sCloseButtonBitmapWeakRef.get() == null) {
@@ -102,6 +110,17 @@
     }
 
     /**
+     * Set text for the secondary action button and toggles the visibility to VISIBLE if GONE.
+     * @param secondaryActionText Text to be displayed.
+     */
+    void setSecondaryActionText(String secondaryActionText) {
+        if (mSecondaryActionButton.getVisibility() == View.GONE) {
+            mSecondaryActionButton.setVisibility(View.VISIBLE);
+        }
+        mSecondaryActionButton.setText(secondaryActionText);
+    }
+
+    /**
      * Set click listener for the action button.
      * @param listener {@link android.view.View.OnClickListener} for the action button.
      */
@@ -110,6 +129,14 @@
     }
 
     /**
+     * Set click listener for the secondary action button.
+     * @param listener {@link android.view.View.OnClickListener} for the secondary action button.
+     */
+    void setSecondaryActionButtonOnClickListener(OnClickListener listener) {
+        mSecondaryActionButton.setOnClickListener(listener);
+    }
+
+    /**
      * Set content description for dismiss button.
      * @param description The content description.
      */
@@ -157,6 +184,18 @@
         }
     }
 
+    /**
+     * Set close button visibility.
+     * @param visible Whether icon is visible.
+     */
+    void setCloseButtonVisibility(boolean visible) {
+        if (visible) {
+            mCloseButton.setVisibility(View.VISIBLE);
+        } else {
+            mCloseButton.setVisibility(View.GONE);
+        }
+    }
+
     @VisibleForTesting
     void updateWidthWithOrientation(int orientation) {
         if (orientation == Configuration.ORIENTATION_PORTRAIT) {
@@ -181,4 +220,57 @@
         textBubble.setDismissOnTouchInteraction(true);
         textBubble.show();
     }
+
+    /**
+     * Update Message Card when switching between normal mode and incognito mode.
+     *
+     * @param isIncognito Whether it is in the incognito mode.
+     */
+    void updateMessageCardColor(boolean isIncognito) {
+        setBackground(isIncognito);
+        MessageCardViewUtils.setTitleTextAppearance(
+                mTitle, isIncognito, /*isLargeMessageCard=*/true);
+        MessageCardViewUtils.setDescriptionTextAppearance(
+                mDescription, isIncognito, /*isLargeMessageCard=*/true);
+        MessageCardViewUtils.setActionButtonTextAppearance(
+                mActionButton, isIncognito, /*isLargeMessageCard=*/true);
+        MessageCardViewUtils.setSecondaryActionButtonColor(mSecondaryActionButton, isIncognito);
+        MessageCardViewUtils.setCloseButtonTint(mCloseButton, isIncognito);
+    }
+
+    /**
+     * Update the icon's width.
+     *
+     * TODO(crbug.com/1227656): Confirm with UX, whether large message card can follow a general
+     * icon size for all clients. If so, then remove this method.
+     *
+     * @param width The desired width to set.
+     */
+    void updateIconWidth(int width) {
+        mIcon.getLayoutParams().width = ViewUtils.dpToPx(mContext, width);
+    }
+
+    /**
+     * Update the icon's height.
+     *
+     * TODO(crbug.com/1227656): Confirm with UX, whether large message card can follow a general
+     * icon size for all clients. If so, then remove this method.
+     *
+     * @param height The desired height to set.
+     */
+    void updateIconHeight(int height) {
+        mIcon.getLayoutParams().height = ViewUtils.dpToPx(mIcon.getContext(), height);
+    }
+
+    /**
+     * Set background resource.
+     *
+     * @param isIncognito Whether the resource is used for incognito mode.
+     */
+    private void setBackground(boolean isIncognito) {
+        ColorStateList backgroundTint = ColorStateList.valueOf((isIncognito)
+                        ? mContext.getColor(R.color.incognito_card_bg_color)
+                        : ChromeColors.getSurfaceColor(mContext, R.dimen.card_elevation));
+        mMaterialCardViewNoShadow.setBackgroundTintList(backgroundTint);
+    }
 }
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinder.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinder.java
index 64c14bc..1ee4b849 100644
--- a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinder.java
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinder.java
@@ -34,6 +34,12 @@
                     model.get(MessageCardViewProperties.DISMISS_BUTTON_CONTENT_DESCRIPTION));
             itemView.setDismissButtonOnClickListener(
                     v -> { LargeMessageCardViewBinder.handleDismissActionButton(model); });
+        } else if (MessageCardViewProperties.SECONDARY_ACTION_TEXT == propertyKey) {
+            itemView.setSecondaryActionText(
+                    model.get(MessageCardViewProperties.SECONDARY_ACTION_TEXT));
+        } else if (MessageCardViewProperties.SECONDARY_ACTION_BUTTON_CLICK_HANDLER == propertyKey) {
+            itemView.setSecondaryActionButtonOnClickListener(
+                    model.get(MessageCardViewProperties.SECONDARY_ACTION_BUTTON_CLICK_HANDLER));
         } else if (MessageCardViewProperties.PRICE_DROP == propertyKey) {
             itemView.setupPriceInfoBox(model.get(MessageCardViewProperties.PRICE_DROP));
         } else if (MessageCardViewProperties.ICON_PROVIDER == propertyKey) {
@@ -43,6 +49,15 @@
             itemView.setIconVisibility(model.get(MessageCardViewProperties.IS_ICON_VISIBLE));
         } else if (CARD_ALPHA == propertyKey) {
             itemView.setAlpha(model.get(CARD_ALPHA));
+        } else if (MessageCardViewProperties.IS_CLOSE_BUTTON_VISIBLE == propertyKey) {
+            itemView.setCloseButtonVisibility(
+                    model.get(MessageCardViewProperties.IS_CLOSE_BUTTON_VISIBLE));
+        } else if (MessageCardViewProperties.IS_INCOGNITO == propertyKey) {
+            itemView.updateMessageCardColor(model.get(MessageCardViewProperties.IS_INCOGNITO));
+        } else if (MessageCardViewProperties.ICON_WIDTH == propertyKey) {
+            itemView.updateIconWidth(model.get(MessageCardViewProperties.ICON_WIDTH));
+        } else if (MessageCardViewProperties.ICON_HEIGHT == propertyKey) {
+            itemView.updateIconHeight(model.get(MessageCardViewProperties.ICON_HEIGHT));
         }
     }
 
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardView.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardView.java
index 09778d20..5fe4e29 100644
--- a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardView.java
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardView.java
@@ -12,7 +12,6 @@
 import android.util.AttributeSet;
 import android.widget.LinearLayout;
 
-import org.chromium.base.ApiCompatibilityUtils;
 import org.chromium.chrome.tab_ui.R;
 import org.chromium.components.browser_ui.styles.ChromeColors;
 import org.chromium.components.browser_ui.widget.text.TemplatePreservingTextView;
@@ -166,42 +165,15 @@
     }
 
     /**
-     * Set text appearance for description.
-     * @param isIncognito Whether the text appearance is used for incognito mode.
-     */
-    private void setDescriptionTextAppearance(boolean isIncognito) {
-        ApiCompatibilityUtils.setTextAppearance(mDescription,
-                TabUiThemeProvider.getMessageCardDescriptionTextAppearance(isIncognito));
-    }
-
-    /**
-     * Set text appearance for action button.
-     * @param isIncognito Whether the text appearance is used for incognito mode.
-     */
-    private void setActionButtonTextAppearance(boolean isIncognito) {
-        ApiCompatibilityUtils.setTextAppearance(mActionButton,
-                TabUiThemeProvider.getMessageCardActionButtonTextAppearance(isIncognito));
-    }
-
-    /**
-     * Set tint for close button.
-     * @param isIncognito Whether the tint is used for incognito mode.
-     */
-    private void setCloseButtonTint(boolean isIncognito) {
-        ApiCompatibilityUtils.setImageTintList(mCloseButton,
-                TabUiThemeProvider.getMessageCardCloseButtonTintList(
-                        mCloseButton.getContext(), isIncognito));
-    }
-
-    /**
      * Update Message Card when switching between normal mode and incognito mode.
      * @param isIncognito Whether it is in the incognito mode.
      */
     void updateMessageCardColor(boolean isIncognito) {
         setBackground(isIncognito);
-        setDescriptionTextAppearance(isIncognito);
-        setActionButtonTextAppearance(isIncognito);
-        // TODO(crbug.com/1139194): Set action button ripple color.
-        setCloseButtonTint(isIncognito);
+        MessageCardViewUtils.setDescriptionTextAppearance(
+                mDescription, isIncognito, /*isLargeMessageCard=*/false);
+        MessageCardViewUtils.setActionButtonTextAppearance(
+                mActionButton, isIncognito, /*isLargeMessageCard=*/false);
+        MessageCardViewUtils.setCloseButtonTint(mCloseButton, isIncognito);
     }
 }
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewProperties.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewProperties.java
index 12715ad..d14ed27 100644
--- a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewProperties.java
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewProperties.java
@@ -7,6 +7,8 @@
 import static org.chromium.chrome.browser.tasks.tab_management.TabListModel.CardProperties.CARD_ALPHA;
 import static org.chromium.chrome.browser.tasks.tab_management.TabListModel.CardProperties.CARD_TYPE;
 
+import android.view.View.OnClickListener;
+
 import org.chromium.chrome.browser.tab.state.ShoppingPersistedTabData;
 import org.chromium.ui.modelutil.PropertyKey;
 import org.chromium.ui.modelutil.PropertyModel;
@@ -23,6 +25,8 @@
             new PropertyModel.ReadableIntPropertyKey();
     public static final PropertyModel.WritableObjectPropertyKey<String> ACTION_TEXT =
             new PropertyModel.WritableObjectPropertyKey<>();
+    public static final PropertyModel.WritableObjectPropertyKey<String> SECONDARY_ACTION_TEXT =
+            new PropertyModel.WritableObjectPropertyKey<>();
     public static final PropertyModel.WritableObjectPropertyKey<String> DESCRIPTION_TEXT =
             new PropertyModel.WritableObjectPropertyKey<>();
     public static final PropertyModel.WritableObjectPropertyKey<String> DESCRIPTION_TEXT_TEMPLATE =
@@ -36,6 +40,9 @@
     public static final PropertyModel
             .WritableObjectPropertyKey<MessageCardView.DismissActionProvider>
                     UI_DISMISS_ACTION_PROVIDER = new PropertyModel.WritableObjectPropertyKey<>();
+    public static final PropertyModel
+            .WritableObjectPropertyKey<OnClickListener> SECONDARY_ACTION_BUTTON_CLICK_HANDLER =
+            new PropertyModel.WritableObjectPropertyKey<>();
     public static final PropertyModel.WritableObjectPropertyKey<
             MessageCardView.ReviewActionProvider> MESSAGE_SERVICE_ACTION_PROVIDER =
             new PropertyModel.WritableObjectPropertyKey<>();
@@ -47,8 +54,14 @@
             new PropertyModel.WritableObjectPropertyKey<>();
     public static final PropertyModel.WritableBooleanPropertyKey SHOULD_KEEP_AFTER_REVIEW =
             new PropertyModel.WritableBooleanPropertyKey();
+    public static final PropertyModel.WritableBooleanPropertyKey IS_CLOSE_BUTTON_VISIBLE =
+            new PropertyModel.WritableBooleanPropertyKey();
     public static final PropertyModel.WritableBooleanPropertyKey IS_ICON_VISIBLE =
             new PropertyModel.WritableBooleanPropertyKey();
+    public static final PropertyModel.WritableIntPropertyKey ICON_WIDTH =
+            new PropertyModel.WritableIntPropertyKey();
+    public static final PropertyModel.WritableIntPropertyKey ICON_HEIGHT =
+            new PropertyModel.WritableIntPropertyKey();
     public static final PropertyModel.WritableBooleanPropertyKey IS_INCOGNITO =
             new PropertyModel.WritableBooleanPropertyKey();
     public static final PropertyModel.WritableObjectPropertyKey<String> TITLE_TEXT =
@@ -60,10 +73,12 @@
             .WritableObjectPropertyKey<ShoppingPersistedTabData.PriceDrop> PRICE_DROP =
             new PropertyModel.WritableObjectPropertyKey<>();
 
-    public static final PropertyKey[] ALL_KEYS = new PropertyKey[] {ACTION_TEXT, DESCRIPTION_TEXT,
-            DESCRIPTION_TEXT_TEMPLATE, MESSAGE_TYPE, MESSAGE_IDENTIFIER, ICON_PROVIDER,
-            UI_ACTION_PROVIDER, UI_DISMISS_ACTION_PROVIDER, MESSAGE_SERVICE_ACTION_PROVIDER,
+    public static final PropertyKey[] ALL_KEYS = new PropertyKey[] {ACTION_TEXT,
+            SECONDARY_ACTION_TEXT, DESCRIPTION_TEXT, DESCRIPTION_TEXT_TEMPLATE, MESSAGE_TYPE,
+            MESSAGE_IDENTIFIER, ICON_PROVIDER, UI_ACTION_PROVIDER, UI_DISMISS_ACTION_PROVIDER,
+            SECONDARY_ACTION_BUTTON_CLICK_HANDLER, MESSAGE_SERVICE_ACTION_PROVIDER,
             MESSAGE_SERVICE_DISMISS_ACTION_PROVIDER, DISMISS_BUTTON_CONTENT_DESCRIPTION,
-            SHOULD_KEEP_AFTER_REVIEW, IS_ICON_VISIBLE, CARD_TYPE, CARD_ALPHA, IS_INCOGNITO,
-            TITLE_TEXT, SHOULD_SHOW_IN_INCOGNITO, PRICE_DROP};
+            SHOULD_KEEP_AFTER_REVIEW, IS_CLOSE_BUTTON_VISIBLE, IS_ICON_VISIBLE, ICON_WIDTH,
+            ICON_HEIGHT, CARD_TYPE, CARD_ALPHA, IS_INCOGNITO, TITLE_TEXT, SHOULD_SHOW_IN_INCOGNITO,
+            PRICE_DROP};
 }
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewUtils.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewUtils.java
new file mode 100644
index 0000000..db2e155e
--- /dev/null
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/MessageCardViewUtils.java
@@ -0,0 +1,102 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+package org.chromium.chrome.browser.tasks.tab_management;
+
+import android.widget.TextView;
+
+import org.chromium.base.ApiCompatibilityUtils;
+import org.chromium.ui.widget.ButtonCompat;
+import org.chromium.ui.widget.ChromeImageView;
+
+/**
+ * A common utils class for Message cards for updating the look of different UI elements present
+ * inside the message card view.
+ */
+public class MessageCardViewUtils {
+    /**
+     * Set text appearance for title.
+     *
+     * @param title The title whose text appearance we want to modify.
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @param isLargeMessageCard Whether the message card view requesting is a large message card.
+     */
+    public static void setTitleTextAppearance(
+            TextView title, boolean isIncognito, boolean isLargeMessageCard) {
+        int titleTextAppearance = (isLargeMessageCard)
+                ? TabUiThemeProvider.getLargeMessageCardTitleTextAppearance(isIncognito)
+                : TabUiThemeProvider.getMessageCardTitleTextAppearance(isIncognito);
+        ApiCompatibilityUtils.setTextAppearance(title, titleTextAppearance);
+    }
+
+    /**
+     * Set text appearance for description.
+     *
+     * @param description The description whose text appearance we want to modify.
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @param isLargeMessageCard Whether the message card view requesting is a large message card.
+     */
+    public static void setDescriptionTextAppearance(
+            TextView description, boolean isIncognito, boolean isLargeMessageCard) {
+        int descriptionTextAppearance = (isLargeMessageCard)
+                ? TabUiThemeProvider.getLargeMessageCardDescriptionTextAppearance(isIncognito)
+                : TabUiThemeProvider.getMessageCardDescriptionTextAppearance(isIncognito);
+        ApiCompatibilityUtils.setTextAppearance(description, descriptionTextAppearance);
+    }
+
+    /**
+     * Set text appearance for action button.
+     *
+     * @param actionButton The button whose text appearance we want to modify.
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @param isLargeMessageCard Whether the message card view requesting is a large message card.
+     */
+    public static void setActionButtonTextAppearance(
+            ButtonCompat actionButton, boolean isIncognito, boolean isLargeMessageCard) {
+        int actionButtonTextAppearance = (isLargeMessageCard)
+                ? TabUiThemeProvider.getLargeMessageCardActionButtonTextAppearance(isIncognito)
+                : TabUiThemeProvider.getMessageCardActionButtonTextAppearance(isIncognito);
+
+        ApiCompatibilityUtils.setTextAppearance(actionButton, actionButtonTextAppearance);
+    }
+
+    /**
+     * Set text appearance for secondary action button.
+     *
+     * @param secondaryActionButton The button whose text appearance we want to modify.
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     */
+    public static void setSecondaryActionButtonColor(
+            ButtonCompat secondaryActionButton, boolean isIncognito) {
+        secondaryActionButton.setTextColor(
+                TabUiThemeProvider.getMessageCardSecondaryActionButtonColor(
+                        secondaryActionButton.getContext(), isIncognito));
+    }
+
+    /**
+     * Set background color for action button.
+     *
+     * @param actionButton The button whose background color we want to modify.
+     * @param isIncognito Whether the background color is used for incognito mode.
+     */
+    public static void setActionButtonBackgroundColor(
+            ButtonCompat actionButton, boolean isIncognito) {
+        actionButton.setButtonColor(TabUiThemeProvider.getToggleActionButtonCheckedDrawableTintList(
+                actionButton.getContext(), isIncognito));
+    }
+
+    /**
+     * Set tint for close button.
+     *
+     * TODO(crbug.com/1139194): Set action button ripple color.
+     *
+     * @param closeButton The close button image view whose tint we want to set.
+     * @param isIncognito Whether the tint is used for incognito mode.
+     */
+    public static void setCloseButtonTint(ChromeImageView closeButton, boolean isIncognito) {
+        ApiCompatibilityUtils.setImageTintList(closeButton,
+                TabUiThemeProvider.getMessageCardCloseButtonTintList(
+                        closeButton.getContext(), isIncognito));
+    }
+}
diff --git a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/TabUiThemeProvider.java b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/TabUiThemeProvider.java
index d145093..db28e197 100644
--- a/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/TabUiThemeProvider.java
+++ b/chrome/android/features/tab_ui/java/src/org/chromium/chrome/browser/tasks/tab_management/TabUiThemeProvider.java
@@ -456,7 +456,18 @@
     }
 
     /**
-     * Returns the text appearance for the message card description based on the incognito mode.
+     * Returns the text appearance for the message card title based on the incognito mode.
+     *
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @return The text appearance for the message card title.
+     */
+    public static int getMessageCardTitleTextAppearance(boolean isIncognito) {
+        return isIncognito ? R.style.TextAppearance_TextLarge_Primary_Baseline_Light
+                           : R.style.TextAppearance_TextLarge_Primary;
+    }
+
+    /**
+     * Returns the text appearance for message card description based on the incognito mode.
      *
      * @param isIncognito Whether the text appearance is used for incognito mode.
      * @return The text appearance for the message card description.
@@ -478,6 +489,55 @@
     }
 
     /**
+     * Returns the text appearance for the message card title based on the incognito mode.
+     *
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @return The text appearance for the message card title.
+     */
+    public static int getLargeMessageCardTitleTextAppearance(boolean isIncognito) {
+        return isIncognito ? R.style.TextAppearance_TextLarge_Primary_Baseline_Light
+                           : R.style.TextAppearance_TextLarge_Primary;
+    }
+
+    /**
+     * Returns the text appearance for large message card description based on the incognito mode.
+     *
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @return The text appearance for the message card description.
+     */
+    public static int getLargeMessageCardDescriptionTextAppearance(boolean isIncognito) {
+        return isIncognito ? R.style.TextAppearance_TextMedium_Secondary_Baseline_Light
+                           : R.style.TextAppearance_TextMedium_Secondary;
+    }
+
+    /**
+     * Returns the text appearance for the large message card action button based on the incognito
+     * mode.
+     *
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     * @return The text appearance for the message card action button.
+     */
+    public static int getLargeMessageCardActionButtonTextAppearance(boolean isIncognito) {
+        return isIncognito ? R.style.TextAppearance_Button_Text_Blue_Dark
+                           : R.style.TextAppearance_Button_Text_Filled;
+    }
+
+    /**
+     * Returns the text color for the message card secondary action button based on the
+     * incognito mode.
+     *
+     * @param context The {@link Context} to use to fetch the resources.
+     * @param isIncognito Whether the text appearance is used for incognito mode.
+     *
+     * @return The {@link ColorInt} to set for the message card secondary action button.
+     */
+    public static @ColorInt int getMessageCardSecondaryActionButtonColor(
+            Context context, boolean isIncognito) {
+        return isIncognito ? context.getColor(R.color.default_text_color_link_light)
+                           : SemanticColorUtils.getDefaultTextColorLink(context);
+    }
+
+    /**
      * Returns the {@link ColorStateList} to use for the message card close button based on
      * incognito mode.
      *
diff --git a/chrome/android/features/tab_ui/javatests/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderTest.java b/chrome/android/features/tab_ui/javatests/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderTest.java
index 806c0c8..76f6199a 100644
--- a/chrome/android/features/tab_ui/javatests/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderTest.java
+++ b/chrome/android/features/tab_ui/javatests/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderTest.java
@@ -4,13 +4,19 @@
 
 package org.chromium.chrome.browser.tasks.tab_management;
 
+import static android.view.View.GONE;
+import static android.view.View.VISIBLE;
+
 import static org.junit.Assert.assertEquals;
 import static org.junit.Assert.assertNull;
 import static org.junit.Assert.assertTrue;
 
+import static org.chromium.base.test.util.Batch.UNIT_TESTS;
+
 import android.content.res.Configuration;
 import android.graphics.drawable.Drawable;
 import android.view.View;
+import android.view.View.OnClickListener;
 import android.view.ViewGroup;
 import android.widget.FrameLayout;
 import android.widget.TextView;
@@ -22,6 +28,7 @@
 import org.junit.runner.RunWith;
 
 import org.chromium.base.test.UiThreadTest;
+import org.chromium.base.test.util.Batch;
 import org.chromium.chrome.browser.tab.state.ShoppingPersistedTabData;
 import org.chromium.chrome.tab_ui.R;
 import org.chromium.chrome.test.ChromeJUnit4ClassRunner;
@@ -38,15 +45,18 @@
  * Tests for {@link LargeMessageCardViewBinder}.
  */
 @RunWith(ChromeJUnit4ClassRunner.class)
+@Batch(UNIT_TESTS)
 public class LargeMessageCardViewBinderTest extends BlankUiTestActivityTestCase {
     private static final String TITLE_TEXT = "titleText";
     private static final String ACTION_TEXT = "actionText";
     private static final String DESCRIPTION_TEXT = "descriptionText";
+    private static final String SECONDARY_ACTION_TEXT = "secondaryActionText";
     private static final String DISMISS_BUTTON_CONTENT_DESCRIPTION = "dismiss";
     private static final String PRICE = "$300";
     private static final String PREVIOUS_PRICE = "$400";
 
     private final AtomicBoolean mReviewButtonClicked = new AtomicBoolean();
+    private final AtomicBoolean mSecondaryActionButtonClicked = new AtomicBoolean();
     private final AtomicBoolean mDismissButtonClicked = new AtomicBoolean();
     private final AtomicBoolean mMessageServiceReviewCallbackRan = new AtomicBoolean();
     private final AtomicBoolean mMessageServiceDismissCallbackRan = new AtomicBoolean();
@@ -59,11 +69,14 @@
             () -> mMessageServiceReviewCallbackRan.set(true);
     private final MessageCardView.DismissActionProvider mMessageServiceDismissHandler =
             (int messageType) -> mMessageServiceDismissCallbackRan.set(true);
+    private final OnClickListener mSecondaryActionButtonClickListener =
+            view -> mSecondaryActionButtonClicked.set(true);
 
     private ChromeImageView mIcon;
     private TextView mTitle;
     private TextView mDescription;
     private ButtonCompat mActionButton;
+    private ButtonCompat mSecondaryActionButton;
     private ChromeImageView mCloseButton;
     private PriceCardView mPriceInfoBox;
     private LargeMessageCardView mItemView;
@@ -88,6 +101,7 @@
             mTitle = mItemView.findViewById(R.id.title);
             mDescription = mItemView.findViewById(R.id.description);
             mActionButton = mItemView.findViewById(R.id.action_button);
+            mSecondaryActionButton = mItemView.findViewById(R.id.secondary_action_button);
             mCloseButton = mItemView.findViewById(R.id.close_button);
 
             mItemViewModel =
@@ -113,6 +127,10 @@
         assertEquals(ACTION_TEXT, mActionButton.getText().toString());
         assertEquals(DESCRIPTION_TEXT, mDescription.getText().toString());
         assertEquals(DISMISS_BUTTON_CONTENT_DESCRIPTION, mCloseButton.getContentDescription());
+        assertEquals("Secondary action button should be gone by default.", GONE,
+                mSecondaryActionButton.getVisibility());
+        assertEquals("Close button should be visible by default.", VISIBLE,
+                mCloseButton.getVisibility());
     }
 
     @Test
@@ -131,30 +149,61 @@
     @UiThreadTest
     @SmallTest
     public void testSetIconVisibility() {
-        assertEquals(View.GONE, mIcon.getVisibility());
+        assertEquals(GONE, mIcon.getVisibility());
 
         mItemViewModel.set(MessageCardViewProperties.IS_ICON_VISIBLE, true);
-        assertEquals(View.VISIBLE, mIcon.getVisibility());
+        assertEquals(VISIBLE, mIcon.getVisibility());
         mItemViewModel.set(MessageCardViewProperties.IS_ICON_VISIBLE, false);
-        assertEquals(View.GONE, mIcon.getVisibility());
+        assertEquals(GONE, mIcon.getVisibility());
+    }
+
+    @Test
+    @UiThreadTest
+    @SmallTest
+    public void testSetCloseIconVisibility() {
+        mItemViewModel.set(MessageCardViewProperties.IS_CLOSE_BUTTON_VISIBLE, false);
+        assertEquals("Close button should not be visible.", GONE, mCloseButton.getVisibility());
+    }
+
+    @Test
+    @UiThreadTest
+    @SmallTest
+    public void testSecondaryActionText() {
+        mItemViewModel.set(MessageCardViewProperties.SECONDARY_ACTION_TEXT, SECONDARY_ACTION_TEXT);
+        assertEquals("Fail to set secondary action text.", SECONDARY_ACTION_TEXT,
+                mSecondaryActionButton.getText());
+        assertEquals("Secondary action text should be visible.", View.VISIBLE,
+                mSecondaryActionButton.getVisibility());
+    }
+
+    @Test
+    @UiThreadTest
+    @SmallTest
+    public void testSecondaryActionOnClickListenerTest() {
+        mSecondaryActionButtonClicked.set(false);
+        mItemViewModel.set(MessageCardViewProperties.SECONDARY_ACTION_TEXT, SECONDARY_ACTION_TEXT);
+        mItemViewModel.set(MessageCardViewProperties.SECONDARY_ACTION_BUTTON_CLICK_HANDLER,
+                mSecondaryActionButtonClickListener);
+        mSecondaryActionButton.performClick();
+        assertTrue("Secondary button didn't fire properly.", mSecondaryActionButtonClicked.get());
     }
 
     @Test
     @UiThreadTest
     @SmallTest
     public void testSetupPriceInfoBox() {
-        assertEquals(View.GONE, mPriceInfoBox.getVisibility());
+        assertEquals(GONE, mPriceInfoBox.getVisibility());
 
         mItemViewModel.set(MessageCardViewProperties.PRICE_DROP,
                 new ShoppingPersistedTabData.PriceDrop(PRICE, PREVIOUS_PRICE));
-        assertEquals(View.VISIBLE, mPriceInfoBox.getVisibility());
+        assertEquals(VISIBLE, mPriceInfoBox.getVisibility());
         assertEquals(PRICE,
                 ((TextView) mItemView.findViewById(R.id.current_price)).getText().toString());
         assertEquals(PREVIOUS_PRICE,
                 ((TextView) mItemView.findViewById(R.id.previous_price)).getText().toString());
 
         mItemViewModel.set(MessageCardViewProperties.PRICE_DROP, null);
-        assertEquals(View.GONE, mPriceInfoBox.getVisibility());
+        assertEquals(GONE, mPriceInfoBox.getVisibility());
     }
 
     @Test
diff --git a/chrome/android/features/tab_ui/junit/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderUnitTest.java b/chrome/android/features/tab_ui/junit/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderUnitTest.java
index 04f6be4..d0d4280 100644
--- a/chrome/android/features/tab_ui/junit/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderUnitTest.java
+++ b/chrome/android/features/tab_ui/junit/src/org/chromium/chrome/browser/tasks/tab_management/LargeMessageCardViewBinderUnitTest.java
@@ -8,14 +8,17 @@
 import static org.mockito.Mockito.never;
 import static org.mockito.Mockito.times;
 import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.verifyNoMoreInteractions;
 import static org.mockito.Mockito.when;
 
 import static org.chromium.chrome.browser.tasks.tab_management.TabListModel.CardProperties.CARD_ALPHA;
 
 import android.graphics.drawable.Drawable;
+import android.view.View.OnClickListener;
 
 import androidx.test.filters.SmallTest;
 
+import org.junit.After;
 import org.junit.Before;
 import org.junit.Test;
 import org.junit.runner.RunWith;
@@ -32,6 +35,10 @@
  */
 @RunWith(BaseRobolectricTestRunner.class)
 public class LargeMessageCardViewBinderUnitTest {
+    private static final String FAKE_DISPLAY_TEXT = "Fake Text";
+    private static final int FAKE_ICON_WIDTH = 666;
+    private static final int FAKE_ICON_HEIGHT = 999;
+
     @Mock
     LargeMessageCardView mMockLargeCardView;
 
@@ -56,7 +63,9 @@
     @Mock
     Drawable mMockDrawable;
 
-    private static final String FAKE_DISPLAY_TEXT = "Fake Text";
+    @Mock
+    private OnClickListener mMockOnClickListenerMock;
+
     private PropertyModel mModel;
 
     @Before
@@ -68,6 +77,13 @@
                 mModel, mMockLargeCardView, LargeMessageCardViewBinder::bind);
     }
 
+    @After
+    public void tearDown() {
+        verifyNoMoreInteractions(mMockLargeCardView, mMockDismissActionProvider1,
+                mMockDismissActionProvider2, mMockReviewActionProvider1, mMockReviewActionProvider2,
+                mMockPriceDrop, mMockIconProvider, mMockDrawable, mMockOnClickListenerMock);
+    }
+
     @Test
     @SmallTest
     public void updateContntDescriptionText() {
@@ -94,6 +110,22 @@
 
     @Test
     @SmallTest
+    public void updateSecondaryActionButtonText() {
+        mModel.set(MessageCardViewProperties.SECONDARY_ACTION_TEXT, FAKE_DISPLAY_TEXT);
+        verify(mMockLargeCardView, times(1)).setSecondaryActionText(FAKE_DISPLAY_TEXT);
+    }
+
+    @Test
+    @SmallTest
+    public void updateSecondaryActionButtonOnClickListener() {
+        mModel.set(MessageCardViewProperties.SECONDARY_ACTION_BUTTON_CLICK_HANDLER,
+                mMockOnClickListenerMock);
+        verify(mMockLargeCardView, times(1))
+                .setSecondaryActionButtonOnClickListener(mMockOnClickListenerMock);
+    }
+
+    @Test
+    @SmallTest
     public void updateTitleText() {
         mModel.set(MessageCardViewProperties.TITLE_TEXT, FAKE_DISPLAY_TEXT);
         verify(mMockLargeCardView, times(1)).setTitleText(FAKE_DISPLAY_TEXT);
@@ -121,9 +153,35 @@
 
     @Test
     @SmallTest
+    public void updateIconWidth() {
+        mModel.set(MessageCardViewProperties.ICON_WIDTH, FAKE_ICON_WIDTH);
+        verify(mMockLargeCardView, times(1)).updateIconWidth(FAKE_ICON_WIDTH);
+    }
+
+    @Test
+    @SmallTest
+    public void updateIconHeight() {
+        mModel.set(MessageCardViewProperties.ICON_HEIGHT, FAKE_ICON_HEIGHT);
+        verify(mMockLargeCardView, times(1)).updateIconHeight(FAKE_ICON_HEIGHT);
+    }
+
+    @Test
+    @SmallTest
+    public void updateCloseIconVisibility() {
+        mModel.set(MessageCardViewProperties.IS_CLOSE_BUTTON_VISIBLE, false);
+        verify(mMockLargeCardView, times(1)).setCloseButtonVisibility(false);
+
+        mModel.set(MessageCardViewProperties.IS_CLOSE_BUTTON_VISIBLE, true);
+        verify(mMockLargeCardView, times(1)).setCloseButtonVisibility(true);
+    }
+
+    @Test
+    @SmallTest
     public void updateIconDrawable() {
         when(mMockIconProvider.getIconDrawable()).thenReturn(mMockDrawable);
         mModel.set(MessageCardViewProperties.ICON_PROVIDER, mMockIconProvider);
+
+        verify(mMockIconProvider, times(1)).getIconDrawable();
         verify(mMockLargeCardView, times(1)).setIconDrawable(mMockDrawable);
     }
 
diff --git a/chrome/android/java/src/PRESUBMIT.py b/chrome/android/java/src/PRESUBMIT.py
index 6ce7516a..e1fab0d 100644
--- a/chrome/android/java/src/PRESUBMIT.py
+++ b/chrome/android/java/src/PRESUBMIT.py
@@ -36,8 +36,6 @@
 COMMENT_RE = re.compile(r'^\s*(//|/\*|\*)')
 
 BROWSER_ROOT = 'chrome/android/java/src/org/chromium/chrome/browser/'
-SIGNIN_UI_BROWSER_ROOT = 'chrome/browser/ui/android/signin'
-'/java/src/org/chromium/chrome/browser/ui/signin'
 
 
 def CheckChangeOnUpload(input_api, output_api):
@@ -94,8 +92,6 @@
       BROWSER_ROOT + 'password_manager/AccountChooserDialog.java',
       BROWSER_ROOT + 'password_manager/AutoSigninFirstRunDialog.java',
       BROWSER_ROOT + r'settings[\\\/].*',
-      SIGNIN_UI_BROWSER_ROOT + 'ConfirmManagedSyncDataDialog.java',
-      SIGNIN_UI_BROWSER_ROOT + 'ConfirmSyncDataStateMachineDelegate.java',
       BROWSER_ROOT + 'site_settings/AddExceptionPreference.java',
       BROWSER_ROOT + 'site_settings/ChosenObjectSettings.java',
       BROWSER_ROOT + 'site_settings/ManageSpaceActivity.java',
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragment.java b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragment.java
index 8e07fa7..7456014e 100644
--- a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragment.java
+++ b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragment.java
@@ -9,6 +9,7 @@
 import android.content.Context;
 import android.content.Intent;
 import android.os.Bundle;
+import android.text.SpannableString;
 import android.view.LayoutInflater;
 import android.view.View;
 import android.view.ViewGroup;
@@ -20,21 +21,36 @@
 import androidx.annotation.Nullable;
 import androidx.annotation.VisibleForTesting;
 import androidx.collection.ArraySet;
+import androidx.fragment.app.DialogFragment;
 import androidx.fragment.app.FragmentActivity;
 import androidx.preference.Preference;
 import androidx.preference.PreferenceFragmentCompat;
 
+import org.chromium.base.Callback;
 import org.chromium.base.CollectionUtil;
 import org.chromium.base.metrics.RecordHistogram;
 import org.chromium.chrome.R;
 import org.chromium.chrome.browser.browsing_data.BrowsingDataCounterBridge.BrowsingDataCounterCallback;
+import org.chromium.chrome.browser.flags.ChromeFeatureList;
 import org.chromium.chrome.browser.historyreport.AppIndexingReporter;
 import org.chromium.chrome.browser.multiwindow.MultiWindowUtils;
 import org.chromium.chrome.browser.preferences.Pref;
 import org.chromium.chrome.browser.profiles.Profile;
+import org.chromium.chrome.browser.signin.services.IdentityServicesProvider;
+import org.chromium.chrome.browser.signin.services.SigninManager;
+import org.chromium.chrome.browser.sync.settings.ClearDataProgressDialog;
+import org.chromium.chrome.browser.ui.signin.SignOutDialogCoordinator;
+import org.chromium.chrome.browser.ui.signin.SignOutDialogCoordinator.ActionType;
+import org.chromium.components.browser_ui.settings.ClickableSpansTextMessagePreference;
 import org.chromium.components.browser_ui.settings.SettingsUtils;
 import org.chromium.components.browser_ui.settings.SpinnerPreference;
+import org.chromium.components.signin.GAIAServiceType;
+import org.chromium.components.signin.identitymanager.ConsentLevel;
 import org.chromium.components.user_prefs.UserPrefs;
+import org.chromium.ui.modaldialog.ModalDialogManagerHolder;
+import org.chromium.ui.text.NoUnderlineClickableSpan;
+import org.chromium.ui.text.SpanApplier;
+import org.chromium.ui.text.SpanApplier.SpanInfo;
 import org.chromium.ui.widget.ButtonCompat;
 
 import java.lang.annotation.Retention;
@@ -50,7 +66,10 @@
  */
 public abstract class ClearBrowsingDataFragment extends PreferenceFragmentCompat
         implements BrowsingDataBridge.OnClearBrowsingDataListener,
-                   Preference.OnPreferenceClickListener, Preference.OnPreferenceChangeListener {
+                   Preference.OnPreferenceClickListener, Preference.OnPreferenceChangeListener,
+                   SignOutDialogCoordinator.Listener {
+    private static final String CLEAR_DATA_PROGRESS_DIALOG_TAG = "clear_data_progress";
+
     /**
      * Represents a single item in the dialog.
      */
@@ -566,6 +585,21 @@
         assert spinnerOptionIndex != -1;
         spinner.setOptions(spinnerOptions, spinnerOptionIndex);
         spinner.setOnPreferenceChangeListener(this);
+
+        // Text for sign-out option.
+        if (ChromeFeatureList.isEnabled(ChromeFeatureList.ENABLE_CBD_SIGN_OUT)
+                && IdentityServicesProvider.get()
+                           .getIdentityManager(Profile.getLastUsedRegularProfile())
+                           .hasPrimaryAccount(ConsentLevel.SIGNIN)
+                && IdentityServicesProvider.get()
+                           .getSigninManager(Profile.getLastUsedRegularProfile())
+                           .isSignOutAllowed()) {
+            ClickableSpansTextMessagePreference signOutOfChromeTextPref =
+                    findPreference(ClearBrowsingDataFragment.PREF_SIGN_OUT_OF_CHROME_TEXT);
+            signOutOfChromeTextPref.setSummary(buildSignOutOfChromeText());
+        } else {
+            deleteSignOutOfChromeTextIfExists();
+        }
     }
 
     @Override
@@ -633,6 +667,29 @@
         return mConfirmImportantSitesDialog;
     }
 
+    @VisibleForTesting
+    SpannableString buildSignOutOfChromeText() {
+        return SpanApplier.applySpans(getContext().getString(R.string.sign_out_of_chrome_link),
+                new SpanInfo("<link1>", "</link1>",
+                        new NoUnderlineClickableSpan(
+                                requireContext(), createSignOutOfChromeCallback())));
+    }
+
+    private Callback<View> createSignOutOfChromeCallback() {
+        return view
+                -> SignOutDialogCoordinator.show(requireContext(),
+                        ((ModalDialogManagerHolder) getActivity()).getModalDialogManager(), this,
+                        ActionType.CLEAR_PRIMARY_ACCOUNT, GAIAServiceType.GAIA_SERVICE_TYPE_NONE);
+    }
+
+    private void deleteSignOutOfChromeTextIfExists() {
+        Preference signOutOfChromeTextPref =
+                findPreference(ClearBrowsingDataFragment.PREF_SIGN_OUT_OF_CHROME_TEXT);
+        if (signOutOfChromeTextPref != null) {
+            getPreferenceScreen().removePreference(signOutOfChromeTextPref);
+        }
+    }
+
     /**
      * This method shows the important sites dialog. After the dialog is shown, we correctly clear.
      */
@@ -695,4 +752,44 @@
                     ignoredDomains, ignoredDomainReasons);
         }
     }
+
+    /** {@link SignOutDialogCoordinator.Listener} implementation */
+    @Override
+    public void onSignOutClicked(boolean forceWipeUserData) {
+        // In case the user is not signed in, we guard the sign out so we do not hit a native crash.
+        if (!IdentityServicesProvider.get()
+                        .getIdentityManager(Profile.getLastUsedRegularProfile())
+                        .hasPrimaryAccount(ConsentLevel.SIGNIN)) {
+            return;
+        }
+        final SigninManager signinManager = IdentityServicesProvider.get().getSigninManager(
+                Profile.getLastUsedRegularProfile());
+        signinManager.runAfterOperationInProgress(() -> {
+            // In case supervised users reach this flow, remove the preference and guard against
+            // signing out.
+            if (!signinManager.isSignOutAllowed()) {
+                deleteSignOutOfChromeTextIfExists();
+                return;
+            }
+            final DialogFragment clearDataProgressDialog = new ClearDataProgressDialog();
+            signinManager.signOut(org.chromium.components.signin.metrics.SignoutReason
+                                          .USER_CLICKED_SIGNOUT_FROM_CLEAR_BROWSING_DATA_PAGE,
+                    new SigninManager.SignOutCallback() {
+                        @Override
+                        public void preWipeData() {
+                            clearDataProgressDialog.show(
+                                    getChildFragmentManager(), CLEAR_DATA_PROGRESS_DIALOG_TAG);
+                        }
+
+                        @Override
+                        public void signOutComplete() {
+                            clearDataProgressDialog.dismissAllowingStateLoss();
+                        }
+                    },
+                    forceWipeUserData);
+            // TODO(https://crbug.com/1334918): Observe SignInStateObserver and move this inside
+            // onSignOutAllowedChanged().
+            deleteSignOutOfChromeTextIfExists();
+        });
+    }
 }
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentAdvanced.java b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentAdvanced.java
index 225b975..f0ee8aa 100644
--- a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentAdvanced.java
+++ b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentAdvanced.java
@@ -37,9 +37,6 @@
         // TODO(https://crbug.com/1334920): Change after follow up discussion with privacy team.
         Preference signOutOfChromeTextPref =
                 findPreference(ClearBrowsingDataFragment.PREF_SIGN_OUT_OF_CHROME_TEXT);
-        if (signOutOfChromeTextPref != null) {
-            getPreferenceScreen().removePreference(signOutOfChromeTextPref);
-        }
     }
 
     @Override
diff --git a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasic.java b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasic.java
index c42369d2..ab0fcc0 100644
--- a/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasic.java
+++ b/chrome/android/java/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasic.java
@@ -13,9 +13,7 @@
 import android.view.View;
 
 import androidx.annotation.IntDef;
-import androidx.annotation.VisibleForTesting;
 import androidx.browser.customtabs.CustomTabsIntent;
-import androidx.fragment.app.DialogFragment;
 import androidx.preference.Preference;
 
 import org.chromium.base.Callback;
@@ -23,27 +21,19 @@
 import org.chromium.base.metrics.RecordHistogram;
 import org.chromium.base.metrics.RecordUserAction;
 import org.chromium.chrome.R;
-import org.chromium.chrome.browser.flags.ChromeFeatureList;
 import org.chromium.chrome.browser.profiles.Profile;
 import org.chromium.chrome.browser.search_engines.TemplateUrlServiceFactory;
 import org.chromium.chrome.browser.signin.services.IdentityServicesProvider;
-import org.chromium.chrome.browser.signin.services.SigninManager;
 import org.chromium.chrome.browser.sync.SyncService;
-import org.chromium.chrome.browser.sync.settings.ClearDataProgressDialog;
 import org.chromium.chrome.browser.tab.TabLaunchType;
 import org.chromium.chrome.browser.tabmodel.document.TabDelegate;
-import org.chromium.chrome.browser.ui.signin.SignOutDialogCoordinator;
-import org.chromium.chrome.browser.ui.signin.SignOutDialogCoordinator.ActionType;
 import org.chromium.components.browser_ui.settings.ClickableSpansTextMessagePreference;
 import org.chromium.components.embedder_support.util.UrlConstants;
 import org.chromium.components.search_engines.TemplateUrl;
 import org.chromium.components.search_engines.TemplateUrlService;
-import org.chromium.components.signin.GAIAServiceType;
 import org.chromium.components.signin.identitymanager.ConsentLevel;
 import org.chromium.components.signin.identitymanager.IdentityManager;
-import org.chromium.components.signin.metrics.SignoutReason;
 import org.chromium.components.sync.ModelType;
-import org.chromium.ui.modaldialog.ModalDialogManagerHolder;
 import org.chromium.ui.text.NoUnderlineClickableSpan;
 import org.chromium.ui.text.SpanApplier;
 import org.chromium.ui.text.SpanApplier.SpanInfo;
@@ -57,10 +47,7 @@
  * A simpler version of {@link ClearBrowsingDataFragment} with fewer dialog options and more
  * explanatory text.
  */
-public class ClearBrowsingDataFragmentBasic
-        extends ClearBrowsingDataFragment implements SignOutDialogCoordinator.Listener {
-    private static final String CLEAR_DATA_PROGRESS_DIALOG_TAG = "clear_data_progress";
-
+public class ClearBrowsingDataFragmentBasic extends ClearBrowsingDataFragment {
     /**
      * Functional interface to start a Chrome Custom Tab for the given intent, e.g. by using
      * {@link org.chromium.chrome.browser.LaunchIntentDispatcher#createCustomTabActivityIntent}.
@@ -165,17 +152,6 @@
             nonGoogleSearchHistoryTextPref.setSummary(
                     R.string.clear_search_history_non_google_dse_unknown);
         }
-
-        // Text for sign-out option.
-        if (ChromeFeatureList.isEnabled(ChromeFeatureList.ENABLE_CBD_SIGN_OUT)
-                && identityManager.hasPrimaryAccount(ConsentLevel.SIGNIN)
-                && !Profile.getLastUsedRegularProfile().isChild()) {
-            ClickableSpansTextMessagePreference signOutOfChromeTextPref =
-                    findPreference(ClearBrowsingDataFragment.PREF_SIGN_OUT_OF_CHROME_TEXT);
-            signOutOfChromeTextPref.setSummary(buildSignOutOfChromeText());
-        } else {
-            deleteSignOutOfChromeTextIfExists();
-        }
     }
 
     public void setCustomTabIntentHelper(CustomTabIntentHelper tabHelper) {
@@ -198,14 +174,6 @@
         }
     }
 
-    private void deleteSignOutOfChromeTextIfExists() {
-        Preference signOutOfChromeTextPref =
-                findPreference(ClearBrowsingDataFragment.PREF_SIGN_OUT_OF_CHROME_TEXT);
-        if (signOutOfChromeTextPref != null) {
-            getPreferenceScreen().removePreference(signOutOfChromeTextPref);
-        }
-    }
-
     private SpannableString buildGoogleSearchHistoryText() {
         return SpanApplier.applySpans(getContext().getString(R.string.clear_search_history_link),
                 new SpanInfo("<link1>", "</link1>",
@@ -224,14 +192,6 @@
                                 createOpenMyActivityCallback(/* openSearchHistory = */ false))));
     }
 
-    @VisibleForTesting
-    SpannableString buildSignOutOfChromeText() {
-        return SpanApplier.applySpans(getContext().getString(R.string.sign_out_of_chrome_link),
-                new SpanInfo("<link1>", "</link1>",
-                        new NoUnderlineClickableSpan(
-                                requireContext(), createSignOutOfChromeCallback())));
-    }
-
     /** If openSearchHistory is true, opens the search history page; otherwise: top level. */
     private Callback<View> createOpenMyActivityCallback(boolean openSearchHistory) {
         return (widget) -> {
@@ -263,13 +223,6 @@
         };
     }
 
-    private Callback<View> createSignOutOfChromeCallback() {
-        return view
-                -> SignOutDialogCoordinator.show(requireContext(),
-                        ((ModalDialogManagerHolder) getActivity()).getModalDialogManager(), this,
-                        ActionType.CLEAR_PRIMARY_ACCOUNT, GAIAServiceType.GAIA_SERVICE_TYPE_NONE);
-    }
-
     private boolean isHistorySyncEnabled() {
         SyncService syncService = SyncService.get();
         return syncService != null && syncService.isSyncRequested()
@@ -294,43 +247,4 @@
                 ClearBrowsingDataTab.BASIC, ClearBrowsingDataTab.NUM_TYPES);
         RecordUserAction.record("ClearBrowsingData_BasicTab");
     }
-
-    /** {@link SignOutDialogCoordinator.Listener} implementation */
-    @Override
-    public void onSignOutClicked(boolean forceWipeUserData) {
-        // In case the user is not signed in, we guard the sign out so we do not hit a native crash.
-        if (!IdentityServicesProvider.get()
-                        .getIdentityManager(Profile.getLastUsedRegularProfile())
-                        .hasPrimaryAccount(ConsentLevel.SIGNIN)) {
-            return;
-        }
-        final SigninManager signinManager = IdentityServicesProvider.get().getSigninManager(
-                Profile.getLastUsedRegularProfile());
-        signinManager.runAfterOperationInProgress(() -> {
-            // In case supervised users reach this flow, remove the preference and guard against
-            // signing out.
-            if (!signinManager.isSignOutAllowed()) {
-                deleteSignOutOfChromeTextIfExists();
-                return;
-            }
-            final DialogFragment clearDataProgressDialog = new ClearDataProgressDialog();
-            signinManager.signOut(SignoutReason.USER_CLICKED_SIGNOUT_FROM_CLEAR_BROWSING_DATA_PAGE,
-                    new SigninManager.SignOutCallback() {
-                        @Override
-                        public void preWipeData() {
-                            clearDataProgressDialog.show(
-                                    getChildFragmentManager(), CLEAR_DATA_PROGRESS_DIALOG_TAG);
-                        }
-
-                        @Override
-                        public void signOutComplete() {
-                            clearDataProgressDialog.dismissAllowingStateLoss();
-                        }
-                    },
-                    forceWipeUserData);
-            // TODO(https://crbug.com/1334918): Observe SignInStateObserver and move this inside
-            // onSignOutAllowedChanged().
-            deleteSignOutOfChromeTextIfExists();
-        });
-    }
 }
diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasicTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasicTest.java
index 3793df6..31e74e6 100644
--- a/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasicTest.java
+++ b/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentBasicTest.java
@@ -5,26 +5,17 @@
 package org.chromium.chrome.browser.browsing_data;
 
 import static androidx.test.espresso.Espresso.onView;
-import static androidx.test.espresso.action.ViewActions.click;
 import static androidx.test.espresso.assertion.ViewAssertions.doesNotExist;
-import static androidx.test.espresso.matcher.RootMatchers.isDialog;
 import static androidx.test.espresso.matcher.ViewMatchers.withText;
 
 import static org.mockito.Mockito.when;
 import static org.mockito.MockitoAnnotations.initMocks;
 
-import android.text.Spanned;
-import android.text.style.ClickableSpan;
 import android.view.View;
-import android.widget.TextView;
 
 import androidx.annotation.Nullable;
-import androidx.test.espresso.NoMatchingViewException;
-import androidx.test.espresso.UiController;
-import androidx.test.espresso.ViewAction;
 import androidx.test.filters.LargeTest;
 
-import org.hamcrest.Matcher;
 import org.junit.After;
 import org.junit.Before;
 import org.junit.Rule;
@@ -38,14 +29,11 @@
 import org.chromium.base.test.util.CommandLineFlags;
 import org.chromium.base.test.util.CriteriaHelper;
 import org.chromium.base.test.util.Feature;
-import org.chromium.base.test.util.Matchers;
 import org.chromium.chrome.R;
 import org.chromium.chrome.browser.flags.ChromeFeatureList;
 import org.chromium.chrome.browser.flags.ChromeSwitches;
-import org.chromium.chrome.browser.profiles.Profile;
 import org.chromium.chrome.browser.search_engines.TemplateUrlServiceFactory;
 import org.chromium.chrome.browser.settings.SettingsActivityTestRule;
-import org.chromium.chrome.browser.signin.services.IdentityServicesProvider;
 import org.chromium.chrome.browser.sync.SyncService;
 import org.chromium.chrome.test.ChromeJUnit4ClassRunner;
 import org.chromium.chrome.test.ChromeTabbedActivityTestRule;
@@ -54,7 +42,6 @@
 import org.chromium.chrome.test.util.browser.signin.SigninTestRule;
 import org.chromium.components.search_engines.TemplateUrl;
 import org.chromium.components.search_engines.TemplateUrlService;
-import org.chromium.components.signin.identitymanager.ConsentLevel;
 import org.chromium.components.sync.ModelType;
 import org.chromium.content_public.browser.test.util.TestThreadUtils;
 
@@ -160,31 +147,6 @@
 
     @Test
     @LargeTest
-    public void testSigningOut() {
-        mSigninTestRule.addTestAccountThenSigninAndEnableSync();
-        setSyncable(true);
-        mSettingsActivityTestRule.startSettingsActivity();
-        waitForOptionsMenu();
-
-        final ClearBrowsingDataFragmentBasic clearBrowsingDataFragmentBasic =
-                mSettingsActivityTestRule.getFragment();
-        onView(withText(clearBrowsingDataFragmentBasic.buildSignOutOfChromeText().toString()))
-                .perform(clickOnSignOutLink());
-        onView(withText(R.string.continue_button)).inRoot(isDialog()).perform(click());
-        CriteriaHelper.pollUiThread(
-                ()
-                        -> !IdentityServicesProvider.get()
-                                    .getIdentityManager(Profile.getLastUsedRegularProfile())
-                                    .hasPrimaryAccount(ConsentLevel.SIGNIN),
-                "Account should be signed out!");
-
-        // Footer should be hidden after sign-out.
-        onView(withText(clearBrowsingDataFragmentBasic.buildSignOutOfChromeText().toString()))
-                .check(doesNotExist());
-    }
-
-    @Test
-    @LargeTest
     @Feature({"RenderTest"})
     public void testRenderSignedInAndSyncing() throws IOException {
         mSigninTestRule.addTestAccountThenSigninAndEnableSync();
@@ -290,34 +252,4 @@
                             .getRootView();
         mRenderTestRule.render(view, "clear_browsing_data_basic_shl_unknown_signed_out");
     }
-
-    // TODO(https://crbug.com/1334586): Move this to a test util class.
-    private ViewAction clickOnSignOutLink() {
-        return new ViewAction() {
-            @Override
-            public Matcher<View> getConstraints() {
-                return Matchers.instanceOf(TextView.class);
-            }
-
-            @Override
-            public String getDescription() {
-                return "Clicks on the sign out link in the clear browsing data footer";
-            }
-
-            @Override
-            public void perform(UiController uiController, View view) {
-                TextView textView = (TextView) view;
-                Spanned spannedString = (Spanned) textView.getText();
-                ClickableSpan[] spans =
-                        spannedString.getSpans(0, spannedString.length(), ClickableSpan.class);
-                if (spans.length != 1) {
-                    throw new NoMatchingViewException.Builder()
-                            .includeViewHierarchy(true)
-                            .withRootView(textView)
-                            .build();
-                }
-                spans[0].onClick(view);
-            }
-        };
-    }
 }
diff --git a/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentTest.java b/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentTest.java
index 59df6ab..d2c3bc0 100644
--- a/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentTest.java
+++ b/chrome/android/javatests/src/org/chromium/chrome/browser/browsing_data/ClearBrowsingDataFragmentTest.java
@@ -4,6 +4,12 @@
 
 package org.chromium.chrome.browser.browsing_data;
 
+import static androidx.test.espresso.Espresso.onView;
+import static androidx.test.espresso.action.ViewActions.click;
+import static androidx.test.espresso.assertion.ViewAssertions.doesNotExist;
+import static androidx.test.espresso.matcher.RootMatchers.isDialog;
+import static androidx.test.espresso.matcher.ViewMatchers.withText;
+
 import static org.mockito.ArgumentMatchers.any;
 import static org.mockito.ArgumentMatchers.anyInt;
 import static org.mockito.ArgumentMatchers.eq;
@@ -15,9 +21,13 @@
 
 import android.os.Build;
 import android.support.test.InstrumentationRegistry;
+import android.text.Spanned;
+import android.text.style.ClickableSpan;
+import android.view.View;
 import android.widget.Button;
 import android.widget.ListView;
 import android.widget.Spinner;
+import android.widget.TextView;
 
 import androidx.appcompat.app.AlertDialog;
 import androidx.collection.ArraySet;
@@ -26,12 +36,16 @@
 import androidx.preference.Preference;
 import androidx.preference.PreferenceScreen;
 import androidx.recyclerview.widget.RecyclerView;
+import androidx.test.espresso.NoMatchingViewException;
+import androidx.test.espresso.UiController;
+import androidx.test.espresso.ViewAction;
 import androidx.test.filters.LargeTest;
 import androidx.test.filters.MediumTest;
 import androidx.viewpager2.widget.ViewPager2;
 
 import com.google.android.material.tabs.TabLayout;
 
+import org.hamcrest.Matcher;
 import org.hamcrest.Matchers;
 import org.junit.Assert;
 import org.junit.Before;
@@ -50,14 +64,19 @@
 import org.chromium.base.test.util.JniMocker;
 import org.chromium.chrome.R;
 import org.chromium.chrome.browser.browsing_data.ClearBrowsingDataFragment.DialogOption;
+import org.chromium.chrome.browser.flags.ChromeFeatureList;
 import org.chromium.chrome.browser.flags.ChromeSwitches;
 import org.chromium.chrome.browser.notifications.channels.SiteChannelsManager;
+import org.chromium.chrome.browser.profiles.Profile;
 import org.chromium.chrome.browser.settings.SettingsActivity;
 import org.chromium.chrome.browser.settings.SettingsActivityTestRule;
+import org.chromium.chrome.browser.signin.services.IdentityServicesProvider;
 import org.chromium.chrome.test.ChromeJUnit4ClassRunner;
 import org.chromium.chrome.test.ChromeTabbedActivityTestRule;
+import org.chromium.chrome.test.util.browser.Features.EnableFeatures;
 import org.chromium.chrome.test.util.browser.signin.SigninTestRule;
 import org.chromium.components.browser_ui.settings.SpinnerPreference;
+import org.chromium.components.signin.identitymanager.ConsentLevel;
 import org.chromium.content_public.browser.test.util.TestThreadUtils;
 
 import java.util.Arrays;
@@ -68,6 +87,7 @@
  */
 @RunWith(ChromeJUnit4ClassRunner.class)
 @CommandLineFlags.Add({ChromeSwitches.DISABLE_FIRST_RUN_EXPERIENCE})
+@EnableFeatures({ChromeFeatureList.ENABLE_CBD_SIGN_OUT})
 @Batch(Batch.PER_CLASS)
 public class ClearBrowsingDataFragmentTest {
     @Rule
@@ -151,6 +171,38 @@
         return settingsActivity;
     }
 
+    @Test
+    @LargeTest
+    public void testSigningOut() {
+        mSigninTestRule.addTestAccountThenSigninAndEnableSync();
+        mSettingsActivityTestRule.startSettingsActivity();
+        CriteriaHelper.pollUiThread(() -> {
+            return mSettingsActivityTestRule.getActivity().findViewById(R.id.menu_id_general_help)
+                    != null;
+        });
+
+        final ClearBrowsingDataFragment clearBrowsingDataFragment =
+                mSettingsActivityTestRule.getFragment();
+        TestThreadUtils.runOnUiThreadBlocking(() -> {
+            RecyclerView recyclerView =
+                    clearBrowsingDataFragment.getView().findViewById(R.id.recycler_view);
+            recyclerView.scrollToPosition(recyclerView.getAdapter().getItemCount() - 1);
+        });
+        onView(withText(clearBrowsingDataFragment.buildSignOutOfChromeText().toString()))
+                .perform(clickOnSignOutLink());
+        onView(withText(R.string.continue_button)).inRoot(isDialog()).perform(click());
+        CriteriaHelper.pollUiThread(
+                ()
+                        -> !IdentityServicesProvider.get()
+                                    .getIdentityManager(Profile.getLastUsedRegularProfile())
+                                    .hasPrimaryAccount(ConsentLevel.SIGNIN),
+                "Account should be signed out!");
+
+        // Footer should be hidden after sign-out.
+        onView(withText(clearBrowsingDataFragment.buildSignOutOfChromeText().toString()))
+                .check(doesNotExist());
+    }
+
     /**
      * Test that Clear Browsing Data offers two tabs and records a preference when switched.
      */
@@ -597,4 +649,34 @@
             }
         });
     }
+
+    // TODO(https://crbug.com/1334586): Move this to a test util class.
+    private ViewAction clickOnSignOutLink() {
+        return new ViewAction() {
+            @Override
+            public Matcher<View> getConstraints() {
+                return Matchers.instanceOf(TextView.class);
+            }
+
+            @Override
+            public String getDescription() {
+                return "Clicks on the sign out link in the clear browsing data footer";
+            }
+
+            @Override
+            public void perform(UiController uiController, View view) {
+                TextView textView = (TextView) view;
+                Spanned spannedString = (Spanned) textView.getText();
+                ClickableSpan[] spans =
+                        spannedString.getSpans(0, spannedString.length(), ClickableSpan.class);
+                if (spans.length != 1) {
+                    throw new NoMatchingViewException.Builder()
+                            .includeViewHierarchy(true)
+                            .withRootView(textView)
+                            .build();
+                }
+                spans[0].onClick(view);
+            }
+        };
+    }
 }
diff --git a/chrome/app/resources/generated_resources_af.xtb b/chrome/app/resources/generated_resources_af.xtb
index 5a109c0..c7dd626 100644
--- a/chrome/app/resources/generated_resources_af.xtb
+++ b/chrome/app/resources/generated_resources_af.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Raak met jou vinger aan die vingerafdruksensor</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> word tans geskandeer.</translation>
 <translation id="3615596877979647433">Sleutel word vermis. Druk ’n sleutelbordsleutel om te pasmaak</translation>
+<translation id="3616113530831147358">Oudio</translation>
 <translation id="3616741288025931835">Vee blaaidata uit …</translation>
 <translation id="3617891479562106823">Agtergronde is nie beskikbaar nie. Probeer later weer.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_am.xtb b/chrome/app/resources/generated_resources_am.xtb
index 0f08d069..1e51ebc3 100644
--- a/chrome/app/resources/generated_resources_am.xtb
+++ b/chrome/app/resources/generated_resources_am.xtb
@@ -2766,6 +2766,7 @@
 <translation id="3615073365085224194">የጣት አሻራ ዳሳሹን በእርስዎ ጣት ይንኩት</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> እየተቃኘ ነው።</translation>
 <translation id="3615596877979647433">ቁልፍ ይጎድሏል። ለማበጀት የቁልፍ ሰሌዳን ይጫኑ</translation>
+<translation id="3616113530831147358">ድምጽ</translation>
 <translation id="3616741288025931835">&amp;የአሰሳ ውሂብ አጽዳ…</translation>
 <translation id="3617891479562106823">ዳራዎች አይገኙም። ቆይተው እንደገና ይሞክሩ።</translation>
 <translation id="3619115746895587757">ካፑቺኖ</translation>
diff --git a/chrome/app/resources/generated_resources_ar.xtb b/chrome/app/resources/generated_resources_ar.xtb
index 1102f0d..a59fe35 100644
--- a/chrome/app/resources/generated_resources_ar.xtb
+++ b/chrome/app/resources/generated_resources_ar.xtb
@@ -2762,6 +2762,7 @@
 <translation id="3615073365085224194">يُرجى لمس مستشعر بصمات الإصبع بإصبعك.</translation>
 <translation id="3615579745882581859">يتم الآن فحص <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">لم يتم تخصيص مفتاح. اضغط على مفتاح في لوحة المفاتيح لتخصيصه.</translation>
+<translation id="3616113530831147358">المقاطع الصوتية</translation>
 <translation id="3616741288025931835">&amp;محو بيانات التصفح...</translation>
 <translation id="3617891479562106823">الخلفيات غير متاحة. يُرجى إعادة المحاولة لاحقًا.</translation>
 <translation id="3619115746895587757">كابتشينو</translation>
diff --git a/chrome/app/resources/generated_resources_as.xtb b/chrome/app/resources/generated_resources_as.xtb
index a005ba1..5a8c0dd5 100644
--- a/chrome/app/resources/generated_resources_as.xtb
+++ b/chrome/app/resources/generated_resources_as.xtb
@@ -2769,6 +2769,7 @@
 <translation id="3615073365085224194">আপোনাৰ আঙুলিৰে ফিংগাৰপ্ৰিণ্ট ছেন্সৰটো স্পৰ্শ কৰক</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> স্কেন কৰি থকা হৈছে।</translation>
 <translation id="3615596877979647433">কী নাই। কাষ্টমাইজ কৰিবলৈ কীব’ৰ্ডৰ এটা কী টিপক</translation>
+<translation id="3616113530831147358">অডিঅ’</translation>
 <translation id="3616741288025931835">&amp;ব্ৰাউজিং ডেটা মচক...</translation>
 <translation id="3617891479562106823">নেপথ্য উপলব্ধ নহয়। পিছত পুনৰ চেষ্টা কৰক।</translation>
 <translation id="3619115746895587757">কেপ’চিনো</translation>
diff --git a/chrome/app/resources/generated_resources_az.xtb b/chrome/app/resources/generated_resources_az.xtb
index 1773186..a764b4a 100644
--- a/chrome/app/resources/generated_resources_az.xtb
+++ b/chrome/app/resources/generated_resources_az.xtb
@@ -2755,6 +2755,7 @@
 <translation id="3615073365085224194">Barmağınızla barmaq izi sensoruna toxunun</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> skan edildi.</translation>
 <translation id="3615596877979647433">Düymə yoxdur. Fərdiləşdirmək üçün klaviatura düyməsini basın</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Brauzinq tarixçəsini təmizləyin...</translation>
 <translation id="3617891479562106823">Arxa fonlar əlçatan deyil. Sonra yenidən cəhd edin.</translation>
 <translation id="3619115746895587757">Kappuçino</translation>
diff --git a/chrome/app/resources/generated_resources_be.xtb b/chrome/app/resources/generated_resources_be.xtb
index e0fc664..e5f47b8d 100644
--- a/chrome/app/resources/generated_resources_be.xtb
+++ b/chrome/app/resources/generated_resources_be.xtb
@@ -2759,6 +2759,7 @@
 <translation id="3615073365085224194">Дакраніцеся пальцам да сканера адбіткаў пальцаў</translation>
 <translation id="3615579745882581859">Выконваецца праверка файла "<ph name="FILE_NAME" />".</translation>
 <translation id="3615596877979647433">Клавіша не ўказана. Націсніце клавішу на клавіятуры, каб выканаць наладжванне.</translation>
+<translation id="3616113530831147358">Аўдыя</translation>
 <translation id="3616741288025931835">&amp;Выдаліць гісторыю праглядаў...</translation>
 <translation id="3617891479562106823">Змяненне фону недаступнае. Паўтарыце спробу пазней.</translation>
 <translation id="3619115746895587757">Капучына</translation>
diff --git a/chrome/app/resources/generated_resources_bg.xtb b/chrome/app/resources/generated_resources_bg.xtb
index 97f1007a..fe88009 100644
--- a/chrome/app/resources/generated_resources_bg.xtb
+++ b/chrome/app/resources/generated_resources_bg.xtb
@@ -2768,6 +2768,7 @@
 <translation id="3615073365085224194">Докоснете сензора за отпечатъци с пръста си</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> се сканира.</translation>
 <translation id="3615596877979647433">Липсва клавиш. Натиснете клавиш от клавиатурата, за да персонализирате</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp;Изчистване на данните за сърфирането...</translation>
 <translation id="3617891479562106823">Фоновете не са налице. Опитайте отново по-късно.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_bn.xtb b/chrome/app/resources/generated_resources_bn.xtb
index 496622c..c182a8a 100644
--- a/chrome/app/resources/generated_resources_bn.xtb
+++ b/chrome/app/resources/generated_resources_bn.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">আঙ্গুলের ছাপের সেন্সরটিকে আপনার আঙ্গুল দিয়ে টাচ করুন</translation>
 <translation id="3615579745882581859">এই <ph name="FILE_NAME" /> স্ক্যান করা হচ্ছে।</translation>
 <translation id="3615596877979647433">কোনও 'কী' নেই কাস্টমাইজ করতে, কীবোর্ডের কোনও 'কী' প্রেস করুন</translation>
+<translation id="3616113530831147358">অডিও</translation>
 <translation id="3616741288025931835">ব্রাউজ করা ডেটা সাফ করুন...</translation>
 <translation id="3617891479562106823">ব্যাকগ্রাউন্ডগুলি উপলভ্য নয়। পরে আবার চেষ্টা করুন।</translation>
 <translation id="3619115746895587757">ক্যাপুচিনো</translation>
diff --git a/chrome/app/resources/generated_resources_bs.xtb b/chrome/app/resources/generated_resources_bs.xtb
index d018910..eb346ed 100644
--- a/chrome/app/resources/generated_resources_bs.xtb
+++ b/chrome/app/resources/generated_resources_bs.xtb
@@ -2770,6 +2770,7 @@
 <translation id="3615073365085224194">Prstom dodirnite senzor za otisak prsta</translation>
 <translation id="3615579745882581859">Fajl <ph name="FILE_NAME" /> se skenira.</translation>
 <translation id="3615596877979647433">Nedostaje tipka. Pritisnite tipku tastature da je prilagodite</translation>
+<translation id="3616113530831147358">Zvuk</translation>
 <translation id="3616741288025931835">&amp;Obriši podatke pregledanja...</translation>
 <translation id="3617891479562106823">Pozadine nisu dostupne. Pokušajte ponovo kasnije.</translation>
 <translation id="3619115746895587757">Kapućino</translation>
diff --git a/chrome/app/resources/generated_resources_ca.xtb b/chrome/app/resources/generated_resources_ca.xtb
index a95a753..587df28 100644
--- a/chrome/app/resources/generated_resources_ca.xtb
+++ b/chrome/app/resources/generated_resources_ca.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">Toca el sensor d'empremtes digitals amb el dit</translation>
 <translation id="3615579745882581859">S'està analitzant <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Falta la tecla. Prem una tecla del teclat per personalitzar-la.</translation>
+<translation id="3616113530831147358">Àudio</translation>
 <translation id="3616741288025931835">&amp;Elimina les dades de navegació...</translation>
 <translation id="3617891479562106823">Els fons de pantalla no estan disponibles. Torna-ho a provar més tard.</translation>
 <translation id="3619115746895587757">Caputxino</translation>
diff --git a/chrome/app/resources/generated_resources_cs.xtb b/chrome/app/resources/generated_resources_cs.xtb
index 1e87ee9..f501d07 100644
--- a/chrome/app/resources/generated_resources_cs.xtb
+++ b/chrome/app/resources/generated_resources_cs.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">Dotkněte se prstem snímače otisků prstů</translation>
 <translation id="3615579745882581859">Probíhá kontrola souboru <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Klávesa chybí. Stisknutím klávesy přizpůsobíte</translation>
+<translation id="3616113530831147358">Zvuk</translation>
 <translation id="3616741288025931835">&amp;Smazat údaje o prohlížení...</translation>
 <translation id="3617891479562106823">Pozadí nejsou k dispozici. Zkuste to znovu později.</translation>
 <translation id="3619115746895587757">Kapučíno</translation>
diff --git a/chrome/app/resources/generated_resources_cy.xtb b/chrome/app/resources/generated_resources_cy.xtb
index d1bfc1c..242a9ac0 100644
--- a/chrome/app/resources/generated_resources_cy.xtb
+++ b/chrome/app/resources/generated_resources_cy.xtb
@@ -2775,6 +2775,7 @@
 <translation id="3615073365085224194">Cyffyrddwch y synhwyrydd olion bysell gyda'ch bys</translation>
 <translation id="3615579745882581859">Mae <ph name="FILE_NAME" /> wrthi'n cael ei sganio.</translation>
 <translation id="3615596877979647433">Mae'r fysell ar goll. Pwyswch fysell bysellfwrdd i bersonoleiddio</translation>
+<translation id="3616113530831147358">Sain</translation>
 <translation id="3616741288025931835">&amp;Clirio Data Pori…</translation>
 <translation id="3617891479562106823">Nid yw cefndiroedd ar gael. Rhowch gynnig arall arni'n nes ymlaen.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_da.xtb b/chrome/app/resources/generated_resources_da.xtb
index 5b7f06d2..aaf0c9a 100644
--- a/chrome/app/resources/generated_resources_da.xtb
+++ b/chrome/app/resources/generated_resources_da.xtb
@@ -2773,6 +2773,7 @@
 <translation id="3615073365085224194">Tryk på fingeraftrykslæseren med din finger</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> scannes.</translation>
 <translation id="3615596877979647433">Du mangler at angive en tast. Tryk på en tastaturtast for at tilpasse den</translation>
+<translation id="3616113530831147358">Lyd</translation>
 <translation id="3616741288025931835">&amp;Slet browserdata...</translation>
 <translation id="3617891479562106823">Baggrunde er utilgængelige. Prøv igen senere.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_de.xtb b/chrome/app/resources/generated_resources_de.xtb
index 95b8cbd8..8b305178 100644
--- a/chrome/app/resources/generated_resources_de.xtb
+++ b/chrome/app/resources/generated_resources_de.xtb
@@ -2754,6 +2754,7 @@
 <translation id="3615073365085224194">Berühre den Fingerabdrucksensor mit dem Finger</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> wird gegenwärtig gescannt</translation>
 <translation id="3615596877979647433">Keine Taste zugewiesen. Drücke zum Anpassen eine Taste auf der Tastatur.</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Browserdaten löschen...</translation>
 <translation id="3617891479562106823">Hintergründe sind nicht verfügbar. Bitte versuche es später noch einmal.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_el.xtb b/chrome/app/resources/generated_resources_el.xtb
index 1591e7b..4f0c2ea 100644
--- a/chrome/app/resources/generated_resources_el.xtb
+++ b/chrome/app/resources/generated_resources_el.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Αγγίξτε τον αισθητήρα δακτυλικών αποτυπωμάτων με το δάχτυλό σας</translation>
 <translation id="3615579745882581859">Πραγματοποιείται σάρωση του αρχείου <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Το πλήκτρο λείπει. Πατήστε ένα πλήκτρο του πληκτρολογίου για προσαρμογή.</translation>
+<translation id="3616113530831147358">Ήχος</translation>
 <translation id="3616741288025931835">&amp;Διαγραφή δεδομένων περιήγησης...</translation>
 <translation id="3617891479562106823">Τα φόντα δεν είναι διαθέσιμα. Δοκιμάστε ξανά αργότερα.</translation>
 <translation id="3619115746895587757">Καπουτσίνο</translation>
diff --git a/chrome/app/resources/generated_resources_en-GB.xtb b/chrome/app/resources/generated_resources_en-GB.xtb
index 0d92eb5..dbef1cb 100644
--- a/chrome/app/resources/generated_resources_en-GB.xtb
+++ b/chrome/app/resources/generated_resources_en-GB.xtb
@@ -2777,6 +2777,7 @@
 <translation id="3615073365085224194">Touch the fingerprint sensor with your finger</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> is being scanned.</translation>
 <translation id="3615596877979647433">Key is missing. Press a keyboard key to customise</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Clear Browsing Data...</translation>
 <translation id="3617891479562106823">Backgrounds are unavailable. Try again later.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_es-419.xtb b/chrome/app/resources/generated_resources_es-419.xtb
index c38eb81a..e5feba4 100644
--- a/chrome/app/resources/generated_resources_es-419.xtb
+++ b/chrome/app/resources/generated_resources_es-419.xtb
@@ -2754,6 +2754,7 @@
 <translation id="3615073365085224194">Toca el sensor de huellas dactilares con el dedo</translation>
 <translation id="3615579745882581859">Se está analizando <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">La tecla no está configurada. Presiona una tecla del teclado para personalizarla</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">Eliminar datos de navega&amp;ción...</translation>
 <translation id="3617891479562106823">Los fondos no están disponibles. Vuelve a intentarlo más tarde.</translation>
 <translation id="3619115746895587757">Capuchino</translation>
diff --git a/chrome/app/resources/generated_resources_es.xtb b/chrome/app/resources/generated_resources_es.xtb
index 09a7dd8..9b19e2c 100644
--- a/chrome/app/resources/generated_resources_es.xtb
+++ b/chrome/app/resources/generated_resources_es.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">Toca el sensor de huellas digitales con el dedo</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> se está analizando.</translation>
 <translation id="3615596877979647433">Falta la tecla. Pulsa una tecla del teclado para personalizarla.</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Borrar datos de navegación...</translation>
 <translation id="3617891479562106823">Los fondos no están disponibles. Inténtalo de nuevo más tarde.</translation>
 <translation id="3619115746895587757">Capuchino</translation>
diff --git a/chrome/app/resources/generated_resources_et.xtb b/chrome/app/resources/generated_resources_et.xtb
index 759dac29..5580764 100644
--- a/chrome/app/resources/generated_resources_et.xtb
+++ b/chrome/app/resources/generated_resources_et.xtb
@@ -2763,6 +2763,7 @@
 <translation id="3615073365085224194">Puudutage oma sõrmega sõrmejäljeandurit</translation>
 <translation id="3615579745882581859">Faili <ph name="FILE_NAME" /> skannitakse.</translation>
 <translation id="3615596877979647433">Klahv on puudu. Kohandamiseks vajutage klaviatuuri klahvi.</translation>
+<translation id="3616113530831147358">Heli</translation>
 <translation id="3616741288025931835">Kustuta sirvi&amp;mise andmed...</translation>
 <translation id="3617891479562106823">Taustad pole saadaval. Proovige hiljem uuesti</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_eu.xtb b/chrome/app/resources/generated_resources_eu.xtb
index addd108..2b3e684 100644
--- a/chrome/app/resources/generated_resources_eu.xtb
+++ b/chrome/app/resources/generated_resources_eu.xtb
@@ -2756,6 +2756,7 @@
 <translation id="3615073365085224194">Ukitu hatz-marken sentsorea hatzarekin</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> aztertzen ari gara.</translation>
 <translation id="3615596877979647433">Tekla falta da. Sakatu teklatuko tekla bat fokuratuta dagoena pertsonalizatzeko</translation>
+<translation id="3616113530831147358">Audioa</translation>
 <translation id="3616741288025931835">&amp;Garbitu arakatze-datuak...</translation>
 <translation id="3617891479562106823">Atzeko planoak ez daude erabilgarri. Saiatu berriro geroago.</translation>
 <translation id="3619115746895587757">Kaputxinoa</translation>
diff --git a/chrome/app/resources/generated_resources_fa.xtb b/chrome/app/resources/generated_resources_fa.xtb
index bcc1808..0ae9bb5 100644
--- a/chrome/app/resources/generated_resources_fa.xtb
+++ b/chrome/app/resources/generated_resources_fa.xtb
@@ -2769,6 +2769,7 @@
 <translation id="3615073365085224194">حسگر اثر انگشت را با انگشتانتان لمس کنید</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> درحال اسکن است.</translation>
 <translation id="3615596877979647433">کلید وجود ندارد. برای سفارشی کردن، یکی از کلیدهای صفحه‌کلید را فشار دهید</translation>
+<translation id="3616113530831147358">صوتی</translation>
 <translation id="3616741288025931835">&amp;پاک کردن داده‌های مرور...</translation>
 <translation id="3617891479562106823">پس‌زمینه‌ها دردسترس نیست. بعداً دوباره امتحان کنید.</translation>
 <translation id="3619115746895587757">کاپوچینو</translation>
diff --git a/chrome/app/resources/generated_resources_fi.xtb b/chrome/app/resources/generated_resources_fi.xtb
index 679a3be5..71d73d0 100644
--- a/chrome/app/resources/generated_resources_fi.xtb
+++ b/chrome/app/resources/generated_resources_fi.xtb
@@ -2771,6 +2771,7 @@
 <translation id="3615073365085224194">Kosketa sormenjälkitunnistinta sormellasi.</translation>
 <translation id="3615579745882581859">Skannataan: <ph name="FILE_NAME" /></translation>
 <translation id="3615596877979647433">Näppäin puuttuu. Yksilöi painamalla näppäimistön näppäintä</translation>
+<translation id="3616113530831147358">Ääni</translation>
 <translation id="3616741288025931835">&amp;Poista selaustiedot...</translation>
 <translation id="3617891479562106823">Taustat eivät ole käytettävissä. Yritä myöhemmin uudelleen.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_fil.xtb b/chrome/app/resources/generated_resources_fil.xtb
index 821c630..324afacb 100644
--- a/chrome/app/resources/generated_resources_fil.xtb
+++ b/chrome/app/resources/generated_resources_fil.xtb
@@ -2773,6 +2773,7 @@
 <translation id="3615073365085224194">Pindutin ang sensor para sa fingerprint gamit ang iyong daliri</translation>
 <translation id="3615579745882581859">Sina-scan ang <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Nawawala ang key. Pumindot ng key sa keyboard para mag-customize</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;I-clear ang Data sa Pag-browse...</translation>
 <translation id="3617891479562106823">Hindi available ang mga background. Subukang muli sa ibang pagkakataon.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_fr-CA.xtb b/chrome/app/resources/generated_resources_fr-CA.xtb
index 53d0d8d..ceb62df 100644
--- a/chrome/app/resources/generated_resources_fr-CA.xtb
+++ b/chrome/app/resources/generated_resources_fr-CA.xtb
@@ -2759,6 +2759,7 @@
 <translation id="3615073365085224194">Touchez le capteur d'empreintes digitales avec votre doigt</translation>
 <translation id="3615579745882581859">Le fichier <ph name="FILE_NAME" /> est en train d'être analysé.</translation>
 <translation id="3615596877979647433">La clé est manquante. Appuyez sur une touche du clavier pour la personnaliser</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">Effa&amp;cer les données de navigation…</translation>
 <translation id="3617891479562106823">Les arrière-plans ne sont pas disponibles. Réessayez plus tard.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_fr.xtb b/chrome/app/resources/generated_resources_fr.xtb
index ea83c39a..fe7c012 100644
--- a/chrome/app/resources/generated_resources_fr.xtb
+++ b/chrome/app/resources/generated_resources_fr.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">Appuyez avec un doigt sur le lecteur d'empreinte digitale</translation>
 <translation id="3615579745882581859">Analyse de <ph name="FILE_NAME" />…</translation>
 <translation id="3615596877979647433">Touche manquante. Appuyez sur une touche du clavier pour la personnaliser</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Effacer les données de navigation...</translation>
 <translation id="3617891479562106823">Les arrière-plans sont indisponibles. Réessayez plus tard.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_gl.xtb b/chrome/app/resources/generated_resources_gl.xtb
index c8efda7..13e45376 100644
--- a/chrome/app/resources/generated_resources_gl.xtb
+++ b/chrome/app/resources/generated_resources_gl.xtb
@@ -2755,6 +2755,7 @@
 <translation id="3615073365085224194">Toca o sensor de impresión dixital co dedo</translation>
 <translation id="3615579745882581859">Estase analizando <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Falta a tecla. Preme unha tecla para personalizala</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Borrar datos de navegación...</translation>
 <translation id="3617891479562106823">Os fondos non están dispoñibles. Téntao de novo máis tarde.</translation>
 <translation id="3619115746895587757">Capuchino</translation>
diff --git a/chrome/app/resources/generated_resources_gu.xtb b/chrome/app/resources/generated_resources_gu.xtb
index 6b61a01..d68cd67 100644
--- a/chrome/app/resources/generated_resources_gu.xtb
+++ b/chrome/app/resources/generated_resources_gu.xtb
@@ -2755,6 +2755,7 @@
 <translation id="3615073365085224194">તમારી આંગળી વડે ફિંગરપ્રિન્ટ સેન્સરને સ્પર્શ કરો</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" />ને સ્કૅન કરવામાં આવી રહી છે.</translation>
 <translation id="3615596877979647433">કી ખૂટે છે. કસ્ટમાઇઝ કરવા માટે કીબોર્ડની કી દબાવો</translation>
+<translation id="3616113530831147358">ઑડિઓ</translation>
 <translation id="3616741288025931835">બ્રાઉઝિંગ ડેટા &amp;સાફ કરો...</translation>
 <translation id="3617891479562106823">બૅકગ્રાઉન્ડ અનુપલબ્ધ છે. થોડા સમય પછી ફરી પ્રયાસ કરો.</translation>
 <translation id="3619115746895587757">કૅપુચિનો</translation>
diff --git a/chrome/app/resources/generated_resources_hi.xtb b/chrome/app/resources/generated_resources_hi.xtb
index 5e62b52..48442e3 100644
--- a/chrome/app/resources/generated_resources_hi.xtb
+++ b/chrome/app/resources/generated_resources_hi.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">उंगली से फ़िंगरप्रिंट सेंसर को छुएं</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> स्कैन हो रही है.</translation>
 <translation id="3615596877979647433">किसी कुंजी को नहीं दबाया गया. पसंद के मुताबिक बनाने के लिए, कीबोर्ड की कुंजी को दबाएं</translation>
+<translation id="3616113530831147358">ऑडियो</translation>
 <translation id="3616741288025931835">ब्राउज़िंग डेटा &amp;साफ़ करें...</translation>
 <translation id="3617891479562106823">बैकग्राउंड उपलब्ध नहीं हैं. बाद में फिर से कोशिश करें.</translation>
 <translation id="3619115746895587757">कैपुचिनो</translation>
diff --git a/chrome/app/resources/generated_resources_hr.xtb b/chrome/app/resources/generated_resources_hr.xtb
index 9402658..a04321e8 100644
--- a/chrome/app/resources/generated_resources_hr.xtb
+++ b/chrome/app/resources/generated_resources_hr.xtb
@@ -2760,6 +2760,7 @@
 <translation id="3615073365085224194">Prislonite prst na senzor otiska prsta</translation>
 <translation id="3615579745882581859">U tijeku je pregled datoteke <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Nedostaje tipka. Pritisnite tipku na tipkovnici da biste je prilagodili</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Obriši podatke o pregledavanju...</translation>
 <translation id="3617891479562106823">Pozadine nisu dostupne. Pokušajte ponovo kasnije.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_hu.xtb b/chrome/app/resources/generated_resources_hu.xtb
index e2842eb..6553b2b 100644
--- a/chrome/app/resources/generated_resources_hu.xtb
+++ b/chrome/app/resources/generated_resources_hu.xtb
@@ -2770,6 +2770,7 @@
 <translation id="3615073365085224194">Érintse ujját az ujjlenyomat-érzékelőhöz</translation>
 <translation id="3615579745882581859">Folyamatban van a(z) <ph name="FILE_NAME" /> ellenőrzése.</translation>
 <translation id="3615596877979647433">Hiányzó gomb. Nyomja le a személyre szabni kívánt billentyűt.</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Böngészés adatainak törlése...</translation>
 <translation id="3617891479562106823">A hátterek nem állnak rendelkezésre. Próbálja újra később.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_hy.xtb b/chrome/app/resources/generated_resources_hy.xtb
index aec920f1..d255126 100644
--- a/chrome/app/resources/generated_resources_hy.xtb
+++ b/chrome/app/resources/generated_resources_hy.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">Մատով հպեք մատնահետքերի սկաներին</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ֆայլը սկանավորվում է։</translation>
 <translation id="3615596877979647433">Ստեղնը նշված չէ։ Սեղմեք այն՝ կարգավորելու համար։</translation>
+<translation id="3616113530831147358">Աուդիո</translation>
 <translation id="3616741288025931835">&amp;Մաքրել դիտարկումների տվյալները…</translation>
 <translation id="3617891479562106823">Ֆոնային պատկերները հասանելի չեն: Փորձեք ավելի ուշ:</translation>
 <translation id="3619115746895587757">Կապուչինո</translation>
diff --git a/chrome/app/resources/generated_resources_id.xtb b/chrome/app/resources/generated_resources_id.xtb
index 1e93aca27..3d78fc3 100644
--- a/chrome/app/resources/generated_resources_id.xtb
+++ b/chrome/app/resources/generated_resources_id.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Sentuh sensor sidik jari dengan jari Anda</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> sedang dipindai.</translation>
 <translation id="3615596877979647433">Tombol tidak ada. Tekan tombol keyboard untuk menyesuaikan</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Hapus Data browsing...</translation>
 <translation id="3617891479562106823">Background tidak tersedia. Coba lagi nanti.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_is.xtb b/chrome/app/resources/generated_resources_is.xtb
index 49564ce1..55101db 100644
--- a/chrome/app/resources/generated_resources_is.xtb
+++ b/chrome/app/resources/generated_resources_is.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Snertu fingrafaralesarann með fingrinum</translation>
 <translation id="3615579745882581859">Verið er að skanna <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Lykil vantar. Ýttu á lyklaborðslykil til að sérsníða</translation>
+<translation id="3616113530831147358">Hljóð</translation>
 <translation id="3616741288025931835">Hreinsa vafragögn...</translation>
 <translation id="3617891479562106823">Bakgrunnar eru ekki tiltækir. Reyndu aftur síðar.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_it.xtb b/chrome/app/resources/generated_resources_it.xtb
index f1a31482..f475a63 100644
--- a/chrome/app/resources/generated_resources_it.xtb
+++ b/chrome/app/resources/generated_resources_it.xtb
@@ -784,7 +784,7 @@
 <translation id="173628468822554835">Ok. Per impostazione predefinita, i nuovi siti che visiti non ti invieranno notifiche.</translation>
 <translation id="1736419249208073774">Esplora</translation>
 <translation id="1737968601308870607">Segnala bug</translation>
-<translation id="1739684185846730053">Le prove di Privacy Sandbox sono ancora in fase di sviluppo attivo e sono disponibili soltanto in alcune aree geografiche. Per il momento i siti possono provare Privacy Sandbox continuando a usare le attuali tecnologie web quali i cookie di terze parti.</translation>
+<translation id="1739684185846730053">Le prove di Privacy Sandbox sono ancora in fase di sviluppo attivo e sono disponibili soltanto in alcune regioni. Per il momento i siti possono provare Privacy Sandbox continuando a usare le attuali tecnologie web quali i cookie di terze parti.</translation>
 <translation id="1741190788710022490">Ricarica adattiva</translation>
 <translation id="174123615272205933">Personalizzati</translation>
 <translation id="1741314857973421784">Continua</translation>
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">Tocca il sensore di impronte digitali con il dito</translation>
 <translation id="3615579745882581859">È in corso la scansione di <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Tasto mancante. Premi un tasto della tastiera per personalizzarlo</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Cancella dati di navigazione...</translation>
 <translation id="3617891479562106823">Gli sfondi non sono disponibili. Riprova più tardi.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
@@ -5194,7 +5195,7 @@
 <translation id="6027945736510816438">Intendevi <ph name="WEBSITE" />?</translation>
 <translation id="6028117231645531007">Aggiungi impronta</translation>
 <translation id="6031600495088157824">Opzioni di immissione nella barra degli strumenti</translation>
-<translation id="6032091552407840792">Questa prova è attiva soltanto in <ph name="BEGIN_LINK" />alcune aree geografiche<ph name="END_LINK" />.</translation>
+<translation id="6032091552407840792">Questa prova è attiva soltanto in <ph name="BEGIN_LINK" />alcune regioni<ph name="END_LINK" />.</translation>
 <translation id="6032715498678347852">Per consentire a un'estensione di accedere a questo sito, fai clic sull'estensione.</translation>
 <translation id="6032912588568283682">File system</translation>
 <translation id="603539183851330738">Pulsante per annullare la correzione automatica. Ripristina <ph name="TYPED_WORD" />.  Premi Invio per attivare o Esc per ignorare.</translation>
@@ -7080,7 +7081,7 @@
 <translation id="7877451762676714207">Errore del server sconosciuto. Riprova o contatta l'amministratore del server.</translation>
 <translation id="7879631849810108578">Scorciatoia impostata: <ph name="IDS_SHORT_SET_COMMAND" /></translation>
 <translation id="7880685873361171388">Quando la funzionalità è attivata e lo stato è attivo, Chrome usa la tua cronologia di navigazione di 7 giorni per definire un gruppo, o "coorte", di cui fai parte. Gli inserzionisti possono selezionare annunci per il gruppo. La cronologia di navigazione rimane privata sul tuo dispositivo. Questa prova è attiva soltanto in
-    <ph name="BEGIN_LINK" />alcune aree geografiche<ph name="END_LINK" />.</translation>
+    <ph name="BEGIN_LINK" />alcune regioni<ph name="END_LINK" />.</translation>
 <translation id="7880823633812189969">I dati locali verranno eliminati al riavvio</translation>
 <translation id="7881066108824108340">DNS</translation>
 <translation id="7881483672146086348">Visualizza account</translation>
diff --git a/chrome/app/resources/generated_resources_iw.xtb b/chrome/app/resources/generated_resources_iw.xtb
index 15f1204..478a4252 100644
--- a/chrome/app/resources/generated_resources_iw.xtb
+++ b/chrome/app/resources/generated_resources_iw.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">יש לגעת עם האצבע בחיישן טביעת האצבע</translation>
 <translation id="3615579745882581859">מתבצעת סריקה בקובץ <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">המפתח חסר. יש להקיש על מקש מקלדת כלשהו כדי להתאים אישית</translation>
+<translation id="3616113530831147358">אודיו</translation>
 <translation id="3616741288025931835">&amp;ניקוי נתוני גלישה...</translation>
 <translation id="3617891479562106823">רקעים אינם זמינים. צריך לנסות שוב מאוחר יותר.</translation>
 <translation id="3619115746895587757">קפוצ'ינו</translation>
diff --git a/chrome/app/resources/generated_resources_ja.xtb b/chrome/app/resources/generated_resources_ja.xtb
index 95ae85b6..855d1f04 100644
--- a/chrome/app/resources/generated_resources_ja.xtb
+++ b/chrome/app/resources/generated_resources_ja.xtb
@@ -2750,6 +2750,7 @@
 <translation id="3615073365085224194">指紋認証センサーを指でタッチしてください</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> をスキャンしています。</translation>
 <translation id="3615596877979647433">キーが設定されていません。カスタマイズするには、キーボードのキーを押してください</translation>
+<translation id="3616113530831147358">音声</translation>
 <translation id="3616741288025931835">閲覧履歴を消去(&amp;C)...</translation>
 <translation id="3617891479562106823">背景を利用できません。しばらくしてからもう一度お試しください。</translation>
 <translation id="3619115746895587757">カプチーノ</translation>
diff --git a/chrome/app/resources/generated_resources_ka.xtb b/chrome/app/resources/generated_resources_ka.xtb
index d2f176ff..d6b140e 100644
--- a/chrome/app/resources/generated_resources_ka.xtb
+++ b/chrome/app/resources/generated_resources_ka.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">შეეხეთ თითის ანაბეჭდის სენსორს თითით</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> სკანირდება.</translation>
 <translation id="3615596877979647433">აკლია კლავიში. მოსარგებად დააჭირეთ კლავიატურის კლავიშს.</translation>
+<translation id="3616113530831147358">აუდიო</translation>
 <translation id="3616741288025931835">დათვალიერების მონაცემების &amp;გასუფთავება…</translation>
 <translation id="3617891479562106823">ფონები მიუწვდომელია. ცადეთ მოგვიანებით.</translation>
 <translation id="3619115746895587757">კაპუჩინო</translation>
diff --git a/chrome/app/resources/generated_resources_kk.xtb b/chrome/app/resources/generated_resources_kk.xtb
index 823e2830..fe22186 100644
--- a/chrome/app/resources/generated_resources_kk.xtb
+++ b/chrome/app/resources/generated_resources_kk.xtb
@@ -2753,6 +2753,7 @@
 <translation id="3615073365085224194">Саусақ ізін оқу сканерін саусағыңызбен түртіңіз.</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> сканерленуде.</translation>
 <translation id="3615596877979647433">Перне тағайындалмаған. Реттеу үшін пернетақта пернесін басыңыз.</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp;Шолу деректерін жою…</translation>
 <translation id="3617891479562106823">Фондар жоқ. Кейінірек қайталап көріңіз.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_km.xtb b/chrome/app/resources/generated_resources_km.xtb
index 70338405..2a2cfd1 100644
--- a/chrome/app/resources/generated_resources_km.xtb
+++ b/chrome/app/resources/generated_resources_km.xtb
@@ -382,6 +382,7 @@
 <translation id="1374844444528092021">វិញ្ញាបនប័ត្រដែលបានតម្រូវដោយបណ្តាញ "<ph name="NETWORK_NAME" />" មិនត្រូវបានតំឡើង ឬមិនមានសុពលភាពទៀតទេ។  សូមទទួលយកវិញ្ញាបនប័ត្រថ្មី ហើយព្យាយាមភ្ជាប់ម្តងទៀត។</translation>
 <translation id="1375321115329958930">ពាក្យសម្ងាត់ដែលបានរក្សាទុក</translation>
 <translation id="1375557162880614858">តើអ្នកចង់​បើកដំណើរការ ChromeVox ដែលជា​កម្មវិធី​អានអេក្រង់ភ្ជាប់មកជាមួយស្រាប់​សម្រាប់ ChromeOS Flex ដែរទេ?</translation>
+<translation id="1375938286942050085">បានបញ្ចប់​ការរៀបចំ​ហើយ! បន្ទាប់​មក រៀបចំ​ឧបករណ៍​របស់​អ្នក​ឱ្យរួចរាល់​សម្រាប់​​ការ​លេងហ្គេម</translation>
 <translation id="137651782282853227">អាសយដ្ឋាន​ដែល​បាន​រក្សាទុក​នឹង​បង្ហាញ​នៅទីនេះ</translation>
 <translation id="1376771218494401509">ឈ្មោះ និងវិនដូ...</translation>
 <translation id="1377600615067678409">រំលងឥឡូវនេះ</translation>
@@ -396,6 +397,7 @@
 <translation id="138784436342154190">ស្តារទំព័រចាប់ផ្តើមលំនាំដើម?</translation>
 <translation id="1388253969141979417">អនុញ្ញាតឱ្យប្រើមីក្រូហ្វូនរបស់អ្នក</translation>
 <translation id="1388728792929436380"><ph name="DEVICE_TYPE" /> ​នឹងចាប់ផ្ដើម​ឡើងវិញ នៅពេលបញ្ចប់​ការដំឡើងកំណែ​។</translation>
+<translation id="1389601498324964367">ទំហំ​ផ្ទុកដែល​គ្រប់គ្រង​ដោយ​កម្រិតកំណត់</translation>
 <translation id="139013308650923562">អនុញ្ញាតឱ្យប្រើពុម្ព​អក្សរ​ ដែលបានដំឡើងនៅលើឧបករណ៍របស់អ្នក</translation>
 <translation id="1390548061267426325">បើកជាផ្ទាំងធម្មតា</translation>
 <translation id="1390907927270446471"><ph name="PROFILE_USERNAME" /> មិនទទួលបានសិទ្ធិក្នុងការបោះពុម្ពតាម <ph name="PRINTER_NAME" /> ទេ។ សូមទាក់ទង​អ្នកគ្រប់គ្រង​របស់អ្នក។</translation>
@@ -1075,6 +1077,7 @@
 <translation id="1992924914582925289">លុបចេញពីឧបករណ៍</translation>
 <translation id="1994173015038366702">URL គេហទំព័រ</translation>
 <translation id="1995916364271252349">គ្រប់គ្រង​ថាតើ​ព័ត៌មាន​អ្វីខ្លះ​ដែលគេហទំព័រ​អាច​ប្រើ និង​បង្ហាញ (ទីតាំង កាមេរ៉ា ផ្ទាំងលោតឡើង និង​ច្រើនទៀត)</translation>
+<translation id="1997433994358798851">Chrome ត្រូវការ​ការ​អនុញ្ញាត​ឱ្យ​ប្រើប្រាស់​ប៊្លូធូស ដើម្បី​ភ្ជាប់​ទៅ​ឧបករណ៍​របស់​អ្នក</translation>
 <translation id="1997616988432401742">វិញ្ញាបនបត្ររបស់អ្នក</translation>
 <translation id="1999115740519098545">នៅពេលចាប់ផ្តើមដំណើរការ</translation>
 <translation id="2000419248597011803">បញ្ជូនការស្វែងរក និងខូគី​មួយចំនួនពី​របារអាសយដ្ឋាន និង​ប្រអប់​ស្វែងរកទៅ​ម៉ាស៊ីន​ស្វែងរក​លំនាំដើម​របស់​អ្នក</translation>
@@ -1739,6 +1742,7 @@
 <translation id="25899519884572181">ចាកចេញពីមុខងារអាន</translation>
 <translation id="2593499352046705383">មុនពេលចាប់ផ្ដើម សូមប្រាកដថា អ្នកមានការបម្រុងទុកទិន្នន័យរបស់អ្នក។ ការដំឡើង <ph name="DEVICE_OS" /> នឹងលុបពីលើថាស​រឹងរបស់អ្នក។ ស្វែងយល់បន្ថែមតាមរយៈ g.co/flex/InstallGuide។</translation>
 <translation id="2594999711683503743">ស្វែងរក​តាម Google ឬ​វាយបញ្ចូល URL</translation>
+<translation id="2599048253926156421">បាន​ចម្លង​ឈ្មោះអ្នកប្រើប្រាស់ទៅ​ក្នុង​ឃ្លីបបត</translation>
 <translation id="2602501489742255173">អូស​ឡើងលើ ដើម្បី​ចាប់ផ្ដើម</translation>
 <translation id="2603115962224169880">សម្អាត​កុំព្យូទ័រ</translation>
 <translation id="2603355571917519942">អាចប្រើ​មុខងារ Voice Match បានហើយ</translation>
@@ -1962,6 +1966,7 @@
 <translation id="2804043232879091219">មិនអាចបើក​កម្មវិធីរុករកតាម​អ៊ីនធឺណិត​ផ្សេងបានទេ</translation>
 <translation id="2804667941345577550">អ្នក​នឹង​ត្រូវនាំចេញ​ពី​គេហទំព័រ​នេះ រួមទាំង​នៅក្នុង​ផ្ទាំង​បើក​ផងដែរ</translation>
 <translation id="2804680522274557040">បានបិទ​កាមេរ៉ា</translation>
+<translation id="280518252911523675">ប្រសិនបើ​អ្នកបន្ត​ដោយ​មិន​បញ្ចូល​ពាក្យសម្ងាត់​ចាស់​របស់​អ្នក​ទេ ទិន្នន័យ​មូលដ្ឋាន​របស់​អ្នក​នឹង​ត្រូវ​បានលុប។ អ្នកនឹង​ចូល​ដោយ​ប្រើ​គណនី Google របស់​អ្នក ដើម្បី​រៀបចំ​អ្នកប្រើប្រាស់ម្នាក់នេះ​ម្ដង​ទៀត។</translation>
 <translation id="2805539617243680210">រួចរាល់អស់ហើយ!</translation>
 <translation id="2805646850212350655">ប្រព័ន្ធឯកសារអ៊ីនគ្រីប Microsoft</translation>
 <translation id="2805756323405976993">កម្មវិធី</translation>
@@ -2772,6 +2777,7 @@
 <translation id="3615073365085224194">ប៉ះ​ឧបករណ៍​ចាប់ស្នាមម្រាមដៃដោយប្រើម្រាម​ដៃរបស់អ្នក</translation>
 <translation id="3615579745882581859">កំពុង​ស្កេន <ph name="FILE_NAME" /> ។</translation>
 <translation id="3615596877979647433">បាត់​គ្រាប់ចុច​ដែល​ចង​ភ្ជាប់។ ចុច​គ្រាប់ចុច​ក្ដារចុច ដើម្បីប្ដូរ​តាមបំណង</translation>
+<translation id="3616113530831147358">សម្លេង</translation>
 <translation id="3616741288025931835">ជម្រះទិន្នន័យរុករក...</translation>
 <translation id="3617891479562106823">មិនមាន​ផ្ទៃ​ខាងក្រោយ​ទេ។ សូម​ព្យាយាម​ម្ដងទៀត​នៅពេល​ក្រោយ។</translation>
 <translation id="3619115746895587757">កាពូឈីណូ</translation>
@@ -3076,6 +3082,7 @@
 <translation id="3895090224522145010">ឈ្មោះអ្នកប្រើប្រាស់ Kerberos</translation>
 <translation id="389521680295183045">គេហទំព័រ​អាចសួរដើម្បីដឹងថា នៅពេលណាដែល​អ្នកកំពុងប្រើ​ឧបករណ៍របស់អ្នកយ៉ាងសកម្ម</translation>
 <translation id="3897298432557662720">{COUNT,plural, =1{រូបភាព​មួយ}other{រូបភាព #}}</translation>
+<translation id="3897746662269329507"><ph name="DEVICE_TYPE" /> របស់​អ្នក​ត្រូវ​បាន​បង្កើត​ឡើង​សម្រាប់​ការលេង​ហ្គេម។ បន្ទាប់​មក កម្មវិធី​រុករក​នឹង​បើក ហើយ​នៅ​លើ​នោះ អ្នក​អាច​ចូល​លេង​ហ្គេម​ថ្មីៗបំផុត​​រាប់​រយ មើល​ការ​ផ្ដល់​ជូន​សម្រាប់​ការ​លេងហ្គេម និង​ស្វែងយល់​អំពី​មុខងារ​លេង​ហ្គេម​ដែល​ភ្ជាប់​មកជា​មួយ​ឧបករណ៍​របស់​អ្នក។</translation>
 <translation id="3898233949376129212">ភាសា​របស់ឧបករណ៍</translation>
 <translation id="3898327728850887246"><ph name="SITE_NAME" /> ចង់៖ <ph name="FIRST_PERMISSION" /> និង <ph name="SECOND_PERMISSION" /></translation>
 <translation id="389901847090970821">ជ្រើសរើសក្តារចុច</translation>
@@ -3226,6 +3233,7 @@
 <translation id="4033471457476425443">បន្ថែម​ថត​ថ្មី</translation>
 <translation id="4033711848170683365">ការលុបនេះ​នឹងលុប​ទិន្នន័យរុករក​ចេញពី​ឧបករណ៍នេះ​ជាអចិន្ត្រៃយ៍។ គណនី Google នៅក្នុង​កម្រងព័ត៌មាន​នេះ​អាចនឹង​ត្រូវ​បានប្រើ​ដោយកម្មវិធី​ផ្សេងទៀតនៅលើ <ph name="DEVICE_TYPE" /> របស់អ្នក។ អ្នកអាច​ដក​គណនី​ទាំងនេះ​ចេញ​នៅក្នុង <ph name="BEGIN_LINK" /><ph name="SETTING_SECTION" /> &gt; <ph name="ACCOUNTS_SECTION" /><ph name="END_LINK" />។</translation>
 <translation id="4033963223187371752">គេហទំព័រដែលមានសុវត្ថិភាពអាចបង្កប់ខ្លឹមសារដែលគ្មានសុវត្ថិភាពដូចជា រូបភាព ឬស៊ុមបណ្ដាញជាដើម</translation>
+<translation id="4034741552964543387">បន្ត​ដោយ​គ្មាន​ទិន្នន័យ​មូលដ្ឋាន</translation>
 <translation id="4034824040120875894">ម៉ាស៊ីន​បោះពុម្ព</translation>
 <translation id="4035758313003622889">កម្មវិធីគ្រប់គ្រងភារកិច្ច</translation>
 <translation id="4035877632587724847">មិនអនុញ្ញាត</translation>
@@ -3417,6 +3425,7 @@
 <translation id="4242533952199664413">បើកការកំណត់</translation>
 <translation id="4242577469625748426">បានបរាជ័យក្នុងការតំឡើងការកំណត់គោលការណ៍នៅឧបករណ៍នេះ៖ <ph name="VALIDATION_ERROR" />។</translation>
 <translation id="4243504193894350135">ម៉ាស៊ីនបោះពុម្ព​ត្រូវបានផ្អាក</translation>
+<translation id="424423026762293842">ស្ដារទិន្នន័យមូលដ្ឋានរបស់​អ្នក</translation>
 <translation id="4244238649050961491">ស្វែងរក​កម្មវិធី​ប៊ិច​ជា​ច្រើន​ទៀត</translation>
 <translation id="4246980464509998944">មតិ​បន្ថែម៖</translation>
 <translation id="424726838611654458">បើកនៅក្នុង Adobe Reader ជានិច្ច</translation>
@@ -4976,6 +4985,7 @@
 <translation id="5792728279623964091">សូមចុចប៊ូតុង​ថាមពលរបស់អ្នក</translation>
 <translation id="5793339252089865437">ប្រសិនបើអ្នក​ទាញយកកំណែថ្មី​តាមរយៈបណ្ដាញ​ទូរសព្ទ​ចល័ត ការទាញយកនេះអាចនឹងមាន​ការគិតប្រាក់លើការប្រើប្រាស់ទិន្នន័យលើសកំណត់។</translation>
 <translation id="5793420564274426163">ការបញ្ជាក់​ការផ្គូផ្គង</translation>
+<translation id="5793430094159150686">ពាក្យសម្ងាត់របស់អ្នកបាន​ផ្លាស់ប្ដូរ​ហើយ។ ដើម្បី​ស្ដារ​ទិន្នន័យ​មូលដ្ឋាន​របស់​អ្នក អ្នកត្រូវ​បញ្ចូល​ពាក្យសម្ងាត់​ចាស់​របស់​អ្នក។</translation>
 <translation id="5794034487966529952">តុ <ph name="DESK_TITLE" /> បានបើក​វិនដូ​កម្មវិធីរុករកតាម​អ៊ីនធឺណិត <ph name="NUM_BROWSERS" /></translation>
 <translation id="5794414402486823030">បើកជាមួយកម្មវិធីមើលប្រព័ន្ធជានិច្ច</translation>
 <translation id="5794700615121138172">ថតដែល Linux បានចែករំលែក</translation>
@@ -5900,6 +5910,7 @@
 <translation id="6700093763382332031">ការចាក់សោ​ស៊ីម​បណ្ដាញចល័ត</translation>
 <translation id="6700480081846086223">ខាស <ph name="HOST_NAME" /></translation>
 <translation id="6701535245008341853">មិនអាចទទួលយកទម្រង់ទេ។</translation>
+<translation id="6701824422332982935">ផ្ទុក​ទំព័រ​ឡើងវិញ ដើម្បីប្រើប្រាស់កម្មវិធីបន្ថែម​​ទាំង​នេះ</translation>
 <translation id="6702639462873609204">កែប្រែ...</translation>
 <translation id="6703212423117969852">អ្នក​អាច​ព្យាយាមម្ដងទៀត​នៅពេលក្រោយ​នៅក្នុង​ Chrome។</translation>
 <translation id="6703254819490889819">ស្ដារការបម្រុងទុក</translation>
@@ -7127,6 +7138,7 @@
 <translation id="7903742244674067440">អ្នកមានវិញ្ញាបនបត្រនៅលើឯកសារដែលកំណត់អត្តសញ្ញាណអាជ្ញាធរវិញ្ញាបនបត្រទាំងនេះ</translation>
 <translation id="7903925330883316394">ឧបករណ៍ប្រើប្រាស់៖ <ph name="UTILITY_TYPE" /></translation>
 <translation id="7904526211178107182">កំណត់ឱ្យឧបករណ៍ផ្សេងទៀតនៅលើបណ្ដាញរបស់អ្នក​អាចប្រើច្រក Linux។</translation>
+<translation id="7906440585529721295">ទិន្នន័យ​មូលដ្ឋាន​នឹង​ត្រូវ​បានលុប</translation>
 <translation id="7907837847548254634">បង្ហាញ​ការរំលេច​រហ័ស​លើវត្ថុ​ដែលបានផ្ដោត</translation>
 <translation id="7908378463497120834">សូមទោស យ៉ាងហោចណាស់ផ្នែកមួយនៃឧបករណ៍ផ្ទុកទិន្នន័យខាងក្រៅរបស់អ្នកមិនអាចម៉ោនបានទេ។</translation>
 <translation id="7909324225945368569">ប្ដូរឈ្មោះ​កម្រងព័ត៌មាន​របស់អ្នក</translation>
@@ -7464,6 +7476,7 @@
 <translation id="822050276545350872">ចាប់ពី​ពេលនេះទៅ មិនចាំបាច់​រង់ចាំទេ</translation>
 <translation id="8221491193165283816">ជាធម្មតា អ្នកទប់ស្កាត់​ការជូនដំណឹង។ ដើម្បីអនុញ្ញាត​ឱ្យគេហទំព័រនេះ​ជូនដំណឹងដល់អ្នក សូមចុច​ត្រង់នេះ។</translation>
 <translation id="822347941086490485">កំពុងស្វែងរកឧបករណ៍ HID...</translation>
+<translation id="8223573963214454788">បន្ត រួច​លុប​ទិន្នន័យ</translation>
 <translation id="8225046344534779393">ពិនិត្យការតភ្ជាប់​អ៊ីនធឺណិត</translation>
 <translation id="8225265270453771718">ចែករំលែក​វិនដូ​កម្មវិធី</translation>
 <translation id="8226222018808695353">ហាមឃាត់</translation>
@@ -7564,6 +7577,7 @@
 <translation id="8314381333424235892">កម្មវិធីបន្ថែម​ដែលបាត់ ឬមិនបានដំឡើង</translation>
 <translation id="831440797644402910">មិនអាច​បើក​ថតនេះ​បានទេ</translation>
 <translation id="8314835274931377415">ចាប់ផ្ដើម​រៀបចំ​មុខងារប្រើឧបករណ៍ចុច​ឬ?</translation>
+<translation id="8317582043908962055">ស្គាល់​អត្ថបទ P&amp;DF</translation>
 <translation id="8317671367883557781">បន្ថែមការតភ្ជាប់បណ្តាញ</translation>
 <translation id="8319414634934645341">ការប្រើប្រាស់សោបន្ថែម</translation>
 <translation id="8321837372750396788"><ph name="DEVICE_TYPE" /> នេះនឹង​ស្ថិតក្រោម​ការគ្រប់គ្រង​របស់ <ph name="MANAGER" />។</translation>
@@ -8450,6 +8464,7 @@
 <translation id="9203398526606335860">បើកដំណើរការទម្រង់</translation>
 <translation id="9203904171912129171">ជ្រើសរើស​ឧបករណ៍</translation>
 <translation id="9206889157914079472">ការកត់ត្រា​ដោយប្រើប៊ិក​ពីអេក្រង់ចាក់សោ</translation>
+<translation id="9208192193641542858">ទិន្នន័យ​មូលដ្ឋាន​ត្រូវបានការពារ​ដោយ​ពាក្យសម្ងាត់​ចាស់​របស់​អ្នក។ ប្រសិនបើអ្នកបានផ្លាស់ប្ដូរ​ពាក្យសម្ងាត់​របស់​អ្នក​ថ្មីៗ​នេះ សូម​សាកល្បង​បញ្ចូល​ពាក្យសម្ងាត់​ចាស់​របស់​អ្នក​ម្ដង​ទៀត។</translation>
 <translation id="9209563766569767417">កំពុងពិនិត្យមើល​ការរៀបចំ​ទម្រង់ផ្ទុក Linux</translation>
 <translation id="9209689095351280025">គេហទំព័រ​មិន​អាចប្រើ​ខូគី ដែលតាមដាន​អ្នក​នៅលើអ៊ីនធឺណិតបានទេ</translation>
 <translation id="9211177926627870898">តម្រូវឱ្យ​ដំឡើង​កំណែ</translation>
diff --git a/chrome/app/resources/generated_resources_kn.xtb b/chrome/app/resources/generated_resources_kn.xtb
index d651c5e..5fe3ee3 100644
--- a/chrome/app/resources/generated_resources_kn.xtb
+++ b/chrome/app/resources/generated_resources_kn.xtb
@@ -2764,6 +2764,7 @@
 <translation id="3615073365085224194">ನಿಮ್ಮ ಬೆರಳಿನ ಮೂಲಕ ಫಿಂಗರ್‌ಪ್ರಿಂಟ್ ಸೆನ್ಸರ್ ಅನ್ನು ಸ್ಪರ್ಶಿಸಿ</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ಅನ್ನು ಸ್ಕ್ಯಾನ್ ಮಾಡಲಾಗುತ್ತಿದೆ.</translation>
 <translation id="3615596877979647433">ಕೀ ಬೈಂಡಿಂಗ್ ಕಾಣೆಯಾಗಿದೆ. ಕಸ್ಟಮೈಸ್ ಮಾಡಲು ಕೀಬೋರ್ಡ್ ಕೀ ಅನ್ನು ಒತ್ತಿ</translation>
+<translation id="3616113530831147358">ಆಡಿಯೋ</translation>
 <translation id="3616741288025931835">ಬ್ರೌಸಿಂಗ್ ಡೇಟಾವನ್ನು &amp;ತೆರವುಗೊಳಿಸಿ...</translation>
 <translation id="3617891479562106823">ಹಿನ್ನೆಲೆಗಳ ಕಸ್ಟಮೈಸೇಶನ್‌ ಲಭ್ಯವಿಲ್ಲ. ನಂತರ ಮತ್ತೆ ಪ್ರಯತ್ನಿಸಿ.</translation>
 <translation id="3619115746895587757">ಕ್ಯಾಪಚಿನೊ</translation>
diff --git a/chrome/app/resources/generated_resources_ko.xtb b/chrome/app/resources/generated_resources_ko.xtb
index 08aea631..1775005 100644
--- a/chrome/app/resources/generated_resources_ko.xtb
+++ b/chrome/app/resources/generated_resources_ko.xtb
@@ -2773,6 +2773,7 @@
 <translation id="3615073365085224194">손가락으로 지문 센서를 터치하세요.</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" />을(를) 스캔하는 중입니다.</translation>
 <translation id="3615596877979647433">키가 누락되었습니다. 키보드 키를 눌러 맞춤설정하세요.</translation>
+<translation id="3616113530831147358">오디오</translation>
 <translation id="3616741288025931835">인터넷 사용 기록 삭제(&amp;C)...</translation>
 <translation id="3617891479562106823">배경을 사용할 수 없습니다. 나중에 다시 시도하세요.</translation>
 <translation id="3619115746895587757">카푸치노</translation>
diff --git a/chrome/app/resources/generated_resources_ky.xtb b/chrome/app/resources/generated_resources_ky.xtb
index da5bd5e..e361c61a 100644
--- a/chrome/app/resources/generated_resources_ky.xtb
+++ b/chrome/app/resources/generated_resources_ky.xtb
@@ -843,7 +843,7 @@
 <translation id="177989070088644880">Колдонмо (<ph name="ANDROID_PACKAGE_NAME" />)</translation>
 <translation id="1780152987505130652">Топту жабуу</translation>
 <translation id="1780273119488802839">Кыстармалар өткөрүлүп алынууда...</translation>
-<translation id="178092663238929451">Жакын жердеги кишилерден файлдарды алуу жана жөнөтүү үчүн Nearby Share функциясын жөндөңүз</translation>
+<translation id="178092663238929451">Жакын жердеги кишилерден файлдарды алуу жана жөнөтүү үчүн Nearby Share функциясын тууралаңыз</translation>
 <translation id="1781291988450150470">Учурдагы PIN код</translation>
 <translation id="1781502536226964113">Жаңы өтмөк бетин ачуу</translation>
 <translation id="1781553166608855614">Колдонулуучу тилдер</translation>
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Манжа изинин сенсоруна манжаңыз менен тийиңиз</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> жокко чыгарылууда.</translation>
 <translation id="3615596877979647433">Баскыч тандалган жок. Ыңгайлаштыруу үчүн баскычтоптогу бир баскычты басыңыз</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp;Серептөө дайындарын тазалап салуу…</translation>
 <translation id="3617891479562106823">Фондук сүрөттөр жеткиликсиз. Бир аздан кийин дагы аракет кылыңыз.</translation>
 <translation id="3619115746895587757">Капучино</translation>
@@ -4331,7 +4332,7 @@
 <translation id="514575469079499857">Жайгашкан жерди аныктоо үчүн IP дарегиңизди колдонуңуз (демейки)</translation>
 <translation id="5147103632304200977">Сайт HID түзмөктөрүн колдонгону жатканда уруксат суралсын (сунушталат)</translation>
 <translation id="5148277445782867161">Google'дун жайгашкан жерди аныктоо кызматы түзмөктүн жайгашкан жерин болжолдоп билүү үчүн Wi‑Fi, мобилдик тармактар жана сенсорлор сыяктуу булактарды колдонот.</translation>
-<translation id="5150070631291639005">Купуялык жөндөөлөрү</translation>
+<translation id="5150070631291639005">Купуялык параметрлери</translation>
 <translation id="5150254825601720210">Netscape Тастыктама SSL сервер аталышы</translation>
 <translation id="5151354047782775295">Дисктен орун бошотуңуз же автоматтык түрдө жок кылына турган дайындарды тандаңыз</translation>
 <translation id="5153234146675181447">Телефон унутулсун</translation>
diff --git a/chrome/app/resources/generated_resources_lo.xtb b/chrome/app/resources/generated_resources_lo.xtb
index 0560dac0..62241af 100644
--- a/chrome/app/resources/generated_resources_lo.xtb
+++ b/chrome/app/resources/generated_resources_lo.xtb
@@ -2771,6 +2771,7 @@
 <translation id="3615073365085224194">ໃຊ້ນິ້ວມືຂອງທ່ານແຕະເຊັນເຊີລາຍນິ້ວມື</translation>
 <translation id="3615579745882581859">ລະບົບກຳລັງສະແກນ <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">ບໍ່ມີປຸ່ມ. ກົດປຸ່ມແປ້ນພິມເພື່ອປັບແຕ່ງ</translation>
+<translation id="3616113530831147358">ສຽງ</translation>
 <translation id="3616741288025931835">ລຶບຂໍ້​ມູນການທ່ອງ​ເນັດ...</translation>
 <translation id="3617891479562106823">ພື້ນຫຼັງບໍ່ສາມາດໃຊ້ໄດ້. ກະລຸນາລອງໃໝ່ໃນພາຍຫຼັງ.</translation>
 <translation id="3619115746895587757">ຄາປູຊິໂນ</translation>
diff --git a/chrome/app/resources/generated_resources_lt.xtb b/chrome/app/resources/generated_resources_lt.xtb
index 1a3af6e..daa3a30 100644
--- a/chrome/app/resources/generated_resources_lt.xtb
+++ b/chrome/app/resources/generated_resources_lt.xtb
@@ -2775,6 +2775,7 @@
 <translation id="3615073365085224194">Palieskite kontrolinio kodo jutiklį pirštu</translation>
 <translation id="3615579745882581859">Nuskaitomas „<ph name="FILE_NAME" />“.</translation>
 <translation id="3615596877979647433">Trūksta klavišo. Jei norite tinkinti, paspauskite klaviatūros klavišą</translation>
+<translation id="3616113530831147358">Garsas</translation>
 <translation id="3616741288025931835">&amp;Išvalyti naršymo duomenis...</translation>
 <translation id="3617891479562106823">Fonai nepasiekiami. Vėliau bandykite dar kartą.</translation>
 <translation id="3619115746895587757">Kapučino kava</translation>
diff --git a/chrome/app/resources/generated_resources_lv.xtb b/chrome/app/resources/generated_resources_lv.xtb
index 4145b2f..1b0f95e 100644
--- a/chrome/app/resources/generated_resources_lv.xtb
+++ b/chrome/app/resources/generated_resources_lv.xtb
@@ -2759,6 +2759,7 @@
 <translation id="3615073365085224194">Ar pirkstu pieskarieties pirkstu nospiedumu sensoram</translation>
 <translation id="3615579745882581859">Notiek faila “<ph name="FILE_NAME" />” pārbaude.</translation>
 <translation id="3615596877979647433">Nav norādīts taustiņš. Lai pielāgotu, nospiediet tastatūras taustiņu.</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Dzēst pārlūkošanas datus...</translation>
 <translation id="3617891479562106823">Fona attēli nav pieejami. Vēlāk mēģiniet vēlreiz.</translation>
 <translation id="3619115746895587757">Kapučīno</translation>
diff --git a/chrome/app/resources/generated_resources_mk.xtb b/chrome/app/resources/generated_resources_mk.xtb
index b07a025..2cb2ca7 100644
--- a/chrome/app/resources/generated_resources_mk.xtb
+++ b/chrome/app/resources/generated_resources_mk.xtb
@@ -2773,6 +2773,7 @@
 <translation id="3615073365085224194">Допрете го сензорот за отпечатоци со прстот</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> се скенира.</translation>
 <translation id="3615596877979647433">Недостасува копче. Притиснете копче на тастатура за да го приспособите</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp;Исчисти податоци од прелистување...</translation>
 <translation id="3617891479562106823">Заднините се недостапни. Обидете се повторно подоцна.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_ml.xtb b/chrome/app/resources/generated_resources_ml.xtb
index 649ca69..b32b3e96c 100644
--- a/chrome/app/resources/generated_resources_ml.xtb
+++ b/chrome/app/resources/generated_resources_ml.xtb
@@ -2756,6 +2756,7 @@
 <translation id="3615073365085224194">ഫിംഗർപ്രിന്റ് സെൻസറിൽ സ്‌പർശിക്കുക</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> സ്‌കാൻ ചെയ്യുകയാണ്.</translation>
 <translation id="3615596877979647433">കീ തിരഞ്ഞെടുത്തിട്ടില്ല. ഇഷ്ടാനുസൃതമാക്കാൻ കീബോർഡ് കീ അമർത്തുക</translation>
+<translation id="3616113530831147358">ഓഡിയോ</translation>
 <translation id="3616741288025931835">&amp;ബ്രൌസിംഗ് ഡാറ്റ ഇല്ലാതാക്കുക...</translation>
 <translation id="3617891479562106823">പശ്ചാത്തലങ്ങൾ ലഭ്യമല്ല. പിന്നീട് വീണ്ടും ശ്രമിക്കുക.</translation>
 <translation id="3619115746895587757">കാപ്പുചീനോ</translation>
diff --git a/chrome/app/resources/generated_resources_mn.xtb b/chrome/app/resources/generated_resources_mn.xtb
index 3800085..9fb25a5 100644
--- a/chrome/app/resources/generated_resources_mn.xtb
+++ b/chrome/app/resources/generated_resources_mn.xtb
@@ -2768,6 +2768,7 @@
 <translation id="3615073365085224194">Хурууны хээ мэдрэгчид хуруугаараа хүрнэ үү</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" />-г скан хийж байна.</translation>
 <translation id="3615596877979647433">Товч дутуу байна. Өөрчлөхийн тулд гарын товч дээр дарна уу</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp; Хайлтын өгөгдлийг цэвэрлэ...</translation>
 <translation id="3617891479562106823">Арын дэвсгэр боломжгүй байна. Дараа дахин оролдоно уу.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_mr.xtb b/chrome/app/resources/generated_resources_mr.xtb
index 66e748d..74dd180 100644
--- a/chrome/app/resources/generated_resources_mr.xtb
+++ b/chrome/app/resources/generated_resources_mr.xtb
@@ -2771,6 +2771,7 @@
 <translation id="3615073365085224194">तुमच्या बोटाने फिंगरप्रिंट सेन्सरला स्पर्श करा</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> स्कॅन केली जात आहे.</translation>
 <translation id="3615596877979647433">की उपलब्ध नाही. कस्टमाइझ करण्यासाठी किबोर्ड की प्रेस करा</translation>
+<translation id="3616113530831147358">ऑडिओ</translation>
 <translation id="3616741288025931835">ब्राउझिंग डेटा &amp;साफ करा...</translation>
 <translation id="3617891479562106823">बॅकग्राउंड अनुपलब्ध आहेत. नंतर पुन्हा प्रयत्न करा.</translation>
 <translation id="3619115746895587757">कॅपिचिनो</translation>
diff --git a/chrome/app/resources/generated_resources_ms.xtb b/chrome/app/resources/generated_resources_ms.xtb
index 31c44d4..927d1c3 100644
--- a/chrome/app/resources/generated_resources_ms.xtb
+++ b/chrome/app/resources/generated_resources_ms.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Sentuh penderia cap jari menggunakan jari anda</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> sedang diimbas.</translation>
 <translation id="3615596877979647433">Tiada kekunci. Tekan kekunci papan kekunci untuk menyesuaikan</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Kosongkan Data Menyemak Imbas...</translation>
 <translation id="3617891479562106823">Latar belakang tidak tersedia. Cuba lagi nanti.</translation>
 <translation id="3619115746895587757">Kapucino</translation>
diff --git a/chrome/app/resources/generated_resources_my.xtb b/chrome/app/resources/generated_resources_my.xtb
index 6f96eb9..bc0a19c7 100644
--- a/chrome/app/resources/generated_resources_my.xtb
+++ b/chrome/app/resources/generated_resources_my.xtb
@@ -2770,6 +2770,7 @@
 <translation id="3615073365085224194">လက်ဗွေ အာရုံခံကိရိယာကို သင့်လက်ချောင်းဖြင့် ထိပါ</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ကို စစ်ဆေးနေပါသည်။</translation>
 <translation id="3615596877979647433">ကီး မရှိပါ။ စိတ်ကြိုက်လုပ်ရန် ကီးဘုတ်ကီးတစ်ခုကို နှိပ်ပါ</translation>
+<translation id="3616113530831147358">အသံ</translation>
 <translation id="3616741288025931835">ဘရောက်လုပ်ထားသည့် အချက်လက်များ ရှင်းလင်းရန်...</translation>
 <translation id="3617891479562106823">နောက်ခံပုံများ မရရှိနိုင်ပါ။ နောက်မှ ထပ်စမ်းကြည့်ပါ။</translation>
 <translation id="3619115746895587757">ကာပူချီနို</translation>
diff --git a/chrome/app/resources/generated_resources_ne.xtb b/chrome/app/resources/generated_resources_ne.xtb
index e2c243b..b0987c7 100644
--- a/chrome/app/resources/generated_resources_ne.xtb
+++ b/chrome/app/resources/generated_resources_ne.xtb
@@ -2755,6 +2755,7 @@
 <translation id="3615073365085224194">आफ्नो औँलाले फिंगरप्रिन्ट सेन्सरमा छुनुहोस्</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> स्क्यान गरिँदै छ।</translation>
 <translation id="3615596877979647433">की थिचिएको छैन। कस्टमाइज गरिनु पर्ने किबोर्ड कीमा थिच्नुहोस्</translation>
+<translation id="3616113530831147358">अडियो</translation>
 <translation id="3616741288025931835">&amp;ब्राउजिङ लगत खालि गर्नुहोस्...</translation>
 <translation id="3617891479562106823">पृष्ठभूमिहरू उपलब्ध छैनन्। पछि फेरि प्रयास गर्नुहोस्।</translation>
 <translation id="3619115746895587757">कापाचिनो</translation>
diff --git a/chrome/app/resources/generated_resources_nl.xtb b/chrome/app/resources/generated_resources_nl.xtb
index 5114295..4e73c07 100644
--- a/chrome/app/resources/generated_resources_nl.xtb
+++ b/chrome/app/resources/generated_resources_nl.xtb
@@ -2756,6 +2756,7 @@
 <translation id="3615073365085224194">Raak de vingerafdruksensor aan met je vinger</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> wordt gescand.</translation>
 <translation id="3615596877979647433">De toets ontbreekt. Druk op een toets op het toetsenbord om deze aan te passen.</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Browsegegevens wissen</translation>
 <translation id="3617891479562106823">Achtergronden zijn niet beschikbaar. Probeer het later opnieuw.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_no.xtb b/chrome/app/resources/generated_resources_no.xtb
index 74e37d4..809cd78b 100644
--- a/chrome/app/resources/generated_resources_no.xtb
+++ b/chrome/app/resources/generated_resources_no.xtb
@@ -2759,6 +2759,7 @@
 <translation id="3615073365085224194">Trykk på fingeravtrykkssensoren med fingeren</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> skannes.</translation>
 <translation id="3615596877979647433">Tast mangler Trykk på en tastaturtast for å tilpasse</translation>
+<translation id="3616113530831147358">Lyd</translation>
 <translation id="3616741288025931835">&amp;Fjern nettlesingsdata</translation>
 <translation id="3617891479562106823">Bakgrunner er utilgjengelig. Prøv på nytt senere.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_or.xtb b/chrome/app/resources/generated_resources_or.xtb
index f171b22a..c7b9b56 100644
--- a/chrome/app/resources/generated_resources_or.xtb
+++ b/chrome/app/resources/generated_resources_or.xtb
@@ -2755,6 +2755,7 @@
 <translation id="3615073365085224194">ଆପଣଙ୍କର ଆଙ୍ଗୁଠିରେ ଟିପଚିହ୍ନ ସେନ୍ସର୍‌କୁ ସ୍ପର୍ଶ କରନ୍ତୁ</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" />ର ସ୍କାନ୍ କରାଯାଉଛି।</translation>
 <translation id="3615596877979647433">କୀ ଉପଲବ୍ଧ ନାହିଁ। କଷ୍ଟମାଇଜ କରିବା ପାଇଁ ଏକ କୀବୋର୍ଡ କୀକୁ ଦବାନ୍ତୁ</translation>
+<translation id="3616113530831147358">ଅଡିଓ</translation>
 <translation id="3616741288025931835">&amp;ବ୍ରାଉଜିଂ ଡାଟା ଖାଲି କରନ୍ତୁ...</translation>
 <translation id="3617891479562106823">ପୃଷ୍ଠଭୂମି ଉପଲବ୍ଧ ନାହିଁ। ପରେ ପୁଣି ଚେଷ୍ଟା କରନ୍ତୁ।</translation>
 <translation id="3619115746895587757">କ୍ୟାପାଚିନୋ</translation>
diff --git a/chrome/app/resources/generated_resources_pa.xtb b/chrome/app/resources/generated_resources_pa.xtb
index 68db999..8237ab0 100644
--- a/chrome/app/resources/generated_resources_pa.xtb
+++ b/chrome/app/resources/generated_resources_pa.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">ਆਪਣੀ ਉਂਗਲ ਨਾਲ ਫਿੰਗਰਪ੍ਰਿੰਟ ਸੈਂਸਰ ਨੂੰ ਸਪਰਸ਼ ਕਰੋ</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ਨੂੰ ਸਕੈਨ ਕੀਤਾ ਜਾ ਰਿਹਾ ਹੈ।</translation>
 <translation id="3615596877979647433">ਕੁੰਜੀ ਮੌਜੂਦ ਨਹੀਂ ਹੈ। ਵਿਉਂਤਬੱਧ ਕਰਨ ਲਈ ਕੀ-ਬੋਰਡ ਕੁੰਜੀ ਦਬਾਓ</translation>
+<translation id="3616113530831147358">ਆਡੀਓ</translation>
 <translation id="3616741288025931835">&amp;ਬ੍ਰਾਊਜ਼ਿੰਗ ਡਾਟਾ ਹਟਾਓ...</translation>
 <translation id="3617891479562106823">ਬੈਕਗ੍ਰਾਊਂਡਾਂ ਉਪਲਬਧ ਨਹੀਂ ਹਨ। ਬਾਅਦ ਵਿੱਚ ਦੁਬਾਰਾ ਕੋਸ਼ਿਸ਼ ਕਰੋ।</translation>
 <translation id="3619115746895587757">ਕੈਪੁਚੀਨੋ</translation>
diff --git a/chrome/app/resources/generated_resources_pl.xtb b/chrome/app/resources/generated_resources_pl.xtb
index 2abb7f5..f9fb1ad 100644
--- a/chrome/app/resources/generated_resources_pl.xtb
+++ b/chrome/app/resources/generated_resources_pl.xtb
@@ -2743,6 +2743,7 @@
 <translation id="3615073365085224194">Przyłóż palec do czytnika linii papilarnych</translation>
 <translation id="3615579745882581859">Skanuję plik <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Brak klawisza. Aby dostosować, naciśnij klawisz na klawiaturze</translation>
+<translation id="3616113530831147358">Dźwięk</translation>
 <translation id="3616741288025931835">&amp;Wyczyść dane przeglądania...</translation>
 <translation id="3617891479562106823">Tła są niedostępne. Spróbuj ponownie później.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_pt-BR.xtb b/chrome/app/resources/generated_resources_pt-BR.xtb
index 480ab67..50fdf3a 100644
--- a/chrome/app/resources/generated_resources_pt-BR.xtb
+++ b/chrome/app/resources/generated_resources_pt-BR.xtb
@@ -2774,6 +2774,7 @@
 <translation id="3615073365085224194">Toque no sensor de impressão digital com seu dedo</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> está sendo verificado.</translation>
 <translation id="3615596877979647433">A tecla está em branco. Pressione uma tecla para personalizar</translation>
+<translation id="3616113530831147358">Áudio</translation>
 <translation id="3616741288025931835">&amp;Limpar dados de navegação...</translation>
 <translation id="3617891479562106823">Os planos de fundo estão indisponíveis. Tente novamente mais tarde.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_pt-PT.xtb b/chrome/app/resources/generated_resources_pt-PT.xtb
index 8a610ff..28c4f440 100644
--- a/chrome/app/resources/generated_resources_pt-PT.xtb
+++ b/chrome/app/resources/generated_resources_pt-PT.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">Toque no sensor de impressões digitais com o dedo.</translation>
 <translation id="3615579745882581859">O ficheiro <ph name="FILE_NAME" /> está a ser analisado.</translation>
 <translation id="3615596877979647433">A tecla está em falta. Prima uma tecla do teclado para personalizar</translation>
+<translation id="3616113530831147358">Áudio</translation>
 <translation id="3616741288025931835">&amp;Limpar Dados de Navegação...</translation>
 <translation id="3617891479562106823">Os fundos não estão disponíveis. Tente novamente mais tarde.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_ro.xtb b/chrome/app/resources/generated_resources_ro.xtb
index febe1a45..ca91e98 100644
--- a/chrome/app/resources/generated_resources_ro.xtb
+++ b/chrome/app/resources/generated_resources_ro.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">Atinge senzorul de amprentă cu degetul</translation>
 <translation id="3615579745882581859">Se scanează fișierul <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Lipsește tasta. Apasă o tastă de pe tastatură pentru personalizare</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Șterge datele de navigare...</translation>
 <translation id="3617891479562106823">Fundalurile nu sunt disponibile. Încearcă din nou mai târziu.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_ru.xtb b/chrome/app/resources/generated_resources_ru.xtb
index 2c32cf5..c95acd3 100644
--- a/chrome/app/resources/generated_resources_ru.xtb
+++ b/chrome/app/resources/generated_resources_ru.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">Приложите палец к сканеру отпечатков пальцев.</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" />: проверка…</translation>
 <translation id="3615596877979647433">Клавиша не задана. Нажмите на нее, чтобы настроить.</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">Очистить данные просмотров...</translation>
 <translation id="3617891479562106823">Фоновые изображения недоступны. Повторите попытку позже.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_si.xtb b/chrome/app/resources/generated_resources_si.xtb
index f0938a48..b67d416 100644
--- a/chrome/app/resources/generated_resources_si.xtb
+++ b/chrome/app/resources/generated_resources_si.xtb
@@ -2760,6 +2760,7 @@
 <translation id="3615073365085224194">ඔබේ ඇඟිල්ලෙන් ඇඟිලි සලකුණු සංවේදකය ස්පර්ශ කරන්න</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ස්කෑන් කරමින් පවතී.</translation>
 <translation id="3615596877979647433">යතුර අස්ථානගතයි. අභිරුචිකරණය කිරීමට යතුරු පුවරු යතුරක් ඔබන්න</translation>
+<translation id="3616113530831147358">ශබ්ද</translation>
 <translation id="3616741288025931835">ශවේෂණ දත්ත හිස් කරන්න</translation>
 <translation id="3617891479562106823">පසුබිම් නොතිබේ. පසුව නැවත උත්සාහ කරන්න.</translation>
 <translation id="3619115746895587757">කපුචිනෝ</translation>
diff --git a/chrome/app/resources/generated_resources_sk.xtb b/chrome/app/resources/generated_resources_sk.xtb
index 91d73f9..7d6fe08d 100644
--- a/chrome/app/resources/generated_resources_sk.xtb
+++ b/chrome/app/resources/generated_resources_sk.xtb
@@ -2759,6 +2759,7 @@
 <translation id="3615073365085224194">Dotknite sa senzora odtlačkov prstov</translation>
 <translation id="3615579745882581859">Súbor <ph name="FILE_NAME" /> sa kontroluje.</translation>
 <translation id="3615596877979647433">Chýba kláves. Prispôsobte si ho stlačením klávesa na klávesnici</translation>
+<translation id="3616113530831147358">Zvuk</translation>
 <translation id="3616741288025931835">&amp;Vymazať dáta prehliadania…</translation>
 <translation id="3617891479562106823">Pozadia nie sú k dispozícii. Skúste to neskôr.</translation>
 <translation id="3619115746895587757">Kapučíno</translation>
diff --git a/chrome/app/resources/generated_resources_sl.xtb b/chrome/app/resources/generated_resources_sl.xtb
index d8ecba48..3475954 100644
--- a/chrome/app/resources/generated_resources_sl.xtb
+++ b/chrome/app/resources/generated_resources_sl.xtb
@@ -2775,6 +2775,7 @@
 <translation id="3615073365085224194">S prstom se dotaknite tipala prstnih odtisov</translation>
 <translation id="3615579745882581859">Poteka pregled datoteke <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Manjka tipka. Pritisnite tipko na tipkovnici za prilagajanje.</translation>
+<translation id="3616113530831147358">Zvok</translation>
 <translation id="3616741288025931835">&amp;Izbriši podatke brskanja ...</translation>
 <translation id="3617891479562106823">Ozadja niso na voljo. Poskusite znova pozneje.</translation>
 <translation id="3619115746895587757">Kapučino</translation>
diff --git a/chrome/app/resources/generated_resources_sq.xtb b/chrome/app/resources/generated_resources_sq.xtb
index de6623a8..78dc07f 100644
--- a/chrome/app/resources/generated_resources_sq.xtb
+++ b/chrome/app/resources/generated_resources_sq.xtb
@@ -2754,6 +2754,7 @@
 <translation id="3615073365085224194">Prek me gisht sensorin e gjurmës së gishtit</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> po skanohet.</translation>
 <translation id="3615596877979647433">Tasti mungon. Shtyp një tast të tastierës për ta personalizuar</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Pastro të dhënat e shfletimit...</translation>
 <translation id="3617891479562106823">Sfondet nuk disponohen. Provo sërish më vonë.</translation>
 <translation id="3619115746895587757">Kapuçino</translation>
diff --git a/chrome/app/resources/generated_resources_sr-Latn.xtb b/chrome/app/resources/generated_resources_sr-Latn.xtb
index c24d5cb90..177467e6 100644
--- a/chrome/app/resources/generated_resources_sr-Latn.xtb
+++ b/chrome/app/resources/generated_resources_sr-Latn.xtb
@@ -2756,6 +2756,7 @@
 <translation id="3615073365085224194">Dodirnite prstom senzor za otisak prsta</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> se skenira.</translation>
 <translation id="3615596877979647433">Taster nedostaje. Pritisnite taster na tastaturi da biste prilagodili</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">&amp;Obriši podatke pregledanja...</translation>
 <translation id="3617891479562106823">Pozadine nisu dostupne. Probajte ponovo kasnije.</translation>
 <translation id="3619115746895587757">Kapučino</translation>
diff --git a/chrome/app/resources/generated_resources_sr.xtb b/chrome/app/resources/generated_resources_sr.xtb
index 622ba0b..34cfc46 100644
--- a/chrome/app/resources/generated_resources_sr.xtb
+++ b/chrome/app/resources/generated_resources_sr.xtb
@@ -2756,6 +2756,7 @@
 <translation id="3615073365085224194">Додирните прстом сензор за отисак прста</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> се скенира.</translation>
 <translation id="3615596877979647433">Тастер недостаје. Притисните тастер на тастатури да бисте прилагодили</translation>
+<translation id="3616113530831147358">Аудио</translation>
 <translation id="3616741288025931835">&amp;Обриши податке прегледања...</translation>
 <translation id="3617891479562106823">Позадине нису доступне. Пробајте поново касније.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_sv.xtb b/chrome/app/resources/generated_resources_sv.xtb
index d3d97da9..3cfe421 100644
--- a/chrome/app/resources/generated_resources_sv.xtb
+++ b/chrome/app/resources/generated_resources_sv.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Tryck på fingeravtryckssensorn med fingret.</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> genomsöks.</translation>
 <translation id="3615596877979647433">Tangent saknas. Tryck på en tangent för att anpassa den</translation>
+<translation id="3616113530831147358">Ljud</translation>
 <translation id="3616741288025931835">&amp;Rensa webbinformation...</translation>
 <translation id="3617891479562106823">Inga bakgrunder är tillgängliga. Försök igen senare.</translation>
 <translation id="3619115746895587757">Cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_sw.xtb b/chrome/app/resources/generated_resources_sw.xtb
index 24a74f6..c2d9e1a 100644
--- a/chrome/app/resources/generated_resources_sw.xtb
+++ b/chrome/app/resources/generated_resources_sw.xtb
@@ -2769,6 +2769,7 @@
 <translation id="3615073365085224194">Gusa kitambua alama ya kidole ukitumia kidole chako</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> inachanganuliwa.</translation>
 <translation id="3615596877979647433">Kitufe kinakosekana. Bonyeza kitufe cha kibodi ili uweke mapendeleo</translation>
+<translation id="3616113530831147358">Sauti</translation>
 <translation id="3616741288025931835">&amp;Futa Data ya Kuvinjari</translation>
 <translation id="3617891479562106823">Mandhari hayapatikani. Jaribu tena baadaye.</translation>
 <translation id="3619115746895587757">Kapuchino</translation>
diff --git a/chrome/app/resources/generated_resources_ta.xtb b/chrome/app/resources/generated_resources_ta.xtb
index 39768e1..2af04f5 100644
--- a/chrome/app/resources/generated_resources_ta.xtb
+++ b/chrome/app/resources/generated_resources_ta.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">விரலால் கைரேகை சென்சாரைத் தொடவும்</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> ஸ்கேன் செய்யப்படுகிறது.</translation>
 <translation id="3615596877979647433">பட்டன் ஒதுக்கப்படவில்லை. பிரத்தியேகமாக்க கீபோர்டு பட்டனை அழுத்தவும்</translation>
+<translation id="3616113530831147358">ஆடியோ</translation>
 <translation id="3616741288025931835">உலாவிய தரவை &amp;சுத்தமாக்கு...</translation>
 <translation id="3617891479562106823">பின்னணிகள் கிடைக்கவில்லை. பின்னர் மீண்டும் முயலவும்.</translation>
 <translation id="3619115746895587757">காப்பச்சினோ</translation>
diff --git a/chrome/app/resources/generated_resources_te.xtb b/chrome/app/resources/generated_resources_te.xtb
index 45ca411..479a7c89 100644
--- a/chrome/app/resources/generated_resources_te.xtb
+++ b/chrome/app/resources/generated_resources_te.xtb
@@ -2771,6 +2771,7 @@
 <translation id="3615073365085224194">వేలిముద్ర సెన్సార్‌ను మీ వేలితో తాకండి</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> స్కాన్ అవుతోంది.</translation>
 <translation id="3615596877979647433">కీ ఏదీ నొక్కబడలేదు. అనుకూలంగా మార్చడానికి కీబోర్డ్ కీని నొక్కండి</translation>
+<translation id="3616113530831147358">ఆడియో</translation>
 <translation id="3616741288025931835">బ్రౌజింగ్ డేటాను &amp;క్లియర్ చేయి...</translation>
 <translation id="3617891479562106823">నేపథ్యాలు అందుబాటులో లేవు. తర్వాత మళ్లీ ప్రయత్నించండి.</translation>
 <translation id="3619115746895587757">కాపుచినో</translation>
diff --git a/chrome/app/resources/generated_resources_th.xtb b/chrome/app/resources/generated_resources_th.xtb
index bda2903..11ab25ad3 100644
--- a/chrome/app/resources/generated_resources_th.xtb
+++ b/chrome/app/resources/generated_resources_th.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">ใช้นิ้วแตะเซ็นเซอร์ลายนิ้วมือ</translation>
 <translation id="3615579745882581859">กำลังสแกน <ph name="FILE_NAME" /></translation>
 <translation id="3615596877979647433">ไม่มีแป้น กดแป้นพิมพ์เพื่อปรับแต่ง</translation>
+<translation id="3616113530831147358">เสียง</translation>
 <translation id="3616741288025931835">&amp;ล้างข้อมูลการท่องเว็บ...</translation>
 <translation id="3617891479562106823">พื้นหลังไม่พร้อมใช้งาน โปรดลองอีกครั้งภายหลัง</translation>
 <translation id="3619115746895587757">คาปูชิโน</translation>
diff --git a/chrome/app/resources/generated_resources_tr.xtb b/chrome/app/resources/generated_resources_tr.xtb
index fb7f6c1..07e21520 100644
--- a/chrome/app/resources/generated_resources_tr.xtb
+++ b/chrome/app/resources/generated_resources_tr.xtb
@@ -2754,6 +2754,7 @@
 <translation id="3615073365085224194">Parmağınızla parmak izi sensörüne dokunun</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> taranıyor.</translation>
 <translation id="3615596877979647433">Tuş eksik. Özelleştirmek istediğiniz klavye tuşuna basın</translation>
+<translation id="3616113530831147358">Ses</translation>
 <translation id="3616741288025931835">Tarama Verilerini &amp;Temizle...</translation>
 <translation id="3617891479562106823">Arka planlar kullanılamıyor. Daha sonra tekrar deneyin.</translation>
 <translation id="3619115746895587757">Kapuçino</translation>
diff --git a/chrome/app/resources/generated_resources_uk.xtb b/chrome/app/resources/generated_resources_uk.xtb
index 5cb69f2..ea18308 100644
--- a/chrome/app/resources/generated_resources_uk.xtb
+++ b/chrome/app/resources/generated_resources_uk.xtb
@@ -2775,6 +2775,7 @@
 <translation id="3615073365085224194">Торкніться пальцем сканера відбитків</translation>
 <translation id="3615579745882581859">Сканується файл "<ph name="FILE_NAME" />".</translation>
 <translation id="3615596877979647433">Клавішу на зв’язано. Щоб налаштувати прив’язку, натисніть клавішу клавіатури.</translation>
+<translation id="3616113530831147358">Аудіо</translation>
 <translation id="3616741288025931835">&amp;Очистити дані веб-перегляду...</translation>
 <translation id="3617891479562106823">Фони недоступні. Повторіть спробу пізніше.</translation>
 <translation id="3619115746895587757">Капучино</translation>
diff --git a/chrome/app/resources/generated_resources_ur.xtb b/chrome/app/resources/generated_resources_ur.xtb
index 3360bb3..c2359ea2 100644
--- a/chrome/app/resources/generated_resources_ur.xtb
+++ b/chrome/app/resources/generated_resources_ur.xtb
@@ -2758,6 +2758,7 @@
 <translation id="3615073365085224194">اپنی انگلی سے فنگر پرنٹ سینسر کو ٹچ کریں</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> اسکین کیا جا رہا ہے۔</translation>
 <translation id="3615596877979647433">کلید غائب ہے۔ حسب ضرورت بنانے کے ليے کی بورڈ کی کلید دبائیں</translation>
+<translation id="3616113530831147358">آڈیو</translation>
 <translation id="3616741288025931835">براؤزنگ ڈیٹا &amp;صاف کریں…</translation>
 <translation id="3617891479562106823">پس منظر غیر دستیاب ہیں۔ بعد میں دوبارہ کوشش کریں۔</translation>
 <translation id="3619115746895587757">کیپو چینو</translation>
diff --git a/chrome/app/resources/generated_resources_uz.xtb b/chrome/app/resources/generated_resources_uz.xtb
index 20834c44..6fec60f 100644
--- a/chrome/app/resources/generated_resources_uz.xtb
+++ b/chrome/app/resources/generated_resources_uz.xtb
@@ -380,6 +380,7 @@
 <translation id="1374844444528092021"><ph name="NETWORK_NAME" /> tarmog‘i talab qilayotgan sertifikat o‘rnatilmagan yoki eskirgan. Yangisini olish uchun qaytadan ulanib ko‘ring.</translation>
 <translation id="1375321115329958930">Saqlab olingan parollar</translation>
 <translation id="1375557162880614858">ChromeOS Flex tizimidagi ichiga oʻrnatilgan skrin rider – ChromeVox faollashtirilsinmi?</translation>
+<translation id="1375938286942050085">Sozlandi! Qurilma oʻyinlar uchun tayyorlanmoqda</translation>
 <translation id="137651782282853227">Saqlangan manzillar shu yerda turadi</translation>
 <translation id="1376771218494401509">Oynani &amp;nomlash...</translation>
 <translation id="1377600615067678409">Tashlab ketish</translation>
@@ -394,6 +395,7 @@
 <translation id="138784436342154190">Standart boshlang‘ich sahifa tiklansinmi?</translation>
 <translation id="1388253969141979417">Mikrofondan foydalanishga ruxsat berilgan</translation>
 <translation id="1388728792929436380">Yangilanishlar tugasa, <ph name="DEVICE_TYPE" /> qurilmasi qayta ishga tushiriladi.</translation>
+<translation id="1389601498324964367">Taqsimlanadigan xotira</translation>
 <translation id="139013308650923562">Qurilmangizga oʻrnatilgan shriftlardan foydalanishga ruxsat beradi</translation>
 <translation id="1390548061267426325">Oddiy ichki oynada ochish</translation>
 <translation id="1390907927270446471"><ph name="PROFILE_USERNAME" /> foydalanuvchisiga <ph name="PRINTER_NAME" /> printerida chop etishga ruxsat berilmagan. Administratorga murojaat qiling.</translation>
@@ -1062,6 +1064,7 @@
 <translation id="1992924914582925289">Qurilmadan olib tashlash</translation>
 <translation id="1994173015038366702">Sayt URL manzili</translation>
 <translation id="1995916364271252349">Saytlar qaysi axborotlarni (joylashuv, kamera, qalqib chiquvchi va boshqalar) ishlatishi va chiqarishini boshqarish</translation>
+<translation id="1997433994358798851">Qurilmangizga ulanishi uchun Chrome Bluetooth ishlatishiga ruxsat bering</translation>
 <translation id="1997616988432401742">Sertifikatlaringiz</translation>
 <translation id="1999115740519098545">Boshlanishda</translation>
 <translation id="2000419248597011803">Manzillar qatori va qidiruv oynasida kiritilgan so‘rovlar va ba’zi cookie ma’lumotlarni standart qidiruv tizimiga yuboradi</translation>
@@ -1726,6 +1729,7 @@
 <translation id="25899519884572181">Mutolaa rejimidan chiqish</translation>
 <translation id="2593499352046705383">Boshlashdan oldin maʼlumotlaringizni zaxiralang. <ph name="DEVICE_OS" /> oʻrnatilsa, qattiq diskdagi barcha maʼlumotlar tozalanadi. Batafsil: g.co/flex/InstallGuide.</translation>
 <translation id="2594999711683503743">Qidiring yoki veb-sahifa manzilini kiriting</translation>
+<translation id="2599048253926156421">Foydalanuvchi nomi vaqtincha xotiraga nusxalandi</translation>
 <translation id="2602501489742255173">Boshlash uchun tepaga suring</translation>
 <translation id="2603115962224169880">Kompyuterni tozalash vositasi</translation>
 <translation id="2603355571917519942">Voice Match tayyor</translation>
@@ -1949,6 +1953,7 @@
 <translation id="2804043232879091219">Muqobil brauzer ochilmadi</translation>
 <translation id="2804667941345577550">Bu saytdagi hisobingizdan avtomatik chiqarilasiz (shuningdek, ochiq varaqlardan ham)</translation>
 <translation id="2804680522274557040">Kamera faolsizlantirilgan</translation>
+<translation id="280518252911523675">Eski parol kiritilmasa, qurilmadagi axborotlar oʻchirib tashlanadi. Bu foydalanuvchini qayta sozlash uchun Google hisobingizga kirasiz.</translation>
 <translation id="2805539617243680210">Tayyor!</translation>
 <translation id="2805646850212350655">Microsoft (EFS) shifrlangan fayl tizimi</translation>
 <translation id="2805756323405976993">Ilovalar</translation>
@@ -2759,6 +2764,7 @@
 <translation id="3615073365085224194">Barmoq izi skaneriga barmogʻingizni tekizing</translation>
 <translation id="3615579745882581859"><ph name="FILE_NAME" /> tekshirilmoqda.</translation>
 <translation id="3615596877979647433">Tugma topilmadi. Moslashtirish uchun klaviatura tugmasini bosing</translation>
+<translation id="3616113530831147358">Audio</translation>
 <translation id="3616741288025931835">Brauzer tarixini &amp;tozalash...</translation>
 <translation id="3617891479562106823">Fon rasmlari mavjud emas. Keyinroq qaytadan urining.</translation>
 <translation id="3619115746895587757">Kappuchino</translation>
@@ -3063,6 +3069,7 @@
 <translation id="3895090224522145010">Kerberos uchun foydalanuvchi nomi</translation>
 <translation id="389521680295183045">Saytlarga qurilmadan foydalanishga oid axborotlarni soʻrashga ruxsat berish</translation>
 <translation id="3897298432557662720">{COUNT,plural, =1{rasm}other{# ta rasm}}</translation>
+<translation id="3897746662269329507"><ph name="DEVICE_TYPE" /> qurilmangiz oʻyinlar uchun mos ishlab chiqilgan. Tanishuv ilovasi orqali yuzlab yangi oʻyinlar, oʻyin takliflari va qurilmada mavjud oʻyin funksiyalari bilan tanishing.</translation>
 <translation id="3898233949376129212">Qurilmagi til</translation>
 <translation id="3898327728850887246"><ph name="SITE_NAME" /> quyidagi ruxsatlarni olmoqchi: <ph name="FIRST_PERMISSION" /> va <ph name="SECOND_PERMISSION" /></translation>
 <translation id="389901847090970821">Klaviaturani tanlang</translation>
@@ -3213,6 +3220,7 @@
 <translation id="4033471457476425443">Yangi jild qo‘shish</translation>
 <translation id="4033711848170683365">Brauzerning ishlashi haqida axborot ushbu qurilmadan butunlay tozalanadi. Bu profildagi Google hisoblari <ph name="DEVICE_TYPE" /> qurilmangizda boshqa ilovalar tomonidan foydalanilishi mumkin. <ph name="BEGIN_LINK" /><ph name="SETTING_SECTION" /> &gt; <ph name="ACCOUNTS_SECTION" /><ph name="END_LINK" /> orqali bu hisoblarni olib tashlashingiz mumkin.</translation>
 <translation id="4033963223187371752">Xavfsiz saytlarda rasmlar yoki freymlar kabi xavfli kontent boʻlishi mumkin.</translation>
+<translation id="4034741552964543387">Qurilmadagi axborotsiz davom etish</translation>
 <translation id="4034824040120875894">Printer</translation>
 <translation id="4035758313003622889">&amp;Vazifalar menejeri</translation>
 <translation id="4035877632587724847">Rad etish</translation>
@@ -3404,6 +3412,7 @@
 <translation id="4242533952199664413">Sozlamalarni ochish</translation>
 <translation id="4242577469625748426">Qurilmaga tartib-qoida sozlamalarini o‘rnatib bo‘lmadi: <ph name="VALIDATION_ERROR" />.</translation>
 <translation id="4243504193894350135">Printer pauza qilindi</translation>
+<translation id="424423026762293842">Qurilmadagi axborot tiklanmoqda</translation>
 <translation id="4244238649050961491">Stilus bilan ishlovchi boshqa ilovalar</translation>
 <translation id="4246980464509998944">Qoʻshimcha fikrlar:</translation>
 <translation id="424726838611654458">Har doim Adobe Reader dasturida ochish</translation>
@@ -4962,6 +4971,7 @@
 <translation id="5792728279623964091">Quvvat tugmasini bosing</translation>
 <translation id="5793339252089865437">Yangilanishlarni mobil tarmoq orqali amalga oshirsangiz, ancha pulingiz ketib qoladi.</translation>
 <translation id="5793420564274426163">Ulanishni tasdiqlash</translation>
+<translation id="5793430094159150686">Parolingiz oʻzgardi. Qurilmadagi axborotlarni tiklash uchun eski parol kiritilishi kerak.</translation>
 <translation id="5794034487966529952"><ph name="DESK_TITLE" /> ish stolida <ph name="NUM_BROWSERS" /> ta brauzer oynasi ochilgan</translation>
 <translation id="5794414402486823030">Doim tizimdagi birlamchi ko‘rish dasturida ochish</translation>
 <translation id="5794700615121138172">Linux umumiy jildlari</translation>
@@ -5886,6 +5896,7 @@
 <translation id="6700093763382332031">SIM karta bloklangan</translation>
 <translation id="6700480081846086223"><ph name="HOST_NAME" /> translatsiyasi</translation>
 <translation id="6701535245008341853">Profil yuklanmadi.</translation>
+<translation id="6701824422332982935">Bu kengaytmalardan foydalanish uchun sahifani yangilang</translation>
 <translation id="6702639462873609204">&amp;O‘zgartirish...</translation>
 <translation id="6703212423117969852">Keyinroq Chrome orqali qayta urinish mumkin.</translation>
 <translation id="6703254819490889819">Zaxiradan maʼlumotlarni tiklash</translation>
@@ -7112,6 +7123,7 @@
 <translation id="7903742244674067440">Sizda quyidagi sertifikatlash markazlari haqiqiyligini tasdiqlovchi sertifikatlar bor</translation>
 <translation id="7903925330883316394">Vosita: <ph name="UTILITY_TYPE" /></translation>
 <translation id="7904526211178107182">Tarmoqdagi boshqa qurilmalarga Linux portlariga ulanish imkoniyatini bering</translation>
+<translation id="7906440585529721295">Qurilmadagi axborotlar oʻchib ketadi</translation>
 <translation id="7907837847548254634">Fokusdagi obyektni tez belgilab chiqarish</translation>
 <translation id="7908378463497120834">Tashqi xotira qurilmasining bir yoki bir nechta bo‘limini ulab bo‘lmadi.</translation>
 <translation id="7909324225945368569">Profilni qayta nomlang</translation>
@@ -7449,6 +7461,7 @@
 <translation id="822050276545350872">Bundan buyon kutish shart emas</translation>
 <translation id="8221491193165283816">Odatda bildirishnomalarni bloklaysiz. Bu saytga ruxsat berish uchun bu yerga bosing.</translation>
 <translation id="822347941086490485">HID qurilmalar qidirilmoqda...</translation>
+<translation id="8223573963214454788">Davom etish va axborotlarni tozalash</translation>
 <translation id="8225046344534779393">Internet aloqasini tekshiring</translation>
 <translation id="8225265270453771718">Ilova oynasini namoyish qilish</translation>
 <translation id="8226222018808695353">Taqiqlangan</translation>
@@ -7549,6 +7562,7 @@
 <translation id="8314381333424235892">Kengaytma oʻrnatilmagan yoki mavjud emas</translation>
 <translation id="831440797644402910">Jild ochilmadi</translation>
 <translation id="8314835274931377415">Switch Accessni sozlash boshlansinmi?</translation>
+<translation id="8317582043908962055">P&amp;DF matnni tanitish</translation>
 <translation id="8317671367883557781">Yangi tarmoqqa ulanish</translation>
 <translation id="8319414634934645341">Kalitdan keng miqyosda foydalanish</translation>
 <translation id="8321837372750396788">Bu <ph name="DEVICE_TYPE" /> <ph name="MANAGER" /> tomonidan boshqariladi.</translation>
@@ -8434,6 +8448,7 @@
 <translation id="9203398526606335860">&amp;Ma’lumotlarni yig‘ish yoniq</translation>
 <translation id="9203904171912129171">Qurilmani tanlang</translation>
 <translation id="9206889157914079472">Ekran qulfida stilus yordamida qaydlar yaratish</translation>
+<translation id="9208192193641542858">Qurilmadagi axborot eski parolingiz bilan himoyalangan. Parolingiz oʻzgargan boʻlsa, eskisini kiriting.</translation>
 <translation id="9209563766569767417">Linux konteyneri sozlamalari tekshirilmoqda</translation>
 <translation id="9209689095351280025">Saytlar sizni internet boʻylab kuzatadigan cookie fayllardan foydalana olmaydi.</translation>
 <translation id="9211177926627870898">Yangilash zarur</translation>
diff --git a/chrome/app/resources/generated_resources_vi.xtb b/chrome/app/resources/generated_resources_vi.xtb
index 52d3c7bc..6a66de3 100644
--- a/chrome/app/resources/generated_resources_vi.xtb
+++ b/chrome/app/resources/generated_resources_vi.xtb
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">Chạm ngón tay của bạn vào cảm biến vân tay</translation>
 <translation id="3615579745882581859">Đang quét <ph name="FILE_NAME" />.</translation>
 <translation id="3615596877979647433">Thiếu khóa. Nhấn một phím trên bàn phím để tùy chỉnh</translation>
+<translation id="3616113530831147358">Âm thanh</translation>
 <translation id="3616741288025931835">&amp;Xoá Dữ liệu Duyệt web...</translation>
 <translation id="3617891479562106823">Không có nền. Hãy thử lại sau.</translation>
 <translation id="3619115746895587757">Cà phê cappuccino</translation>
diff --git a/chrome/app/resources/generated_resources_zh-CN.xtb b/chrome/app/resources/generated_resources_zh-CN.xtb
index c0e0045..d03cb70 100644
--- a/chrome/app/resources/generated_resources_zh-CN.xtb
+++ b/chrome/app/resources/generated_resources_zh-CN.xtb
@@ -2748,6 +2748,7 @@
 <translation id="3615073365085224194">用手指轻触指纹传感器</translation>
 <translation id="3615579745882581859">正在扫描“<ph name="FILE_NAME" />”。</translation>
 <translation id="3615596877979647433">缺少按键。按一个键盘按键即可自定义</translation>
+<translation id="3616113530831147358">音频</translation>
 <translation id="3616741288025931835">清除浏览数据(&amp;C)...</translation>
 <translation id="3617891479562106823">背景不可用。请稍后重试。</translation>
 <translation id="3619115746895587757">卡布奇诺</translation>
diff --git a/chrome/app/resources/generated_resources_zh-HK.xtb b/chrome/app/resources/generated_resources_zh-HK.xtb
index c6d2b894..41c30e5e 100644
--- a/chrome/app/resources/generated_resources_zh-HK.xtb
+++ b/chrome/app/resources/generated_resources_zh-HK.xtb
@@ -218,7 +218,7 @@
 <translation id="1197199342062592414">開始使用</translation>
 <translation id="11978075283960463">儲存在應用程式中的資料大小:<ph name="APP_SIZE" /></translation>
 <translation id="1197935538609051549">停用</translation>
-<translation id="1198066799963193307">低視能語音工具</translation>
+<translation id="1198066799963193307">低視力語音工具</translation>
 <translation id="119944043368869598">全部清除</translation>
 <translation id="1199814941632954229">正在為這些憑證設定檔佈建憑證</translation>
 <translation id="120069043972472860">無法觀看</translation>
@@ -1512,7 +1512,7 @@
 <translation id="2371076942591664043">完成後開啟(&amp;D)</translation>
 <translation id="2373666622366160481">依紙張大小自動調整</translation>
 <translation id="2375406435414127095">連線至您的手機</translation>
-<translation id="2376056713414548745">朗讀內容</translation>
+<translation id="2376056713414548745">朗讀</translation>
 <translation id="2377588536920405462">關閉裝置的主要位置資訊設定,即可關閉定位服務。您也可以在位置資訊設定中關閉使用 Wi‑Fi、流動網絡和感應器確定位置的功能。</translation>
 <translation id="2377667304966270281">嚴重錯誤</translation>
 <translation id="237828693408258535">要翻譯此網頁嗎?</translation>
@@ -2341,7 +2341,7 @@
 <translation id="3163511056918491211">隨時輕鬆還原您的資料或轉用裝置。您的備份會上載至 Google,並透過您的 Google 帳戶密碼加密。</translation>
 <translation id="3164329792803560526">正在將此分頁與 <ph name="APP_NAME" /> 共用</translation>
 <translation id="3165390001037658081">部分流動網絡供應商可能會封鎖此功能。</translation>
-<translation id="3169930038976362151">選擇符合自身需求的主題。如要變更主題、桌布、螢幕保護程式和其他設定,只要按住桌面即可。</translation>
+<translation id="3169930038976362151">選擇切合您需要的主題。如要變更主題、桌布、螢幕保護程式和其他設定,只要輕觸並按住桌面即可。</translation>
 <translation id="3170072451822350649">您也可以略過登入程序,<ph name="LINK_START" />以訪客身分瀏覽<ph name="LINK_END" />。</translation>
 <translation id="31774765611822736">新分頁位於左側</translation>
 <translation id="3177909033752230686">網頁語言:</translation>
@@ -2772,6 +2772,7 @@
 <translation id="3615073365085224194">請以手指輕觸指紋感應器</translation>
 <translation id="3615579745882581859">正在掃瞄「<ph name="FILE_NAME" />」。</translation>
 <translation id="3615596877979647433">缺少按鍵。按下鍵盤按鍵即可自訂</translation>
+<translation id="3616113530831147358">音效檔案</translation>
 <translation id="3616741288025931835">清除瀏覽數據(&amp;C)…</translation>
 <translation id="3617891479562106823">無法自訂背景,請稍候再試。</translation>
 <translation id="3619115746895587757">泡沫咖啡</translation>
@@ -3215,7 +3216,7 @@
 <translation id="402184264550408568">(TCP)</translation>
 <translation id="4021909830315618592">複製版本詳情</translation>
 <translation id="4021941025609472374">關閉左側分頁</translation>
-<translation id="402211067068791756">這會清除目前顯示的網站所儲存的資料,共 <ph name="TOTAL_USAGE" /></translation>
+<translation id="402211067068791756">此操作會清除已顯示網站儲存的資料,共 <ph name="TOTAL_USAGE" /></translation>
 <translation id="4022426551683927403">新增到字典(&amp;A)</translation>
 <translation id="4025039777635956441">將已選取的網站設定為靜音</translation>
 <translation id="4028467762035011525">新增輸入方法</translation>
@@ -3465,7 +3466,7 @@
 <translation id="4281844954008187215">服務條款</translation>
 <translation id="4282196459431406533">Smart Lock 已啟用</translation>
 <translation id="4284755288573763878">要關閉「強化安全瀏覽」功能嗎?</translation>
-<translation id="4284903252249997120">ChromeVox 螢幕閱讀器和隨選朗讀</translation>
+<translation id="4284903252249997120">ChromeVox 螢幕閱讀器和選取以朗讀</translation>
 <translation id="4285418559658561636">更新密碼</translation>
 <translation id="4285498937028063278">取消固定</translation>
 <translation id="428565720843367874">掃描這個檔案時,防毒軟件發生意外錯誤。</translation>
@@ -5382,7 +5383,7 @@
 <translation id="6200151268994853226">管理擴充程式</translation>
 <translation id="6201608810045805374">要移除此帳戶嗎?</translation>
 <translation id="6202304368170870640">您可使用 PIN 登入或解鎖裝置。</translation>
-<translation id="6206199626856438589">系統會將你登出這些目前顯示的網站,包含已開啟的分頁</translation>
+<translation id="6206199626856438589">您將會從已顯示的網站 (包括已開啟的分頁) 中登出</translation>
 <translation id="6206311232642889873">複製圖片(&amp;Y)</translation>
 <translation id="6207200176136643843">重設為預設縮放等級</translation>
 <translation id="6207937957461833379">國家/地區</translation>
@@ -5929,7 +5930,7 @@
 <translation id="6733620523445262364">建立咗 <ph name="BOOKMARK_TITLE" />。</translation>
 <translation id="6735304988756581115">顯示 Cookie 和其他網站數據…</translation>
 <translation id="6736243959894955139">位址</translation>
-<translation id="6737393581255281855">要清除顯示的資料嗎?</translation>
+<translation id="6737393581255281855">要清除已顯示的資料嗎?</translation>
 <translation id="6737663862851963468">移除 Kerberos 票證</translation>
 <translation id="6738430949033571771">正在驗證帳戶…</translation>
 <translation id="6739923123728562974">顯示桌面捷徑</translation>
@@ -7609,7 +7610,7 @@
 <translation id="8366396658833131068">您的網絡連線已恢復。請選取其他網絡,或按下方的 [繼續] 按鈕啟動 Kiosk 應用程式。</translation>
 <translation id="8366694425498033255">選字鍵</translation>
 <translation id="8368859634510605990">開啟所有書籤(&amp;O)</translation>
-<translation id="8369028061188107403">這會清除目前顯示的網站所儲存的資料 (共 <ph name="TOTAL_USAGE" />),以及所安裝的應用程式</translation>
+<translation id="8369028061188107403">此操作會清除已顯示網站儲存的資料 (共 <ph name="TOTAL_USAGE" />),以及所安裝的應用程式</translation>
 <translation id="8370294614544004647">蓋上手提電腦時進入休眠狀態</translation>
 <translation id="8371695176452482769">請說話</translation>
 <translation id="8371925839118813971">{NUM_TABS,plural, =1{將單一網站靜音}other{將多個網站靜音}}</translation>
diff --git a/chrome/app/resources/generated_resources_zh-TW.xtb b/chrome/app/resources/generated_resources_zh-TW.xtb
index e24c2b5..e40670c 100644
--- a/chrome/app/resources/generated_resources_zh-TW.xtb
+++ b/chrome/app/resources/generated_resources_zh-TW.xtb
@@ -2757,6 +2757,7 @@
 <translation id="3615073365085224194">請以手指輕觸指紋感應器</translation>
 <translation id="3615579745882581859">正在掃描「<ph name="FILE_NAME" />」。</translation>
 <translation id="3615596877979647433">缺少按鍵。按下鍵盤按鍵即可自訂</translation>
+<translation id="3616113530831147358">音訊</translation>
 <translation id="3616741288025931835">清除瀏覽資料(&amp;C)...</translation>
 <translation id="3617891479562106823">目前無法存取背景,請稍後再試。</translation>
 <translation id="3619115746895587757">卡布奇諾</translation>
diff --git a/chrome/app/resources/generated_resources_zu.xtb b/chrome/app/resources/generated_resources_zu.xtb
index 8c01a68..2022a95 100644
--- a/chrome/app/resources/generated_resources_zu.xtb
+++ b/chrome/app/resources/generated_resources_zu.xtb
@@ -2773,6 +2773,7 @@
 <translation id="3615073365085224194">Thinta inzwa yezigxivizo zeminwe ngomunwe wakho</translation>
 <translation id="3615579745882581859">I-<ph name="FILE_NAME" /> iyaskenwa</translation>
 <translation id="3615596877979647433">Ukhiye uyashoda. Cindezela ukhiye wekhibhodi ukuze wenze ngendlela oyifisayo</translation>
+<translation id="3616113530831147358">Umsindo</translation>
 <translation id="3616741288025931835">Sula idatha yokudlulisa amehlo...</translation>
 <translation id="3617891479562106823">Ingemuva alitholakali. Zama futhi kamuva.</translation>
 <translation id="3619115746895587757">I-Cappuccino</translation>
diff --git a/chrome/browser/BUILD.gn b/chrome/browser/BUILD.gn
index fe3c333..1abb46239 100644
--- a/chrome/browser/BUILD.gn
+++ b/chrome/browser/BUILD.gn
@@ -5132,6 +5132,7 @@
       "//chromeos/ash/components/assistant:buildflags",
       "//chromeos/ash/components/dbus/concierge",
       "//chromeos/ash/components/dbus/session_manager",
+      "//chromeos/ash/components/dbus/update_engine",
       "//chromeos/ash/components/dbus/userdataauth:userdataauth",
       "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
       "//chromeos/ash/components/memory",
@@ -5157,7 +5158,6 @@
       "//chromeos/dbus/power",
       "//chromeos/dbus/tpm_manager",
       "//chromeos/dbus/tpm_manager:tpm_manager_proto",
-      "//chromeos/dbus/update_engine",
       "//chromeos/dbus/util",
       "//chromeos/login/login_state",
       "//chromeos/network",
diff --git a/chrome/browser/about_flags.cc b/chrome/browser/about_flags.cc
index 2057fb7..8d09284 100644
--- a/chrome/browser/about_flags.cc
+++ b/chrome/browser/about_flags.cc
@@ -6501,6 +6501,11 @@
      flag_descriptions::kEncryptedClientHelloDescription, kOsAll,
      FEATURE_VALUE_TYPE(net::features::kEncryptedClientHello)},
 
+    {"use-dns-https-svcb-alpn", flag_descriptions::kUseDnsHttpsSvcbAlpnName,
+     flag_descriptions::kUseDnsHttpsSvcbAlpnDescription,
+     kOsLinux | kOsMac | kOsWin | kOsCrOS | kOsAndroid,
+     FEATURE_VALUE_TYPE(net::features::kUseDnsHttpsSvcbAlpn)},
+
     {"web-bundles", flag_descriptions::kWebBundlesName,
      flag_descriptions::kWebBundlesDescription, kOsAll,
      FEATURE_VALUE_TYPE(features::kWebBundles)},
diff --git a/chrome/browser/apps/app_service/publishers/publisher_unittest.cc b/chrome/browser/apps/app_service/publishers/publisher_unittest.cc
index 541bfec..bcbc7b3a 100644
--- a/chrome/browser/apps/app_service/publishers/publisher_unittest.cc
+++ b/chrome/browser/apps/app_service/publishers/publisher_unittest.cc
@@ -236,11 +236,7 @@
 
 class PublisherTest : public extensions::ExtensionServiceTestBase {
  public:
-  PublisherTest() {
-    scoped_feature_list_.InitAndEnableFeature(
-        kAppServiceOnAppTypeInitializedWithoutMojom);
-  }
-
+  PublisherTest() = default;
   PublisherTest(const PublisherTest&) = delete;
   PublisherTest& operator=(const PublisherTest&) = delete;
 
@@ -646,9 +642,7 @@
     crosapi::browser_util::SetLacrosEnabledForTest(true);
     scoped_feature_list_.Reset();
     scoped_feature_list_.InitWithFeatures(
-        {features::kWebAppsCrosapi, chromeos::features::kLacrosPrimary,
-         kAppServiceOnAppTypeInitializedWithoutMojom},
-        {});
+        {features::kWebAppsCrosapi, chromeos::features::kLacrosPrimary}, {});
   }
 
   StandaloneBrowserPublisherTest(const StandaloneBrowserPublisherTest&) =
@@ -1026,9 +1020,7 @@
   BorealisPublisherTest() {
     scoped_feature_list_.Reset();
     scoped_feature_list_.InitWithFeatures(
-        {features::kBorealis, chromeos::features::kBorealisPermitted,
-         kAppServiceOnAppTypeInitializedWithoutMojom},
-        {});
+        {features::kBorealis, chromeos::features::kBorealisPermitted}, {});
   }
 };
 
diff --git a/chrome/browser/ash/BUILD.gn b/chrome/browser/ash/BUILD.gn
index b41b427..ec2a7c4 100644
--- a/chrome/browser/ash/BUILD.gn
+++ b/chrome/browser/ash/BUILD.gn
@@ -2010,6 +2010,7 @@
     "//chromeos/ash/components/dbus/anomaly_detector:proto",
     "//chromeos/ash/components/dbus/authpolicy",
     "//chromeos/ash/components/dbus/authpolicy:authpolicy_proto",
+    "//chromeos/ash/components/dbus/chunneld",
     "//chromeos/ash/components/dbus/cicerone",
     "//chromeos/ash/components/dbus/cicerone:cicerone_proto",
     "//chromeos/ash/components/dbus/concierge",
@@ -2023,6 +2024,7 @@
     "//chromeos/ash/components/dbus/session_manager",
     "//chromeos/ash/components/dbus/system_clock",
     "//chromeos/ash/components/dbus/system_proxy:system_proxy_proto",
+    "//chromeos/ash/components/dbus/update_engine",
     "//chromeos/ash/components/dbus/userdataauth",
     "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
     "//chromeos/ash/components/memory",
@@ -2038,7 +2040,6 @@
     "//chromeos/dbus:vm_launch_proto",
     "//chromeos/dbus/attestation",
     "//chromeos/dbus/attestation:attestation_proto",
-    "//chromeos/dbus/chunneld",
     "//chromeos/dbus/common",
     "//chromeos/dbus/constants",
     "//chromeos/dbus/cros_disks",
@@ -2053,7 +2054,6 @@
     "//chromeos/dbus/runtime_probe",
     "//chromeos/dbus/tpm_manager",
     "//chromeos/dbus/tpm_manager:tpm_manager_proto",
-    "//chromeos/dbus/update_engine",
     "//chromeos/login/login_state",
     "//chromeos/metrics",
     "//chromeos/network",
diff --git a/chrome/browser/ash/app_mode/kiosk_app_update_service_browsertest.cc b/chrome/browser/ash/app_mode/kiosk_app_update_service_browsertest.cc
index 31fff42..bd6be64 100644
--- a/chrome/browser/ash/app_mode/kiosk_app_update_service_browsertest.cc
+++ b/chrome/browser/ash/app_mode/kiosk_app_update_service_browsertest.cc
@@ -33,7 +33,7 @@
 #include "chrome/browser/profiles/profile.h"
 #include "chrome/common/chrome_switches.h"
 #include "chrome/common/pref_names.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/browser/browser_thread.h"
 #include "content/public/test/browser_test.h"
diff --git a/chrome/browser/ash/arc/enterprise/cert_store/cert_store_service_browsertest.cc b/chrome/browser/ash/arc/enterprise/cert_store/cert_store_service_browsertest.cc
index 08c1054..de9ecba 100644
--- a/chrome/browser/ash/arc/enterprise/cert_store/cert_store_service_browsertest.cc
+++ b/chrome/browser/ash/arc/enterprise/cert_store/cert_store_service_browsertest.cc
@@ -38,7 +38,7 @@
 #include "chrome/services/keymaster/public/mojom/cert_store.mojom.h"
 #include "chrome/test/base/mixin_based_in_process_browser_test.h"
 #include "chrome/test/base/testing_profile.h"
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "components/policy/policy_constants.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/browser/browser_task_traits.h"
diff --git a/chrome/browser/ash/borealis/borealis_context_unittest.cc b/chrome/browser/ash/borealis/borealis_context_unittest.cc
index df2bc27..e605247 100644
--- a/chrome/browser/ash/borealis/borealis_context_unittest.cc
+++ b/chrome/browser/ash/borealis/borealis_context_unittest.cc
@@ -22,10 +22,10 @@
 #include "chrome/browser/ash/guest_os/dbus_test_helper.h"
 #include "chrome/browser/ash/guest_os/guest_os_stability_monitor.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
-#include "chromeos/dbus/chunneld/fake_chunneld_client.h"
 #include "components/exo/shell_surface_util.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -138,8 +138,8 @@
 }
 
 TEST_F(BorealisContextTest, ChunneldFailure) {
-  auto* chunneld_client = static_cast<chromeos::FakeChunneldClient*>(
-      chromeos::ChunneldClient::Get());
+  auto* chunneld_client =
+      static_cast<ash::FakeChunneldClient*>(ash::ChunneldClient::Get());
 
   chunneld_client->NotifyChunneldStopped();
   histogram_tester_.ExpectUniqueSample(
diff --git a/chrome/browser/ash/chrome_browser_main_parts_ash.cc b/chrome/browser/ash/chrome_browser_main_parts_ash.cc
index a0d621e5..b8fc3fc 100644
--- a/chrome/browser/ash/chrome_browser_main_parts_ash.cc
+++ b/chrome/browser/ash/chrome_browser_main_parts_ash.cc
@@ -203,6 +203,7 @@
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/fake_userdataauth_client.h"
 #include "chromeos/ash/components/network/fast_transition_observer.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector_stub.h"
 #include "chromeos/ash/services/cros_healthd/private/cpp/data_collector.h"
 #include "chromeos/ash/services/cros_healthd/public/cpp/service_connection.h"
@@ -215,7 +216,6 @@
 #include "chromeos/dbus/power/power_policy_controller.h"
 #include "chromeos/dbus/util/version_loader.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
 #include "chromeos/services/machine_learning/public/cpp/service_connection.h"
diff --git a/chrome/browser/ash/crosapi/BUILD.gn b/chrome/browser/ash/crosapi/BUILD.gn
index ddf062a..2ba4de0 100644
--- a/chrome/browser/ash/crosapi/BUILD.gn
+++ b/chrome/browser/ash/crosapi/BUILD.gn
@@ -246,6 +246,7 @@
     "//chrome/common:constants",
     "//chromeos/ash/components/dbus/lorgnette_manager:lorgnette_proto",
     "//chromeos/ash/components/dbus/session_manager",
+    "//chromeos/ash/components/dbus/update_engine",
     "//chromeos/ash/components/dbus/upstart",
     "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
     "//chromeos/components/cdm_factory_daemon:cdm_factory_daemon_browser",
@@ -259,7 +260,6 @@
     "//chromeos/dbus/cros_disks",
     "//chromeos/dbus/power",
     "//chromeos/dbus/resourced",
-    "//chromeos/dbus/update_engine",
     "//chromeos/dbus/util",
     "//chromeos/login/login_state",
     "//chromeos/network",
diff --git a/chrome/browser/ash/crosapi/networking_private_ash.h b/chrome/browser/ash/crosapi/networking_private_ash.h
index d6d745d..c0867701 100644
--- a/chrome/browser/ash/crosapi/networking_private_ash.h
+++ b/chrome/browser/ash/crosapi/networking_private_ash.h
@@ -6,8 +6,8 @@
 #define CHROME_BROWSER_ASH_CROSAPI_NETWORKING_PRIVATE_ASH_H_
 
 #include "base/scoped_observation.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
 #include "chromeos/crosapi/mojom/networking_private.mojom.h"
-#include "chromeos/network/network_certificate_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "mojo/public/cpp/bindings/pending_receiver.h"
diff --git a/chrome/browser/ash/crosapi/vpn_service_ash.cc b/chrome/browser/ash/crosapi/vpn_service_ash.cc
index 8ceb728e..04d98ea 100644
--- a/chrome/browser/ash/crosapi/vpn_service_ash.cc
+++ b/chrome/browser/ash/crosapi/vpn_service_ash.cc
@@ -17,10 +17,10 @@
 #include "chrome/browser/ash/crosapi/crosapi_ash.h"
 #include "chrome/browser/ash/profiles/profile_helper.h"
 #include "chrome/browser/profiles/profile_manager.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_third_party_vpn_driver_client.h"
 #include "chromeos/dbus/shill/shill_third_party_vpn_observer.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chrome/browser/ash/crosapi/vpn_service_ash.h b/chrome/browser/ash/crosapi/vpn_service_ash.h
index 32bb6547..9f07731 100644
--- a/chrome/browser/ash/crosapi/vpn_service_ash.h
+++ b/chrome/browser/ash/crosapi/vpn_service_ash.h
@@ -17,11 +17,11 @@
 #include "base/memory/weak_ptr.h"
 #include "base/scoped_observation.h"
 #include "chrome/common/extensions/api/vpn_provider.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 #include "chromeos/crosapi/mojom/vpn_service.mojom.h"
 #include "chromeos/dbus/shill/shill_third_party_vpn_driver_client.h"
 #include "chromeos/dbus/shill/shill_third_party_vpn_observer.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_configuration_observer.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
diff --git a/chrome/browser/ash/crostini/ansible/ansible_management_service_unittest.cc b/chrome/browser/ash/crostini/ansible/ansible_management_service_unittest.cc
index 2147a47..9dda7021 100644
--- a/chrome/browser/ash/crostini/ansible/ansible_management_service_unittest.cc
+++ b/chrome/browser/ash/crostini/ansible/ansible_management_service_unittest.cc
@@ -9,10 +9,10 @@
 #include "chrome/browser/ash/crostini/crostini_pref_names.h"
 #include "chrome/browser/ash/crostini/crostini_test_util.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_task_environment.h"
@@ -35,7 +35,7 @@
  public:
   AnsibleManagementServiceTest() {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -69,7 +69,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_disk_unittest.cc b/chrome/browser/ash/crostini/crostini_disk_unittest.cc
index 227d4660..b2ec5e7 100644
--- a/chrome/browser/ash/crostini/crostini_disk_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_disk_unittest.cc
@@ -12,12 +12,12 @@
 #include "chrome/browser/ash/crostini/crostini_test_helper.h"
 #include "chrome/browser/ash/crostini/crostini_types.mojom.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_service.pb.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gmock/include/gmock/gmock-matchers.h"
@@ -55,7 +55,7 @@
  public:
   CrostiniDiskTestDbus() {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -75,7 +75,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_export_import_unittest.cc b/chrome/browser/ash/crostini/crostini_export_import_unittest.cc
index ecaf3ff7..7786a0f 100644
--- a/chrome/browser/ash/crostini/crostini_export_import_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_export_import_unittest.cc
@@ -15,13 +15,13 @@
 #include "chrome/browser/notifications/notification_display_service_factory.h"
 #include "chrome/browser/notifications/notification_display_service_tester.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_service.pb.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_task_environment.h"
@@ -126,7 +126,7 @@
       : default_container_id_(DefaultContainerId()),
         custom_container_id_(kCrostiniDefaultVmType, "MyVM", "MyContainer") {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -141,7 +141,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_installer_unittest.cc b/chrome/browser/ash/crostini/crostini_installer_unittest.cc
index 006c7ca..b046461c 100644
--- a/chrome/browser/ash/crostini/crostini_installer_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_installer_unittest.cc
@@ -21,13 +21,13 @@
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_service.pb.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/dlcservice_client.h"
 #include "content/public/test/browser_task_environment.h"
@@ -117,7 +117,7 @@
 
     chromeos::DlcserviceClient::InitializeFake();
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     SetOSRelease();
     waiting_fake_concierge_client_ =
@@ -155,7 +155,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
     chromeos::DlcserviceClient::Shutdown();
 
diff --git a/chrome/browser/ash/crostini/crostini_manager_unittest.cc b/chrome/browser/ash/crostini/crostini_manager_unittest.cc
index d4d764e..ab51664 100644
--- a/chrome/browser/ash/crostini/crostini_manager_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_manager_unittest.cc
@@ -38,6 +38,7 @@
 #include "chrome/test/base/testing_profile.h"
 #include "chromeos/ash/components/dbus/anomaly_detector/anomaly_detector_client.h"
 #include "chromeos/ash/components/dbus/anomaly_detector/fake_anomaly_detector_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_service.pb.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
@@ -47,7 +48,6 @@
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/session_manager/fake_session_manager_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/fake_cryptohome_misc_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/dlcservice_client.h"
 #include "components/account_id/account_id.h"
@@ -194,7 +194,7 @@
         browser_part_(g_browser_process->platform_part()) {
     chromeos::DBusThreadManager::Initialize();
     ash::AnomalyDetectorClient::InitializeFake();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -213,7 +213,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_package_notification_unittest.cc b/chrome/browser/ash/crostini/crostini_package_notification_unittest.cc
index 13d116e..798b8f9 100644
--- a/chrome/browser/ash/crostini/crostini_package_notification_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_package_notification_unittest.cc
@@ -11,10 +11,10 @@
 #include "chrome/browser/ash/crostini/crostini_test_helper.h"
 #include "chrome/browser/ash/crostini/crostini_util.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gmock/include/gmock/gmock.h"
@@ -36,7 +36,7 @@
 
   void SetUp() override {
     DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -59,7 +59,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_package_service_unittest.cc b/chrome/browser/ash/crostini/crostini_package_service_unittest.cc
index bd2650d..a1aff2a 100644
--- a/chrome/browser/ash/crostini/crostini_package_service_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_package_service_unittest.cc
@@ -19,13 +19,13 @@
 #include "chrome/browser/notifications/notification_display_service_tester.h"
 #include "chrome/grit/generated_resources.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/vm_applications/apps.pb.h"
 #include "content/public/test/browser_task_environment.h"
@@ -170,7 +170,7 @@
 
   void SetUp() override {
     DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -232,7 +232,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_port_forwarder_unittest.cc b/chrome/browser/ash/crostini/crostini_port_forwarder_unittest.cc
index b60bf5074..f765958f 100644
--- a/chrome/browser/ash/crostini/crostini_port_forwarder_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_port_forwarder_unittest.cc
@@ -8,10 +8,10 @@
 #include "chrome/browser/ash/crostini/crostini_manager.h"
 #include "chrome/browser/ash/crostini/crostini_test_helper.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/permission_broker/fake_permission_broker_client.h"
 #include "content/public/test/browser_task_environment.h"
@@ -47,7 +47,7 @@
 
   void SetUp() override {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -74,7 +74,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_sshfs_unittest.cc b/chrome/browser/ash/crostini/crostini_sshfs_unittest.cc
index 85644b42..4292c94 100644
--- a/chrome/browser/ash/crostini/crostini_sshfs_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_sshfs_unittest.cc
@@ -21,11 +21,11 @@
 #include "chrome/browser/ash/file_manager/volume_manager.h"
 #include "chrome/browser/ash/file_manager/volume_manager_factory.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/cros_disks/cros_disks_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/vm_applications/apps.pb.h"
@@ -67,7 +67,7 @@
  public:
   CrostiniSshfsHelperTest() {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -107,7 +107,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_upgrade_available_notification_unittest.cc b/chrome/browser/ash/crostini/crostini_upgrade_available_notification_unittest.cc
index f5473a2..3607369e 100644
--- a/chrome/browser/ash/crostini/crostini_upgrade_available_notification_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_upgrade_available_notification_unittest.cc
@@ -17,11 +17,11 @@
 #include "chrome/common/webui_url_constants.h"
 #include "chrome/test/base/browser_with_test_window_test.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_service.pb.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -47,7 +47,7 @@
   void SetUp() override {
     BrowserWithTestWindowTest::SetUp();
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -65,7 +65,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/crostini/crostini_util_unittest.cc b/chrome/browser/ash/crostini/crostini_util_unittest.cc
index bea1208b..47b5531 100644
--- a/chrome/browser/ash/crostini/crostini_util_unittest.cc
+++ b/chrome/browser/ash/crostini/crostini_util_unittest.cc
@@ -15,11 +15,11 @@
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/dlcservice_client.h"
 #include "content/public/test/browser_task_environment.h"
@@ -48,7 +48,7 @@
             TestingBrowserProcess::GetGlobal())),
         browser_part_(g_browser_process->platform_part()) {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -60,7 +60,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/dbus/ash_dbus_helper.cc b/chrome/browser/ash/dbus/ash_dbus_helper.cc
index e655166..d476a6b7 100644
--- a/chrome/browser/ash/dbus/ash_dbus_helper.cc
+++ b/chrome/browser/ash/dbus/ash_dbus_helper.cc
@@ -20,6 +20,7 @@
 #include "chromeos/ash/components/dbus/audio/cras_audio_client.h"
 #include "chromeos/ash/components/dbus/authpolicy/authpolicy_client.h"
 #include "chromeos/ash/components/dbus/biod/biod_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/cros_healthd/cros_healthd_client.h"
@@ -41,6 +42,7 @@
 #include "chromeos/ash/components/dbus/system_clock/system_clock_client.h"
 #include "chromeos/ash/components/dbus/system_proxy/system_proxy_client.h"
 #include "chromeos/ash/components/dbus/typecd/typecd_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/dbus/upstart/upstart_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/arc_quota_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/cryptohome_misc_client.h"
@@ -55,7 +57,6 @@
 #include "chromeos/dbus/arc/arc_sensor_service_client.h"
 #include "chromeos/dbus/attestation/attestation_client.h"
 #include "chromeos/dbus/cdm_factory_daemon/cdm_factory_daemon_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/constants/dbus_paths.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/dlcservice_client.h"
@@ -74,7 +75,6 @@
 #include "chromeos/dbus/smbprovider/smb_provider_client.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
 #include "chromeos/dbus/u2f/u2f_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "device/bluetooth/dbus/bluez_dbus_manager.h"
 #include "device/bluetooth/floss/floss_dbus_manager.h"
 #include "device/bluetooth/floss/floss_features.h"
@@ -129,7 +129,7 @@
   InitializeDBusClient<AuthPolicyClient>(bus);
   InitializeDBusClient<BiodClient>(bus);  // For device::Fingerprint.
   InitializeDBusClient<chromeos::CdmFactoryDaemonClient>(bus);
-  InitializeDBusClient<chromeos::ChunneldClient>(bus);
+  InitializeDBusClient<ChunneldClient>(bus);
   InitializeDBusClient<CiceroneClient>(bus);
   // ConciergeClient depends on CiceroneClient.
   InitializeDBusClient<ConciergeClient>(bus);
@@ -171,7 +171,7 @@
   InitializeDBusClient<chromeos::TpmManagerClient>(bus);
   InitializeDBusClient<TypecdClient>(bus);
   InitializeDBusClient<chromeos::U2FClient>(bus);
-  InitializeDBusClient<chromeos::UpdateEngineClient>(bus);
+  InitializeDBusClient<UpdateEngineClient>(bus);
   InitializeDBusClient<UserDataAuthClient>(bus);
   InitializeDBusClient<UpstartClient>(bus);
   InitializeDBusClient<VirtualFileProviderClient>(bus);
@@ -235,7 +235,7 @@
   VirtualFileProviderClient::Shutdown();
   UpstartClient::Shutdown();
   UserDataAuthClient::Shutdown();
-  chromeos::UpdateEngineClient::Shutdown();
+  UpdateEngineClient::Shutdown();
   chromeos::U2FClient::Shutdown();
   TypecdClient::Shutdown();
   chromeos::TpmManagerClient::Shutdown();
@@ -282,7 +282,7 @@
   CrasAudioClient::Shutdown();
   ConciergeClient::Shutdown();
   CiceroneClient::Shutdown();
-  chromeos::ChunneldClient::Shutdown();
+  ChunneldClient::Shutdown();
   chromeos::CdmFactoryDaemonClient::Shutdown();
   BiodClient::Shutdown();
   AuthPolicyClient::Shutdown();
diff --git a/chrome/browser/ash/eol_notification.cc b/chrome/browser/ash/eol_notification.cc
index 69f5f70..85c285c 100644
--- a/chrome/browser/ash/eol_notification.cc
+++ b/chrome/browser/ash/eol_notification.cc
@@ -20,7 +20,7 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/common/url_constants.h"
 #include "chrome/grit/generated_resources.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "components/strings/grit/components_strings.h"
 #include "components/vector_icons/vector_icons.h"
diff --git a/chrome/browser/ash/eol_notification.h b/chrome/browser/ash/eol_notification.h
index d39dce5..f09a757 100644
--- a/chrome/browser/ash/eol_notification.h
+++ b/chrome/browser/ash/eol_notification.h
@@ -10,7 +10,7 @@
 #include "base/memory/weak_ptr.h"
 #include "base/time/time.h"
 #include "chrome/browser/profiles/profile.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "third_party/cros_system_api/dbus/update_engine/dbus-constants.h"
 #include "ui/message_center/public/cpp/notification.h"
 
diff --git a/chrome/browser/ash/eol_notification_unittest.cc b/chrome/browser/ash/eol_notification_unittest.cc
index ffd4b43..5f9fcd8 100644
--- a/chrome/browser/ash/eol_notification_unittest.cc
+++ b/chrome/browser/ash/eol_notification_unittest.cc
@@ -17,8 +17,8 @@
 #include "chrome/test/base/testing_profile.h"
 #include "chrome/test/base/testing_profile_manager.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "ui/base/l10n/l10n_util.h"
 #include "ui/base/resource/resource_bundle.h"
 #include "ui/chromeos/devicetype_utils.h"
diff --git a/chrome/browser/ash/exo/chrome_data_exchange_delegate_unittest.cc b/chrome/browser/ash/exo/chrome_data_exchange_delegate_unittest.cc
index e466de92..d11ae09 100644
--- a/chrome/browser/ash/exo/chrome_data_exchange_delegate_unittest.cc
+++ b/chrome/browser/ash/exo/chrome_data_exchange_delegate_unittest.cc
@@ -24,11 +24,11 @@
 #include "chrome/browser/ash/guest_os/guest_os_share_path.h"
 #include "chrome/browser/ash/plugin_vm/plugin_vm_util.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/exo/shell_surface_util.h"
 #include "content/public/common/drop_data.h"
@@ -74,7 +74,7 @@
  public:
   void SetUp() override {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ConciergeClient::InitializeFake();
     SeneschalClient::InitializeFake();
@@ -122,7 +122,7 @@
     SeneschalClient::Shutdown();
     ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/file_manager/file_manager_jstest.cc b/chrome/browser/ash/file_manager/file_manager_jstest.cc
index 71ee153..e5fa4ef 100644
--- a/chrome/browser/ash/file_manager/file_manager_jstest.cc
+++ b/chrome/browser/ash/file_manager/file_manager_jstest.cc
@@ -298,3 +298,7 @@
 IN_PROC_BROWSER_TEST_F(FileManagerJsTest, RecentDateBucketTest) {
   RunTestURL("common/js/recent_date_bucket_unittest.js");
 }
+
+IN_PROC_BROWSER_TEST_F(FileManagerJsTest, XfBreadcrumbs) {
+  RunTestURL("widgets/xf_breadcrumbs_unittest.js");
+}
diff --git a/chrome/browser/ash/file_manager/path_util_unittest.cc b/chrome/browser/ash/file_manager/path_util_unittest.cc
index 49e5453d..a2dff7e 100644
--- a/chrome/browser/ash/file_manager/path_util_unittest.cc
+++ b/chrome/browser/ash/file_manager/path_util_unittest.cc
@@ -43,10 +43,10 @@
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
 #include "chrome/test/base/testing_profile_manager.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/cros_disks/cros_disks_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/account_id/account_id.h"
@@ -331,7 +331,7 @@
 
   // Initialize DBUS and running container.
   chromeos::DBusThreadManager::Initialize();
-  chromeos::ChunneldClient::InitializeFake();
+  ash::ChunneldClient::InitializeFake();
   ash::CiceroneClient::InitializeFake();
   ash::ConciergeClient::InitializeFake();
   ash::SeneschalClient::InitializeFake();
@@ -508,7 +508,7 @@
   profile_.reset();
   ash::SeneschalClient::Shutdown();
   ash::ConciergeClient::Shutdown();
-  chromeos::ChunneldClient::Shutdown();
+  ash::ChunneldClient::Shutdown();
   chromeos::DBusThreadManager::Shutdown();
 }
 
diff --git a/chrome/browser/ash/file_manager/trash_unittest_base.cc b/chrome/browser/ash/file_manager/trash_unittest_base.cc
index 02e6ec9b..4044541 100644
--- a/chrome/browser/ash/file_manager/trash_unittest_base.cc
+++ b/chrome/browser/ash/file_manager/trash_unittest_base.cc
@@ -13,8 +13,8 @@
 #include "chrome/browser/ash/file_manager/volume_manager.h"
 #include "chrome/browser/ash/file_manager/volume_manager_factory.h"
 #include "chrome/browser/ash/login/users/fake_chrome_user_manager.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "storage/browser/file_system/external_mount_points.h"
 #include "storage/browser/test/test_file_system_context.h"
@@ -62,7 +62,7 @@
   ASSERT_TRUE(base::CreateDirectory(downloads_dir_));
 
   chromeos::DBusThreadManager::Initialize();
-  chromeos::ChunneldClient::InitializeFake();
+  ash::ChunneldClient::InitializeFake();
   ash::CiceroneClient::InitializeFake();
   ash::ConciergeClient::InitializeFake();
   ash::SeneschalClient::InitializeFake();
@@ -100,7 +100,7 @@
   ash::SeneschalClient::Shutdown();
   ash::ConciergeClient::Shutdown();
   ash::CiceroneClient::Shutdown();
-  chromeos::ChunneldClient::Shutdown();
+  ash::ChunneldClient::Shutdown();
   chromeos::DBusThreadManager::Shutdown();
 }
 
diff --git a/chrome/browser/ash/guest_os/dbus_test_helper.cc b/chrome/browser/ash/guest_os/dbus_test_helper.cc
index 9878161..f9d294cc 100644
--- a/chrome/browser/ash/guest_os/dbus_test_helper.cc
+++ b/chrome/browser/ash/guest_os/dbus_test_helper.cc
@@ -4,10 +4,10 @@
 
 #include "chrome/browser/ash/guest_os/dbus_test_helper.h"
 
+#include "chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
-#include "chromeos/dbus/chunneld/fake_chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/fake_dlcservice_client.h"
 
@@ -76,11 +76,11 @@
 
 FakeChunneldHelper::FakeChunneldHelper(BasicDBusHelper* basic_helper) {
   DCHECK(basic_helper);
-  chromeos::ChunneldClient::InitializeFake();
+  ash::ChunneldClient::InitializeFake();
 }
 
 FakeChunneldHelper::~FakeChunneldHelper() {
-  chromeos::ChunneldClient::Shutdown();
+  ash::ChunneldClient::Shutdown();
 }
 
 FakeVmServicesHelper::FakeVmServicesHelper()
diff --git a/chrome/browser/ash/guest_os/guest_os_share_path_unittest.cc b/chrome/browser/ash/guest_os/guest_os_share_path_unittest.cc
index a24de1e..b55c751 100644
--- a/chrome/browser/ash/guest_os/guest_os_share_path_unittest.cc
+++ b/chrome/browser/ash/guest_os/guest_os_share_path_unittest.cc
@@ -33,6 +33,7 @@
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
@@ -40,7 +41,6 @@
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_service.pb.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/vm_plugin_dispatcher_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/dlcservice_client.h"
 #include "components/account_id/account_id.h"
@@ -226,7 +226,7 @@
             TestingBrowserProcess::GetGlobal())),
         browser_part_(g_browser_process->platform_part()) {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -244,7 +244,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/guest_os/guest_os_stability_monitor.cc b/chrome/browser/ash/guest_os/guest_os_stability_monitor.cc
index 6c39106..ddd168e 100644
--- a/chrome/browser/ash/guest_os/guest_os_stability_monitor.cc
+++ b/chrome/browser/ash/guest_os/guest_os_stability_monitor.cc
@@ -5,7 +5,7 @@
 #include "chrome/browser/ash/guest_os/guest_os_stability_monitor.h"
 
 #include "base/metrics/histogram_functions.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 
 namespace guest_os {
 
@@ -33,7 +33,7 @@
       base::BindOnce(&GuestOsStabilityMonitor::SeneschalStarted,
                      weak_ptr_factory_.GetWeakPtr()));
 
-  auto* chunneld_client = chromeos::ChunneldClient::Get();
+  auto* chunneld_client = ash::ChunneldClient::Get();
   DCHECK(chunneld_client);
   chunneld_client->WaitForServiceToBeAvailable(
       base::BindOnce(&GuestOsStabilityMonitor::ChunneldStarted,
@@ -69,7 +69,7 @@
 void GuestOsStabilityMonitor::ChunneldStarted(bool is_available) {
   DCHECK(is_available);
 
-  auto* chunneld_client = chromeos::ChunneldClient::Get();
+  auto* chunneld_client = ash::ChunneldClient::Get();
   DCHECK(chunneld_client);
   chunneld_observer_.Observe(chunneld_client);
 }
diff --git a/chrome/browser/ash/guest_os/guest_os_stability_monitor.h b/chrome/browser/ash/guest_os/guest_os_stability_monitor.h
index c53ec800..1168ef88 100644
--- a/chrome/browser/ash/guest_os/guest_os_stability_monitor.h
+++ b/chrome/browser/ash/guest_os/guest_os_stability_monitor.h
@@ -7,10 +7,10 @@
 
 #include "base/memory/weak_ptr.h"
 #include "base/scoped_observation.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 
 namespace guest_os {
 
@@ -56,7 +56,7 @@
 class GuestOsStabilityMonitor : ash::ConciergeClient::Observer,
                                 ash::CiceroneClient::Observer,
                                 ash::SeneschalClient::Observer,
-                                chromeos::ChunneldClient::Observer {
+                                ash::ChunneldClient::Observer {
  public:
   explicit GuestOsStabilityMonitor(const std::string& histogram);
   ~GuestOsStabilityMonitor() override;
@@ -83,7 +83,7 @@
   void SeneschalServiceStopped() override;
   void SeneschalServiceStarted() override;
 
-  //  chromeos::ChunneldClient::Observer::
+  //  ash::ChunneldClient::Observer::
   void ChunneldServiceStopped() override;
   void ChunneldServiceStarted() override;
 
@@ -95,8 +95,7 @@
       cicerone_observer_;
   base::ScopedObservation<ash::SeneschalClient, ash::SeneschalClient::Observer>
       seneschal_observer_;
-  base::ScopedObservation<chromeos::ChunneldClient,
-                          chromeos::ChunneldClient::Observer>
+  base::ScopedObservation<ash::ChunneldClient, ash::ChunneldClient::Observer>
       chunneld_observer_;
 
   // Note: This should remain the last member so it'll be destroyed and
diff --git a/chrome/browser/ash/guest_os/guest_os_stability_monitor_unittest.cc b/chrome/browser/ash/guest_os/guest_os_stability_monitor_unittest.cc
index 6b64246e..d7831fb 100644
--- a/chrome/browser/ash/guest_os/guest_os_stability_monitor_unittest.cc
+++ b/chrome/browser/ash/guest_os/guest_os_stability_monitor_unittest.cc
@@ -14,14 +14,14 @@
 #include "chrome/browser/ash/crostini/crostini_test_helper.h"
 #include "chrome/browser/ash/crostini/crostini_util.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/fake_seneschal_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
-#include "chromeos/dbus/chunneld/fake_chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -32,7 +32,7 @@
  public:
   GuestOsStabilityMonitorTest() : task_env_() {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -60,7 +60,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
@@ -129,8 +129,8 @@
 }
 
 TEST_F(GuestOsStabilityMonitorTest, ChunneldFailure) {
-  auto* chunneld_client = static_cast<chromeos::FakeChunneldClient*>(
-      chromeos::ChunneldClient::Get());
+  auto* chunneld_client =
+      static_cast<ash::FakeChunneldClient*>(ash::ChunneldClient::Get());
 
   chunneld_client->NotifyChunneldStopped();
   histogram_tester_.ExpectUniqueSample(crostini::kCrostiniStabilityHistogram,
diff --git a/chrome/browser/ash/login/configuration_based_oobe_browsertest.cc b/chrome/browser/ash/login/configuration_based_oobe_browsertest.cc
index e4d904a9..6d09c75 100644
--- a/chrome/browser/ash/login/configuration_based_oobe_browsertest.cc
+++ b/chrome/browser/ash/login/configuration_based_oobe_browsertest.cc
@@ -26,10 +26,10 @@
 #include "chrome/browser/ui/webui/chromeos/login/network_screen_handler.h"
 #include "chrome/browser/ui/webui/chromeos/login/update_screen_handler.h"
 #include "chrome/browser/ui/webui/chromeos/login/welcome_screen_handler.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/attestation/fake_attestation_client.h"
 #include "chromeos/dbus/constants/dbus_switches.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/test/chromeos_test_utils.h"
 #include "components/language/core/browser/pref_names.h"
diff --git a/chrome/browser/ash/login/demo_mode/demo_setup_browsertest.cc b/chrome/browser/ash/login/demo_mode/demo_setup_browsertest.cc
index 41e39d3e..1727cc6 100644
--- a/chrome/browser/ash/login/demo_mode/demo_setup_browsertest.cc
+++ b/chrome/browser/ash/login/demo_mode/demo_setup_browsertest.cc
@@ -50,8 +50,8 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/grit/generated_resources.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chrome/browser/ash/login/enable_debugging_browsertest.cc b/chrome/browser/ash/login/enable_debugging_browsertest.cc
index f2af2d4..52dd144d 100644
--- a/chrome/browser/ash/login/enable_debugging_browsertest.cc
+++ b/chrome/browser/ash/login/enable_debugging_browsertest.cc
@@ -26,11 +26,11 @@
 #include "chrome/common/chrome_paths.h"
 #include "chrome/common/chrome_switches.h"
 #include "chrome/common/pref_names.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/constants/dbus_switches.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/debug_daemon/fake_debug_daemon_client.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_test.h"
 #include "content/public/test/browser_test_utils.h"
diff --git a/chrome/browser/ash/login/helper.cc b/chrome/browser/ash/login/helper.cc
index 5f3f1fe..bfc7f682 100644
--- a/chrome/browser/ash/login/helper.cc
+++ b/chrome/browser/ash/login/helper.cc
@@ -21,7 +21,7 @@
 #include "chrome/browser/profiles/profile.h"
 #include "chrome/grit/generated_resources.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "chromeos/network/network_state.h"
diff --git a/chrome/browser/ash/login/oobe_interactive_ui_test.cc b/chrome/browser/ash/login/oobe_interactive_ui_test.cc
index b0b614e..ab6c5657 100644
--- a/chrome/browser/ash/login/oobe_interactive_ui_test.cc
+++ b/chrome/browser/ash/login/oobe_interactive_ui_test.cc
@@ -62,8 +62,8 @@
 #include "chrome/browser/ui/webui/chromeos/login/user_creation_screen_handler.h"
 #include "chrome/common/chrome_features.h"
 #include "chromeos/ash/components/assistant/buildflags.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/constants/chromeos_features.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/system/fake_statistics_provider.h"
 #include "content/public/test/browser_test.h"
 #include "content/public/test/browser_test_utils.h"
diff --git a/chrome/browser/ash/login/reset_browsertest.cc b/chrome/browser/ash/login/reset_browsertest.cc
index ac889f0..28bf5d2b 100644
--- a/chrome/browser/ash/login/reset_browsertest.cc
+++ b/chrome/browser/ash/login/reset_browsertest.cc
@@ -32,10 +32,10 @@
 #include "chrome/test/base/mixin_based_in_process_browser_test.h"
 #include "chromeos/ash/components/dbus/session_manager/fake_session_manager_client.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_test.h"
 #include "content/public/test/browser_test_utils.h"
diff --git a/chrome/browser/ash/login/saml/saml_lockscreen_browsertest.cc b/chrome/browser/ash/login/saml/saml_lockscreen_browsertest.cc
index 1bcf04a..381bee26 100644
--- a/chrome/browser/ash/login/saml/saml_lockscreen_browsertest.cc
+++ b/chrome/browser/ash/login/saml/saml_lockscreen_browsertest.cc
@@ -18,11 +18,11 @@
 #include "chrome/browser/chrome_notification_types.h"
 #include "chrome/browser/ui/login/login_handler.h"
 #include "chrome/test/base/mixin_based_in_process_browser_test.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/proxy/proxy_config_handler.h"
 #include "chromeos/dbus/shill/fake_shill_manager_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "components/account_id/account_id.h"
diff --git a/chrome/browser/ash/login/screens/error_screen.cc b/chrome/browser/ash/login/screens/error_screen.cc
index 8f58bd5..fc26a30 100644
--- a/chrome/browser/ash/login/screens/error_screen.cc
+++ b/chrome/browser/ash/login/screens/error_screen.cc
@@ -34,10 +34,10 @@
 #include "chrome/browser/ui/webui/chromeos/login/signin_screen_handler.h"
 #include "chrome/grit/browser_resources.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector_strategy.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "components/session_manager/core/session_manager.h"
 #include "components/web_modal/web_contents_modal_dialog_manager.h"
diff --git a/chrome/browser/ash/login/screens/error_screen.h b/chrome/browser/ash/login/screens/error_screen.h
index 45c0eb7..68c4807 100644
--- a/chrome/browser/ash/login/screens/error_screen.h
+++ b/chrome/browser/ash/login/screens/error_screen.h
@@ -19,7 +19,7 @@
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chrome/browser/ui/webui/chromeos/login/error_screen_handler.h"
 #include "chrome/browser/ui/webui/chromeos/login/network_state_informer.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "components/web_modal/web_contents_modal_dialog_manager_delegate.h"
 
 namespace ash {
diff --git a/chrome/browser/ash/login/screens/reset_screen.cc b/chrome/browser/ash/login/screens/reset_screen.cc
index 69e576d..345a21c0 100644
--- a/chrome/browser/ash/login/screens/reset_screen.cc
+++ b/chrome/browser/ash/login/screens/reset_screen.cc
@@ -29,8 +29,8 @@
 #include "chrome/browser/ui/webui/chromeos/login/reset_screen_handler.h"
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_registry_simple.h"
 #include "components/prefs/pref_service.h"
 #include "third_party/cros_system_api/dbus/service_constants.h"
diff --git a/chrome/browser/ash/login/screens/reset_screen.h b/chrome/browser/ash/login/screens/reset_screen.h
index f4f37da..ec8fdf1 100644
--- a/chrome/browser/ash/login/screens/reset_screen.h
+++ b/chrome/browser/ash/login/screens/reset_screen.h
@@ -19,7 +19,7 @@
 #include "third_party/abseil-cpp/absl/types/optional.h"
 // TODO(https://crbug.com/1164001): move to forward declaration.
 #include "chrome/browser/ui/webui/chromeos/login/reset_screen_handler.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 class PrefRegistrySimple;
 
diff --git a/chrome/browser/ash/login/screens/update_required_screen.cc b/chrome/browser/ash/login/screens/update_required_screen.cc
index d5d2df8..02f2767 100644
--- a/chrome/browser/ash/login/screens/update_required_screen.cc
+++ b/chrome/browser/ash/login/screens/update_required_screen.cc
@@ -107,7 +107,7 @@
 }
 
 void UpdateRequiredScreen::OnGetEolInfo(
-    const chromeos::UpdateEngineClient::EolInfo& info) {
+    const UpdateEngineClient::EolInfo& info) {
   //  TODO(crbug.com/1020616) : Handle if the device is left on this screen
   //  for long enough to reach Eol.
   if (switches::IsAueReachedForUpdateRequiredForTest() ||
diff --git a/chrome/browser/ash/login/screens/update_required_screen.h b/chrome/browser/ash/login/screens/update_required_screen.h
index efc60cbb..a3b1463 100644
--- a/chrome/browser/ash/login/screens/update_required_screen.h
+++ b/chrome/browser/ash/login/screens/update_required_screen.h
@@ -109,7 +109,7 @@
   // The user requested an attempt to connect to the network should be made.
   void OnConnectRequested();
 
-  void OnGetEolInfo(const chromeos::UpdateEngineClient::EolInfo& info);
+  void OnGetEolInfo(const UpdateEngineClient::EolInfo& info);
 
   void OnErrorScreenHidden();
 
diff --git a/chrome/browser/ash/login/screens/update_required_screen_browsertest.cc b/chrome/browser/ash/login/screens/update_required_screen_browsertest.cc
index 8e8ef6f9..6eaf72b 100644
--- a/chrome/browser/ash/login/screens/update_required_screen_browsertest.cc
+++ b/chrome/browser/ash/login/screens/update_required_screen_browsertest.cc
@@ -32,10 +32,10 @@
 #include "chrome/browser/ui/webui/chromeos/login/update_required_screen_handler.h"
 #include "chrome/grit/chromium_strings.h"
 #include "chrome/grit/generated_resources.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/constants/dbus_switches.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/user_manager/user_manager.h"
 #include "content/public/test/browser_test.h"
 #include "dbus/object_path.h"
diff --git a/chrome/browser/ash/login/screens/update_required_screen_unittest.cc b/chrome/browser/ash/login/screens/update_required_screen_unittest.cc
index 34ca3766..638fe65 100644
--- a/chrome/browser/ash/login/screens/update_required_screen_unittest.cc
+++ b/chrome/browser/ash/login/screens/update_required_screen_unittest.cc
@@ -20,12 +20,12 @@
 #include "chrome/browser/ui/webui/chromeos/login/fake_update_required_screen_handler.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/portal_detector/mock_network_portal_detector.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/chrome/browser/ash/login/screens/update_screen_browsertest.cc b/chrome/browser/ash/login/screens/update_screen_browsertest.cc
index 96b47b0..8897b665 100644
--- a/chrome/browser/ash/login/screens/update_screen_browsertest.cc
+++ b/chrome/browser/ash/login/screens/update_screen_browsertest.cc
@@ -33,10 +33,10 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/grit/chromium_strings.h"
 #include "chrome/grit/generated_resources.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "content/public/test/browser_test.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
@@ -482,7 +482,7 @@
 
 IN_PROC_BROWSER_TEST_P(UpdateScreenTest, TestErrorIssuingUpdateCheck) {
   update_engine_client()->set_update_check_result(
-      chromeos::UpdateEngineClient::UPDATE_RESULT_FAILED);
+      UpdateEngineClient::UPDATE_RESULT_FAILED);
   ShowUpdateScreen();
 
   if (GetParam().is_eu && features::IsConsumerAutoUpdateToggleAllowed()) {
diff --git a/chrome/browser/ash/login/screens/update_screen_unittest.cc b/chrome/browser/ash/login/screens/update_screen_unittest.cc
index ca216a3..0c87792 100644
--- a/chrome/browser/ash/login/screens/update_screen_unittest.cc
+++ b/chrome/browser/ash/login/screens/update_screen_unittest.cc
@@ -15,13 +15,13 @@
 #include "chrome/browser/ash/login/wizard_context.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/portal_detector/mock_network_portal_detector.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/chrome/browser/ash/login/session/user_session_initializer.cc b/chrome/browser/ash/login/session/user_session_initializer.cc
index 0186ffee..b0ee90806 100644
--- a/chrome/browser/ash/login/session/user_session_initializer.cc
+++ b/chrome/browser/ash/login/session/user_session_initializer.cc
@@ -46,7 +46,7 @@
 #include "chrome/browser/ui/webui/settings/chromeos/peripheral_data_access_handler.h"
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/dbus/pciguard/pciguard_client.h"
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/browser/browser_task_traits.h"
 #include "content/public/browser/browser_thread.h"
diff --git a/chrome/browser/ash/login/session/user_session_manager.cc b/chrome/browser/ash/login/session/user_session_manager.cc
index 46355fe1..d7693b0 100644
--- a/chrome/browser/ash/login/session/user_session_manager.cc
+++ b/chrome/browser/ash/login/session/user_session_manager.cc
@@ -563,6 +563,12 @@
   content::GetNetworkConnectionTrackerFromUIThread(
       base::BindOnce(&UserSessionManager::SetNetworkConnectionTracker,
                      weak_factory_.GetWeakPtr()));
+  // TODO(crbug/1341307): Remove the log after the feature settles in Stable.
+  LOG(WARNING) << "UseAuthsessionAuthentication experiment is "
+               << (base::FeatureList::IsEnabled(
+                       ash::features::kUseAuthsessionAuthentication)
+                       ? "enabled"
+                       : "disabled");
 }
 
 UserSessionManager::~UserSessionManager() {
diff --git a/chrome/browser/ash/login/test/oobe_base_test.cc b/chrome/browser/ash/login/test/oobe_base_test.cc
index bd4a639..646cdaa1 100644
--- a/chrome/browser/ash/login/test/oobe_base_test.cc
+++ b/chrome/browser/ash/login/test/oobe_base_test.cc
@@ -34,9 +34,9 @@
 #include "chrome/browser/ui/webui/chromeos/login/user_creation_screen_handler.h"
 #include "chrome/browser/ui/webui/signin/signin_utils.h"
 #include "chrome/common/chrome_switches.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/shill/fake_shill_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/policy/core/common/policy_switches.h"
 #include "components/user_manager/fake_user_manager.h"
 #include "content/public/common/content_switches.h"
diff --git a/chrome/browser/ash/login/test/oobe_base_test.h b/chrome/browser/ash/login/test/oobe_base_test.h
index 7f2b709b..bb4cfec 100644
--- a/chrome/browser/ash/login/test/oobe_base_test.h
+++ b/chrome/browser/ash/login/test/oobe_base_test.h
@@ -12,14 +12,13 @@
 #include "chrome/browser/ash/login/test/embedded_test_server_setup_mixin.h"
 #include "chrome/browser/ash/login/test/js_checker.h"
 #include "chrome/test/base/mixin_based_in_process_browser_test.h"
-// TODO(https://crbug.com/1164001): move to forward declaration.
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 
 namespace content {
 class WebUI;
 }  // namespace content
 
 namespace ash {
+class FakeUpdateEngineClient;
 class LoginOrLockScreenVisibleWaiter;
 
 // Base class for OOBE, login, SAML and Kiosk tests.
diff --git a/chrome/browser/ash/login/version_updater/update_time_estimator.h b/chrome/browser/ash/login/version_updater/update_time_estimator.h
index 8816bf09..33c49941 100644
--- a/chrome/browser/ash/login/version_updater/update_time_estimator.h
+++ b/chrome/browser/ash/login/version_updater/update_time_estimator.h
@@ -6,7 +6,7 @@
 #define CHROME_BROWSER_ASH_LOGIN_VERSION_UPDATER_UPDATE_TIME_ESTIMATOR_H_
 
 #include "base/time/time.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 namespace base {
 class TickClock;
diff --git a/chrome/browser/ash/login/version_updater/version_updater.cc b/chrome/browser/ash/login/version_updater/version_updater.cc
index c6b3916..cf5ef60 100644
--- a/chrome/browser/ash/login/version_updater/version_updater.cc
+++ b/chrome/browser/ash/login/version_updater/version_updater.cc
@@ -17,7 +17,7 @@
 #include "chrome/browser/ash/login/version_updater/update_time_estimator.h"
 #include "chrome/grit/chromium_strings.h"
 #include "chrome/grit/generated_resources.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_state.h"
 #include "ui/base/l10n/l10n_util.h"
 
diff --git a/chrome/browser/ash/login/version_updater/version_updater.h b/chrome/browser/ash/login/version_updater/version_updater.h
index cca3d9c..1a1ce66 100644
--- a/chrome/browser/ash/login/version_updater/version_updater.h
+++ b/chrome/browser/ash/login/version_updater/version_updater.h
@@ -13,8 +13,8 @@
 #include "base/timer/timer.h"
 #include "chrome/browser/ash/login/screens/network_error.h"
 #include "chrome/browser/ash/login/version_updater/update_time_estimator.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 // TODO(https://crbug.com/1164001): move to forward declaration when migrated.
 #include "chromeos/network/network_state.h"
 
diff --git a/chrome/browser/ash/login/version_updater/version_updater_unittest.cc b/chrome/browser/ash/login/version_updater/version_updater_unittest.cc
index eff4493..240f9631 100644
--- a/chrome/browser/ash/login/version_updater/version_updater_unittest.cc
+++ b/chrome/browser/ash/login/version_updater/version_updater_unittest.cc
@@ -16,12 +16,12 @@
 #include "chrome/browser/ash/net/network_portal_detector_test_impl.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/portal_detector/mock_network_portal_detector.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gtest/include/gtest/gtest.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/chrome/browser/ash/login/webview_login_browsertest.cc b/chrome/browser/ash/login/webview_login_browsertest.cc
index 666f0f90..3849b70d 100644
--- a/chrome/browser/ash/login/webview_login_browsertest.cc
+++ b/chrome/browser/ash/login/webview_login_browsertest.cc
@@ -2035,8 +2035,7 @@
       &mixin_host_, DeviceStateMixin::State::OOBE_COMPLETED_CLOUD_ENROLLED};
 };
 
-// Disabled fails on msan and also non-msan bots: https://crbug.com/849128.
-IN_PROC_BROWSER_TEST_F(WebviewProxyAuthLoginTest, DISABLED_ProxyAuthTransfer) {
+IN_PROC_BROWSER_TEST_F(WebviewProxyAuthLoginTest, ProxyAuthTransfer) {
   WaitForSigninScreen();
 
   LoginHandler* login_handler = WaitForAuthRequested();
@@ -2071,7 +2070,7 @@
   // This will re-load gaia, rotating the StoragePartition. The new
   // StoragePartition must also have the proxy auth details.
   test::OobeJS().ClickOnPath(kBackButton);
-  WaitForGaiaPageBackButtonUpdate();
+  WaitForGaiaPageLoadAndPropertyUpdate();
   // Expect that we got back to the identifier page, as there are no known users
   // so the sign-in screen will not display user pods.
   ExpectIdentifierPage();
diff --git a/chrome/browser/ash/login/wizard_controller.cc b/chrome/browser/ash/login/wizard_controller.cc
index 4d09eb3..418d653b 100644
--- a/chrome/browser/ash/login/wizard_controller.cc
+++ b/chrome/browser/ash/login/wizard_controller.cc
@@ -188,8 +188,8 @@
 #include "chrome/common/chrome_constants.h"
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "chromeos/network/network_state.h"
diff --git a/chrome/browser/ash/mobile/mobile_activator.cc b/chrome/browser/ash/mobile/mobile_activator.cc
index df449ad..cd167100 100644
--- a/chrome/browser/ash/mobile/mobile_activator.cc
+++ b/chrome/browser/ash/mobile/mobile_activator.cc
@@ -23,10 +23,10 @@
 #include "base/timer/timer.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/device_state.h"
-#include "chromeos/network/network_activation_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connect.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "content/public/browser/browser_task_traits.h"
diff --git a/chrome/browser/ash/mobile/mobile_activator_unittest.cc b/chrome/browser/ash/mobile/mobile_activator_unittest.cc
index d7808a3..bb417eb 100644
--- a/chrome/browser/ash/mobile/mobile_activator_unittest.cc
+++ b/chrome/browser/ash/mobile/mobile_activator_unittest.cc
@@ -9,8 +9,8 @@
 
 #include "base/test/task_environment.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "content/public/browser/browser_thread.h"
diff --git a/chrome/browser/ash/net/secure_dns_manager.cc b/chrome/browser/ash/net/secure_dns_manager.cc
index f531e5f..419fd27 100644
--- a/chrome/browser/ash/net/secure_dns_manager.cc
+++ b/chrome/browser/ash/net/secure_dns_manager.cc
@@ -17,7 +17,7 @@
 #include "chrome/browser/net/secure_dns_config.h"
 #include "chrome/browser/net/secure_dns_util.h"
 #include "chrome/common/pref_names.h"
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "components/country_codes/country_codes.h"
 #include "net/dns/public/doh_provider_entry.h"
diff --git a/chrome/browser/ash/net/traffic_counters_handler_unittest.cc b/chrome/browser/ash/net/traffic_counters_handler_unittest.cc
index e036f9a..15b7c1c 100644
--- a/chrome/browser/ash/net/traffic_counters_handler_unittest.cc
+++ b/chrome/browser/ash/net/traffic_counters_handler_unittest.cc
@@ -10,9 +10,9 @@
 #include "base/time/time.h"
 #include "chrome/browser/ash/net/traffic_counters_handler.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "chromeos/services/network_config/cros_network_config.h"
 #include "chromeos/services/network_config/in_process_instance.h"
diff --git a/chrome/browser/ash/notifications/update_required_notification_unittest.cc b/chrome/browser/ash/notifications/update_required_notification_unittest.cc
index 60ca00a3..b2cfa1c 100644
--- a/chrome/browser/ash/notifications/update_required_notification_unittest.cc
+++ b/chrome/browser/ash/notifications/update_required_notification_unittest.cc
@@ -23,10 +23,10 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gmock/include/gmock/gmock.h"
@@ -91,9 +91,7 @@
     return notification_service_.get();
   }
 
-  chromeos::FakeUpdateEngineClient* update_engine() {
-    return fake_update_engine_client_;
-  }
+  FakeUpdateEngineClient* update_engine() { return fake_update_engine_client_; }
 
   chromeos::NetworkHandlerTestHelper* network_handler_test_helper() {
     return network_handler_test_helper_.get();
@@ -110,7 +108,7 @@
   ScopedTestingCrosSettings scoped_testing_cros_settings_;
   std::unique_ptr<NotificationDisplayServiceTester> notification_service_;
   ScopedStubInstallAttributes scoped_stub_install_attributes_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;
+  FakeUpdateEngineClient* fake_update_engine_client_;
   std::unique_ptr<base::Version> current_version_;
   std::unique_ptr<policy::MinimumVersionPolicyHandler>
       minimum_version_policy_handler_;
diff --git a/chrome/browser/ash/plugin_vm/plugin_vm_files_unittest.cc b/chrome/browser/ash/plugin_vm/plugin_vm_files_unittest.cc
index ac438f9..30e06cf9 100644
--- a/chrome/browser/ash/plugin_vm/plugin_vm_files_unittest.cc
+++ b/chrome/browser/ash/plugin_vm/plugin_vm_files_unittest.cc
@@ -22,12 +22,12 @@
 #include "chrome/browser/ui/ash/shelf/chrome_shelf_controller.h"
 #include "chrome/browser/ui/ash/shelf/shelf_controller_helper.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/vm_plugin_dispatcher_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/vm_applications/apps.pb.h"
 #include "content/public/test/browser_task_environment.h"
@@ -103,7 +103,7 @@
       ash::CiceroneClient::InitializeFake();
       ash::ConciergeClient::InitializeFake();
       ash::SeneschalClient::InitializeFake();
-      chromeos::ChunneldClient::InitializeFake();
+      ash::ChunneldClient::InitializeFake();
       ash::VmPluginDispatcherClient::InitializeFake();
     }
     ~ScopedDBusThreadManager() {
@@ -111,7 +111,7 @@
       ash::SeneschalClient::Shutdown();
       ash::ConciergeClient::Shutdown();
       ash::CiceroneClient::Shutdown();
-      chromeos::ChunneldClient::Shutdown();
+      ash::ChunneldClient::Shutdown();
       chromeos::DBusThreadManager::Shutdown();
     }
   } dbus_thread_manager_;
diff --git a/chrome/browser/ash/plugin_vm/plugin_vm_manager_impl_unittest.cc b/chrome/browser/ash/plugin_vm/plugin_vm_manager_impl_unittest.cc
index 5b5841d2..87e52c7 100644
--- a/chrome/browser/ash/plugin_vm/plugin_vm_manager_impl_unittest.cc
+++ b/chrome/browser/ash/plugin_vm/plugin_vm_manager_impl_unittest.cc
@@ -23,6 +23,7 @@
 #include "chrome/browser/ui/ash/shelf/shelf_controller_helper.h"
 #include "chrome/browser/ui/ash/shelf/shelf_spinner_controller.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
@@ -30,7 +31,6 @@
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/fake_vm_plugin_dispatcher_client.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/vm_plugin_dispatcher_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlcservice/fake_dlcservice_client.h"
 #include "components/prefs/pref_service.h"
@@ -51,7 +51,7 @@
  public:
   PluginVmManagerImplTest() {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -97,7 +97,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/policy/core/browser_policy_connector_ash.cc b/chrome/browser/ash/policy/core/browser_policy_connector_ash.cc
index ea16ab4..11507ee 100644
--- a/chrome/browser/ash/policy/core/browser_policy_connector_ash.cc
+++ b/chrome/browser/ash/policy/core/browser_policy_connector_ash.cc
@@ -74,9 +74,9 @@
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
 #include "chromeos/ash/components/dbus/upstart/upstart_client.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer_impl.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/system/statistics_provider.h"
 #include "components/policy/core/common/cloud/cloud_policy_client.h"
diff --git a/chrome/browser/ash/policy/core/device_policy_decoder.cc b/chrome/browser/ash/policy/core/device_policy_decoder.cc
index 8b0d676..f533d41 100644
--- a/chrome/browser/ash/policy/core/device_policy_decoder.cc
+++ b/chrome/browser/ash/policy/core/device_policy_decoder.cc
@@ -21,8 +21,8 @@
 #include "chrome/browser/ash/policy/off_hours/off_hours_proto_parser.h"
 #include "chrome/browser/ash/tpm_firmware_update.h"
 #include "chrome/browser/policy/chrome_browser_policy_connector.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/policy/core/common/chrome_schema.h"
 #include "components/policy/core/common/external_data_fetcher.h"
 #include "components/policy/core/common/external_data_manager.h"
diff --git a/chrome/browser/ash/policy/dlp/dlp_files_controller_unittest.cc b/chrome/browser/ash/policy/dlp/dlp_files_controller_unittest.cc
index aeca94b..4a02afb 100644
--- a/chrome/browser/ash/policy/dlp/dlp_files_controller_unittest.cc
+++ b/chrome/browser/ash/policy/dlp/dlp_files_controller_unittest.cc
@@ -29,10 +29,10 @@
 #include "chrome/browser/chromeos/policy/dlp/mock_dlp_rules_manager.h"
 #include "chrome/browser/profiles/profile.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/dlp/dlp_client.h"
 #include "chromeos/dbus/dlp/dlp_service.pb.h"
@@ -406,7 +406,7 @@
     crostini_features.set_enabled(true);
 
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -442,7 +442,7 @@
     DlpFilesControllerTest::TearDown();
 
     chromeos::DBusThreadManager::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     ash::CiceroneClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::SeneschalClient::Shutdown();
diff --git a/chrome/browser/ash/policy/handlers/lock_to_single_user_manager_unittest.cc b/chrome/browser/ash/policy/handlers/lock_to_single_user_manager_unittest.cc
index dbe4295..f444ff3 100644
--- a/chrome/browser/ash/policy/handlers/lock_to_single_user_manager_unittest.cc
+++ b/chrome/browser/ash/policy/handlers/lock_to_single_user_manager_unittest.cc
@@ -23,13 +23,13 @@
 #include "chrome/browser/ui/app_list/arc/arc_app_test.h"
 #include "chrome/test/base/browser_with_test_window_test.h"
 #include "chromeos/ash/components/dbus/anomaly_detector/anomaly_detector_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/fake_cryptohome_misc_client.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/vm_plugin_dispatcher_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/account_id/account_id.h"
 #include "components/policy/proto/chrome_device_policy.pb.h"
@@ -52,7 +52,7 @@
     // This is required before Concierge tests start calling
     // DBusThreadManager::Get() for GuestOsStabilityMonitor.
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -110,7 +110,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.cc b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.cc
index 023b182..588a3023 100644
--- a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.cc
+++ b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.cc
@@ -30,7 +30,7 @@
 #include "chrome/browser/upgrade_detector/build_state.h"
 #include "chrome/browser/upgrade_detector/upgrade_detector.h"
 #include "chrome/common/pref_names.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "components/prefs/pref_registry_simple.h"
 #include "components/prefs/pref_service.h"
@@ -40,7 +40,7 @@
 
 namespace {
 
-using chromeos::UpdateEngineClient;
+using ::ash::UpdateEngineClient;
 using MinimumVersionRequirement =
     MinimumVersionPolicyHandler::MinimumVersionRequirement;
 
@@ -333,7 +333,7 @@
 }
 
 void MinimumVersionPolicyHandler::OnFetchEolInfo(
-    const chromeos::UpdateEngineClient::EolInfo info) {
+    const UpdateEngineClient::EolInfo info) {
   if (!ash::switches::IsAueReachedForUpdateRequiredForTest() &&
       (info.eol_date.is_null() || info.eol_date > update_required_time_)) {
     // End of life is not reached. Start update with |warning_time_|.
@@ -588,8 +588,7 @@
 
 void MinimumVersionPolicyHandler::UpdateOverMeteredPermssionGranted() {
   VLOG(1) << "Permission for update over metered network granted.";
-  chromeos::UpdateEngineClient* const update_engine_client =
-      UpdateEngineClient::Get();
+  UpdateEngineClient* const update_engine_client = UpdateEngineClient::Get();
   if (!update_engine_client->HasObserver(this))
     update_engine_client->AddObserver(this);
   update_engine_client->RequestUpdateCheck(
@@ -598,9 +597,9 @@
 }
 
 void MinimumVersionPolicyHandler::OnUpdateCheckStarted(
-    chromeos::UpdateEngineClient::UpdateCheckResult result) {
+    UpdateEngineClient::UpdateCheckResult result) {
   VLOG(1) << "Update check started.";
-  if (result != chromeos::UpdateEngineClient::UPDATE_RESULT_SUCCESS)
+  if (result != UpdateEngineClient::UPDATE_RESULT_SUCCESS)
     UpdateEngineClient::Get()->RemoveObserver(this);
 }
 
diff --git a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.h b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.h
index b9c7bf7..18fd9a8e 100644
--- a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.h
+++ b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler.h
@@ -15,7 +15,7 @@
 #include "base/version.h"
 #include "chrome/browser/ash/settings/cros_settings.h"
 #include "chrome/browser/upgrade_detector/build_state_observer.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 
@@ -43,7 +43,7 @@
 class MinimumVersionPolicyHandler
     : public BuildStateObserver,
       public chromeos::NetworkStateHandlerObserver,
-      public chromeos::UpdateEngineClient::Observer {
+      public ash::UpdateEngineClient::Observer {
  public:
   static const char kRequirements[];
   static const char kChromeOsVersion[];
@@ -219,7 +219,7 @@
   void FetchEolInfo();
 
   // Callback after fetching end-of-life info from the update_engine_client.
-  void OnFetchEolInfo(chromeos::UpdateEngineClient::EolInfo info);
+  void OnFetchEolInfo(ash::UpdateEngineClient::EolInfo info);
 
   // Called when the warning time to apply updates has expired. If the user on
   // the login screen, the update required screen is shown else the current user
@@ -250,8 +250,7 @@
   void UpdateOverMeteredPermssionGranted();
 
   // Tells whether starting an update check succeeded or not.
-  void OnUpdateCheckStarted(
-      chromeos::UpdateEngineClient::UpdateCheckResult result);
+  void OnUpdateCheckStarted(ash::UpdateEngineClient::UpdateCheckResult result);
 
   // Callback from UpdateEngineClient::SetUpdateOverCellularOneTimePermission().
   void OnSetUpdateOverCellularOneTimePermission(bool success);
diff --git a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_browsertest.cc b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_browsertest.cc
index 31de0c7..64f81d2 100644
--- a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_browsertest.cc
+++ b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_browsertest.cc
@@ -53,10 +53,10 @@
 #include "chrome/browser/ui/webui/chromeos/login/update_required_screen_handler.h"
 #include "chrome/browser/upgrade_detector/upgrade_detector.h"
 #include "chrome/common/pref_names.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/constants/dbus_switches.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/policy/proto/chrome_device_policy.pb.h"
 #include "components/prefs/pref_service.h"
 #include "components/user_manager/user_type.h"
@@ -113,7 +113,7 @@
   void SetUpInProcessBrowserTestFixture() override {
     LoginManagerTest::SetUpInProcessBrowserTestFixture();
     fake_update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+        ash::UpdateEngineClient::InitializeFakeForTest();
     const std::string lsb_release =
         base::StringPrintf("CHROMEOS_RELEASE_VERSION=%s", kCurrentVersion);
     version_info_.emplace(lsb_release, base::Time::Now());
@@ -132,7 +132,7 @@
 
   DevicePolicyCrosTestHelper helper_;
   base::test::ScopedFeatureList feature_list_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
   ash::DeviceStateMixin device_state_{
       &mixin_host_,
       ash::DeviceStateMixin::State::OOBE_COMPLETED_CLOUD_ENROLLED};
diff --git a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_unittest.cc b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_unittest.cc
index f39b2ec..f54aedc0 100644
--- a/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_unittest.cc
+++ b/chrome/browser/ash/policy/handlers/minimum_version_policy_handler_unittest.cc
@@ -21,11 +21,11 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gmock/include/gmock/gmock.h"
@@ -96,7 +96,7 @@
   base::test::ScopedFeatureList feature_list_;
   ash::ScopedTestingCrosSettings scoped_testing_cros_settings_;
   ash::ScopedStubInstallAttributes scoped_stub_install_attributes_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;
   std::unique_ptr<chromeos::NetworkHandlerTestHelper>
       network_handler_test_helper_;
   std::unique_ptr<base::Version> current_version_;
@@ -110,8 +110,7 @@
 
 void MinimumVersionPolicyHandlerTest::SetUp() {
   chromeos::DBusThreadManager::Initialize();
-  fake_update_engine_client_ =
-      chromeos::UpdateEngineClient::InitializeFakeForTest();
+  fake_update_engine_client_ = ash::UpdateEngineClient::InitializeFakeForTest();
   network_handler_test_helper_ =
       std::make_unique<chromeos::NetworkHandlerTestHelper>();
 
@@ -132,7 +131,7 @@
 void MinimumVersionPolicyHandlerTest::TearDown() {
   minimum_version_policy_handler_.reset();
   network_handler_test_helper_.reset();
-  chromeos::UpdateEngineClient::Shutdown();
+  ash::UpdateEngineClient::Shutdown();
   chromeos::DBusThreadManager::Shutdown();
 }
 
diff --git a/chrome/browser/ash/policy/networking/network_policy_application_browsertest.cc b/chrome/browser/ash/policy/networking/network_policy_application_browsertest.cc
index 50e0d94f..8da6c0d 100644
--- a/chrome/browser/ash/policy/networking/network_policy_application_browsertest.cc
+++ b/chrome/browser/ash/policy/networking/network_policy_application_browsertest.cc
@@ -19,12 +19,12 @@
 #include "chrome/browser/ash/profiles/profile_helper.h"
 #include "chrome/browser/ash/scoped_test_system_nss_key_slot_mixin.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_property_changed_observer.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_policy_observer.h"
 #include "chromeos/system/fake_statistics_provider.h"
diff --git a/chrome/browser/ash/policy/networking/policy_certs_browsertest.cc b/chrome/browser/ash/policy/networking/policy_certs_browsertest.cc
index ef24187..956a719 100644
--- a/chrome/browser/ash/policy/networking/policy_certs_browsertest.cc
+++ b/chrome/browser/ash/policy/networking/policy_certs_browsertest.cc
@@ -48,10 +48,10 @@
 #include "chrome/browser/ui/webui/chromeos/login/signin_screen_handler.h"
 #include "chrome/common/chrome_paths.h"
 #include "chrome/test/base/in_process_browser_test.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer_impl.h"
 #include "chromeos/components/onc/onc_test_utils.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/policy_certificate_provider.h"
 #include "chromeos/test/chromeos_test_utils.h"
 #include "components/onc/onc_constants.h"
diff --git a/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.cc b/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.cc
index daa05bb..05ec89e 100644
--- a/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.cc
+++ b/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.cc
@@ -7,7 +7,7 @@
 #include <utility>
 
 #include "chrome/browser/browser_process.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "components/device_event_log/device_event_log.h"
 #include "components/policy/core/common/policy_service.h"
@@ -21,7 +21,7 @@
           update_checker_internal::
               kMaxOsAndPoliciesUpdateCheckerRetryIterations,
           update_checker_internal::kOsAndPoliciesUpdateCheckerRetryTime),
-      update_engine_client_(chromeos::UpdateEngineClient::Get()) {}
+      update_engine_client_(ash::UpdateEngineClient::Get()) {}
 
 OsAndPoliciesUpdateChecker::~OsAndPoliciesUpdateChecker() {
   // Called to remove any observers.
@@ -191,17 +191,17 @@
 }
 
 void OsAndPoliciesUpdateChecker::OnUpdateCheckStarted(
-    chromeos::UpdateEngineClient::UpdateCheckResult result) {
+    ash::UpdateEngineClient::UpdateCheckResult result) {
   switch (result) {
-    case chromeos::UpdateEngineClient::UPDATE_RESULT_SUCCESS:
+    case ash::UpdateEngineClient::UPDATE_RESULT_SUCCESS:
       // Nothing to do if the update check started successfully.
       break;
-    case chromeos::UpdateEngineClient::UPDATE_RESULT_FAILED:
+    case ash::UpdateEngineClient::UPDATE_RESULT_FAILED:
       update_check_task_executor_.ScheduleRetry(
           base::BindOnce(&OsAndPoliciesUpdateChecker::StartUpdateCheck,
                          base::Unretained(this)));
       break;
-    case chromeos::UpdateEngineClient::UPDATE_RESULT_NOTIMPLEMENTED:
+    case ash::UpdateEngineClient::UPDATE_RESULT_NOTIMPLEMENTED:
       // No point retrying if the operation is not implemented. Refresh policies
       // since the update check is done.
       LOG(ERROR) << "Update check failed: Operation not implemented";
diff --git a/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.h b/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.h
index 46cc01c..6b847d2 100644
--- a/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.h
+++ b/chrome/browser/ash/policy/scheduled_task_handler/os_and_policies_update_checker.h
@@ -10,7 +10,7 @@
 #include "base/time/time.h"
 #include "base/timer/timer.h"
 #include "chrome/browser/ash/policy/scheduled_task_handler/task_executor_with_retries.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 
@@ -38,7 +38,7 @@
 // This class is used by the scheduled update check policy to perform the actual
 // device update check.
 class OsAndPoliciesUpdateChecker
-    : public chromeos::UpdateEngineClient::Observer,
+    : public ash::UpdateEngineClient::Observer,
       public chromeos::NetworkStateHandlerObserver {
  public:
   explicit OsAndPoliciesUpdateChecker(
@@ -92,8 +92,7 @@
   void UpdateStatusChanged(const update_engine::StatusResult& status) override;
 
   // Tells whether starting an update check succeeded or not.
-  void OnUpdateCheckStarted(
-      chromeos::UpdateEngineClient::UpdateCheckResult result);
+  void OnUpdateCheckStarted(ash::UpdateEngineClient::UpdateCheckResult result);
 
   // Refreshes policies. |update_check_result| represents the status of the
   // previous stage i.e. an OS update check and download.
@@ -134,7 +133,7 @@
   base::OneShotTimer timeout_timer_;
 
   // Not owned.
-  chromeos::UpdateEngineClient* const update_engine_client_;
+  ash::UpdateEngineClient* const update_engine_client_;
 
   base::WeakPtrFactory<OsAndPoliciesUpdateChecker> weak_factory_{this};
 };
diff --git a/chrome/browser/ash/policy/scheduled_task_handler/test/device_scheduled_update_checker_unittest.cc b/chrome/browser/ash/policy/scheduled_task_handler/test/device_scheduled_update_checker_unittest.cc
index 37c9fc3..731e57e 100644
--- a/chrome/browser/ash/policy/scheduled_task_handler/test/device_scheduled_update_checker_unittest.cc
+++ b/chrome/browser/ash/policy/scheduled_task_handler/test/device_scheduled_update_checker_unittest.cc
@@ -34,13 +34,13 @@
 #include "chrome/browser/ash/settings/stub_cros_settings_provider.h"
 #include "chrome/common/chrome_features.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
 #include "chromeos/dbus/shill/shill_clients.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/policy/core/common/policy_service.h"
@@ -126,7 +126,7 @@
                             base::Unretained(&wake_lock_provider_)));
     chromeos::DBusThreadManager::Initialize();
     fake_update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+        ash::UpdateEngineClient::InitializeFakeForTest();
     chromeos::PowerManagerClient::InitializeFake();
     chromeos::FakePowerManagerClient::Get()->set_tick_clock(
         task_environment_.GetMockTickClock());
@@ -154,7 +154,7 @@
     device_scheduled_update_checker_.reset();
     network_state_test_helper_.reset();
     chromeos::PowerManagerClient::Shutdown();
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
     ScopedWakeLock::OverrideWakeLockProviderBinderForTesting(
         base::NullCallback());
@@ -357,7 +357,7 @@
   std::unique_ptr<DeviceScheduledUpdateCheckerForTest>
       device_scheduled_update_checker_;
   ash::ScopedTestingCrosSettings cros_settings_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;
   std::unique_ptr<chromeos::NetworkStateTestHelper> network_state_test_helper_;
   device::TestWakeLockProvider wake_lock_provider_;
 
diff --git a/chrome/browser/ash/policy/status_collector/child_status_collector_browsertest.cc b/chrome/browser/ash/policy/status_collector/child_status_collector_browsertest.cc
index 9648ac5..0c5451fa 100644
--- a/chrome/browser/ash/policy/status_collector/child_status_collector_browsertest.cc
+++ b/chrome/browser/ash/policy/status_collector/child_status_collector_browsertest.cc
@@ -46,11 +46,11 @@
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
 #include "chromeos/dbus/power_manager/idle.pb.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/login/login_state/login_state.h"
 #include "chromeos/system/fake_statistics_provider.h"
 #include "components/account_id/account_id.h"
@@ -201,7 +201,7 @@
 
     chromeos::DBusThreadManager::Initialize();
     // Use FakeUpdateEngineClient.
-    chromeos::UpdateEngineClient::InitializeFakeForTest();
+    ash::UpdateEngineClient::InitializeFakeForTest();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -219,7 +219,7 @@
     testing_profile_.reset();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr);
 
     // Finish pending tasks.
diff --git a/chrome/browser/ash/policy/status_collector/device_status_collector.cc b/chrome/browser/ash/policy/status_collector/device_status_collector.cc
index e3b92561..1686f43a7 100644
--- a/chrome/browser/ash/policy/status_collector/device_status_collector.cc
+++ b/chrome/browser/ash/policy/status_collector/device_status_collector.cc
@@ -67,6 +67,7 @@
 #include "chrome/common/channel_info.h"
 #include "chrome/common/chrome_features.h"
 #include "chrome/common/pref_names.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/services/cros_healthd/public/mojom/cros_healthd_probe.mojom.h"
 #include "chromeos/dbus/attestation/attestation_client.h"
@@ -76,7 +77,6 @@
 #include "chromeos/dbus/power_manager/idle.pb.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager.pb.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/util/version_loader.h"
 #include "chromeos/login/login_state/login_state.h"
 #include "chromeos/network/network_handler.h"
@@ -2511,7 +2511,7 @@
   em::OsUpdateStatus* os_update_status = status->mutable_os_update_status();
 
   const update_engine::StatusResult update_engine_status =
-      chromeos::UpdateEngineClient::Get()->GetLastStatus();
+      ash::UpdateEngineClient::Get()->GetLastStatus();
 
   absl::optional<base::Version> required_platform_version;
 
diff --git a/chrome/browser/ash/policy/status_collector/device_status_collector_browsertest.cc b/chrome/browser/ash/policy/status_collector/device_status_collector_browsertest.cc
index 642f80c..ca61a2f 100644
--- a/chrome/browser/ash/policy/status_collector/device_status_collector_browsertest.cc
+++ b/chrome/browser/ash/policy/status_collector/device_status_collector_browsertest.cc
@@ -68,6 +68,8 @@
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/userdataauth_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/services/cros_healthd/public/cpp/fake_cros_healthd.h"
@@ -82,8 +84,6 @@
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/vm_applications/apps.pb.h"
 #include "chromeos/login/login_state/login_state.h"
 #include "chromeos/network/network_handler.h"
@@ -904,8 +904,7 @@
 
     // Use FakeUpdateEngineClient.
     chromeos::DBusThreadManager::Initialize();
-    update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+    update_engine_client_ = ash::UpdateEngineClient::InitializeFakeForTest();
     // Async tasks posted when calling `chromeos::DBusThreadManager::Initialize`
     // need to be flushed.
     base::RunLoop().RunUntilIdle();
@@ -939,7 +938,7 @@
     chromeos::PowerManagerClient::Shutdown();
     ash::UserDataAuthClient::Shutdown();
     chromeos::CrasAudioHandler::Shutdown();
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     ash::KioskAppManager::Shutdown();
     ash::cros_healthd::FakeCrosHealthd::Shutdown();
     TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr);
@@ -1227,7 +1226,7 @@
   const DeviceLocalAccount fake_web_kiosk_device_local_account_;
   base::ScopedPathOverride user_data_dir_override_;
   base::ScopedPathOverride crash_dumps_dir_override_;
-  chromeos::FakeUpdateEngineClient* update_engine_client_;
+  ash::FakeUpdateEngineClient* update_engine_client_;
   std::unique_ptr<base::RunLoop> run_loop_;
   base::test::ScopedFeatureList scoped_feature_list_;
   base::SimpleTestClock test_clock_;
diff --git a/chrome/browser/ash/policy/status_collector/legacy_device_status_collector.cc b/chrome/browser/ash/policy/status_collector/legacy_device_status_collector.cc
index a92e5aba..7209484 100644
--- a/chrome/browser/ash/policy/status_collector/legacy_device_status_collector.cc
+++ b/chrome/browser/ash/policy/status_collector/legacy_device_status_collector.cc
@@ -66,6 +66,7 @@
 #include "chrome/common/channel_info.h"
 #include "chrome/common/chrome_features.h"
 #include "chrome/common/pref_names.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/services/cros_healthd/public/cpp/service_connection.h"
 #include "chromeos/ash/services/cros_healthd/public/mojom/cros_healthd_probe.mojom.h"
@@ -74,7 +75,6 @@
 #include "chromeos/dbus/power_manager/idle.pb.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager.pb.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/util/version_loader.h"
 #include "chromeos/login/login_state/login_state.h"
 #include "chromeos/network/network_handler.h"
@@ -2432,7 +2432,7 @@
   em::OsUpdateStatus* os_update_status = status->mutable_os_update_status();
 
   const update_engine::StatusResult update_engine_status =
-      chromeos::UpdateEngineClient::Get()->GetLastStatus();
+      ash::UpdateEngineClient::Get()->GetLastStatus();
 
   absl::optional<base::Version> required_platform_version;
 
diff --git a/chrome/browser/ash/policy/status_collector/legacy_device_status_collector_browsertest.cc b/chrome/browser/ash/policy/status_collector/legacy_device_status_collector_browsertest.cc
index 61f7199..c36dee9 100644
--- a/chrome/browser/ash/policy/status_collector/legacy_device_status_collector_browsertest.cc
+++ b/chrome/browser/ash/policy/status_collector/legacy_device_status_collector_browsertest.cc
@@ -66,6 +66,8 @@
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/ash/components/dbus/userdataauth/userdataauth_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/services/cros_healthd/public/mojom/cros_healthd.mojom.h"
@@ -79,8 +81,6 @@
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/vm_applications/apps.pb.h"
 #include "chromeos/login/login_state/login_state.h"
 #include "chromeos/network/network_handler.h"
@@ -893,8 +893,7 @@
 
     // Use FakeUpdateEngineClient.
     chromeos::DBusThreadManager::Initialize();
-    update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+    update_engine_client_ = ash::UpdateEngineClient::InitializeFakeForTest();
     // Async tasks posted when calling `chromeos::DBusThreadManager::Initialize`
     // need to be flushed.
     base::RunLoop().RunUntilIdle();
@@ -928,7 +927,7 @@
     chromeos::PowerManagerClient::Shutdown();
     ash::UserDataAuthClient::Shutdown();
     chromeos::CrasAudioHandler::Shutdown();
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     ash::KioskAppManager::Shutdown();
     TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr);
 
@@ -1189,7 +1188,7 @@
   const DeviceLocalAccount fake_web_kiosk_device_local_account_;
   base::ScopedPathOverride user_data_dir_override_;
   base::ScopedPathOverride crash_dumps_dir_override_;
-  chromeos::FakeUpdateEngineClient* update_engine_client_;
+  ash::FakeUpdateEngineClient* update_engine_client_;
   std::unique_ptr<base::RunLoop> run_loop_;
   base::test::ScopedFeatureList scoped_feature_list_;
   base::SimpleTestClock test_clock_;
diff --git a/chrome/browser/ash/preferences.cc b/chrome/browser/ash/preferences.cc
index d23d6978..e86b5ae 100644
--- a/chrome/browser/ash/preferences.cc
+++ b/chrome/browser/ash/preferences.cc
@@ -50,9 +50,9 @@
 #include "chrome/common/chrome_features.h"
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/dbus/pciguard/pciguard_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/components/disks/disks_prefs.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/system/devicemode.h"
 #include "chromeos/system/statistics_provider.h"
 #include "components/drive/drive_pref_names.h"
diff --git a/chrome/browser/ash/preferences.h b/chrome/browser/ash/preferences.h
index 882d54f0..16602bc 100644
--- a/chrome/browser/ash/preferences.h
+++ b/chrome/browser/ash/preferences.h
@@ -10,7 +10,7 @@
 #include "ash/public/mojom/cros_display_config.mojom.h"
 #include "base/memory/weak_ptr.h"
 #include "chrome/browser/ash/language_preferences.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_change_registrar.h"
 #include "components/prefs/pref_member.h"
 #include "components/sync_preferences/pref_service_syncable_observer.h"
diff --git a/chrome/browser/ash/preferences_unittest.cc b/chrome/browser/ash/preferences_unittest.cc
index 7a18dd0..e958663 100644
--- a/chrome/browser/ash/preferences_unittest.cc
+++ b/chrome/browser/ash/preferences_unittest.cc
@@ -22,8 +22,8 @@
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
 #include "chrome/test/base/testing_profile_manager.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/language/core/browser/pref_names.h"
 #include "components/prefs/pref_member.h"
 #include "components/sync/base/client_tag_hash.h"
@@ -222,7 +222,7 @@
   TestingProfile* test_profile_;
   sync_preferences::TestingPrefServiceSyncable* pref_service_;
   input_method::MyMockInputMethodManager* mock_manager_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;
+  FakeUpdateEngineClient* fake_update_engine_client_;
 };
 
 TEST_F(PreferencesTest, TestUpdatePrefOnBrowserScreenDetails) {
diff --git a/chrome/browser/ash/system/automatic_reboot_manager.cc b/chrome/browser/ash/system/automatic_reboot_manager.cc
index 024d46d..96d6445e 100644
--- a/chrome/browser/ash/system/automatic_reboot_manager.cc
+++ b/chrome/browser/ash/system/automatic_reboot_manager.cc
@@ -36,7 +36,7 @@
 #include "chrome/browser/browser_process.h"
 #include "chrome/browser/lifetime/termination_notification.h"
 #include "chrome/common/pref_names.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_registry_simple.h"
 #include "components/prefs/pref_service.h"
 #include "components/user_manager/user_manager.h"
diff --git a/chrome/browser/ash/system/automatic_reboot_manager.h b/chrome/browser/ash/system/automatic_reboot_manager.h
index 815d7bf1..71a8c9e0 100644
--- a/chrome/browser/ash/system/automatic_reboot_manager.h
+++ b/chrome/browser/ash/system/automatic_reboot_manager.h
@@ -16,8 +16,8 @@
 #include "base/timer/timer.h"
 #include "base/timer/wall_clock_timer.h"
 #include "chrome/browser/ash/system/automatic_reboot_manager_observer.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_change_registrar.h"
 #include "components/session_manager/core/session_manager.h"
 #include "components/session_manager/core/session_manager_observer.h"
diff --git a/chrome/browser/ash/system/automatic_reboot_manager_unittest.cc b/chrome/browser/ash/system/automatic_reboot_manager_unittest.cc
index 65f4e7f..ff37d29 100644
--- a/chrome/browser/ash/system/automatic_reboot_manager_unittest.cc
+++ b/chrome/browser/ash/system/automatic_reboot_manager_unittest.cc
@@ -29,9 +29,9 @@
 #include "chrome/browser/ash/system/automatic_reboot_manager_observer.h"
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/account_id/account_id.h"
 #include "components/prefs/pref_registry_simple.h"
 #include "components/prefs/testing_pref_service.h"
diff --git a/chrome/browser/ash/system_token_cert_db_initializer.cc b/chrome/browser/ash/system_token_cert_db_initializer.cc
index 407c12f..61d1a12 100644
--- a/chrome/browser/ash/system_token_cert_db_initializer.cc
+++ b/chrome/browser/ash/system_token_cert_db_initializer.cc
@@ -26,10 +26,10 @@
 #include "chrome/browser/ash/crosapi/crosapi_manager.h"
 #include "chrome/browser/ash/login/startup_utils.h"
 #include "chromeos/ash/components/dbus/userdataauth/userdataauth_client.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/dbus/common/dbus_method_call_status.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager.pb.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
 #include "content/public/browser/browser_task_traits.h"
 #include "content/public/browser/browser_thread.h"
diff --git a/chrome/browser/ash/system_token_cert_db_initializer_unittest.cc b/chrome/browser/ash/system_token_cert_db_initializer_unittest.cc
index 123fba1..8418cc8 100644
--- a/chrome/browser/ash/system_token_cert_db_initializer_unittest.cc
+++ b/chrome/browser/ash/system_token_cert_db_initializer_unittest.cc
@@ -13,9 +13,9 @@
 #include "base/test/task_environment.h"
 #include "base/time/time.h"
 #include "chromeos/ash/components/dbus/userdataauth/userdataauth_client.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/system_token_cert_db_storage_test_util.h"
 #include "chromeos/dbus/tpm_manager/tpm_manager_client.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "content/public/test/browser_task_environment.h"
 #include "crypto/nss_util.h"
 #include "crypto/scoped_test_system_nss_key_slot.h"
diff --git a/chrome/browser/ash/tether/tether_service.cc b/chrome/browser/ash/tether/tether_service.cc
index 59f62c92..55e6fc33 100644
--- a/chrome/browser/ash/tether/tether_service.cc
+++ b/chrome/browser/ash/tether/tether_service.cc
@@ -21,7 +21,7 @@
 #include "chrome/browser/ui/ash/network/tether_notification_presenter.h"
 #include "chrome/common/pref_names.h"
 #include "chromeos/ash/components/network/device_state.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/network/network_type_pattern.h"
 #include "components/pref_registry/pref_registry_syncable.h"
 #include "components/prefs/pref_service.h"
diff --git a/chrome/browser/ash/tether/tether_service_unittest.cc b/chrome/browser/ash/tether/tether_service_unittest.cc
index 7b3b717..9363c11 100644
--- a/chrome/browser/ash/tether/tether_service_unittest.cc
+++ b/chrome/browser/ash/tether/tether_service_unittest.cc
@@ -41,6 +41,7 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
@@ -48,7 +49,6 @@
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_connect.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_type_pattern.h"
diff --git a/chrome/browser/ash/usb/cros_usb_detector_unittest.cc b/chrome/browser/ash/usb/cros_usb_detector_unittest.cc
index 9ab36b4..ffbd52d 100644
--- a/chrome/browser/ash/usb/cros_usb_detector_unittest.cc
+++ b/chrome/browser/ash/usb/cros_usb_detector_unittest.cc
@@ -34,13 +34,13 @@
 #include "chrome/test/base/browser_with_test_window_test.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile_manager.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/cicerone/fake_cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/concierge/fake_concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
 #include "chromeos/ash/components/dbus/vm_plugin_dispatcher/fake_vm_plugin_dispatcher_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/cros_disks/cros_disks_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "services/device/public/cpp/test/fake_usb_device_info.h"
@@ -137,7 +137,7 @@
   CrosUsbDetectorTest() {
     // Needed for ChunneldClient via GuestOsStabilityMonitor.
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ConciergeClient::InitializeFake();
     SeneschalClient::InitializeFake();
@@ -162,7 +162,7 @@
     SeneschalClient::Shutdown();
     ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/chromeos/BUILD.gn b/chrome/browser/chromeos/BUILD.gn
index 5fb35f4a..079713cf 100644
--- a/chrome/browser/chromeos/BUILD.gn
+++ b/chrome/browser/chromeos/BUILD.gn
@@ -251,6 +251,7 @@
     "//chromeos/ash/components/dbus/authpolicy",
     "//chromeos/ash/components/dbus/authpolicy:authpolicy_proto",
     "//chromeos/ash/components/dbus/biod",
+    "//chromeos/ash/components/dbus/chunneld",
     "//chromeos/ash/components/dbus/cicerone",
     "//chromeos/ash/components/dbus/concierge",
     "//chromeos/ash/components/dbus/cros_healthd",
@@ -280,6 +281,8 @@
     "//chromeos/ash/components/dbus/system_proxy",
     "//chromeos/ash/components/dbus/system_proxy:system_proxy_proto",
     "//chromeos/ash/components/dbus/typecd",
+    "//chromeos/ash/components/dbus/update_engine",
+    "//chromeos/ash/components/dbus/update_engine:proto",
     "//chromeos/ash/components/dbus/upstart",
     "//chromeos/ash/components/dbus/userdataauth",
     "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
@@ -320,7 +323,6 @@
     "//chromeos/dbus/attestation",
     "//chromeos/dbus/attestation:attestation_proto",
     "//chromeos/dbus/cdm_factory_daemon",
-    "//chromeos/dbus/chunneld",
     "//chromeos/dbus/constants",
     "//chromeos/dbus/cros_disks",
     "//chromeos/dbus/cryptohome",
@@ -348,8 +350,6 @@
     "//chromeos/dbus/tpm_manager:tpm_manager_proto",
     "//chromeos/dbus/u2f",
     "//chromeos/dbus/u2f:u2f_proto",
-    "//chromeos/dbus/update_engine",
-    "//chromeos/dbus/update_engine:proto",
     "//chromeos/dbus/util",
     "//chromeos/ime:gencode",
     "//chromeos/language/language_packs",
@@ -2191,6 +2191,7 @@
     "//chrome/common:constants",
     "//chrome/test:test_support",
     "//chrome/test:test_support_ui",
+    "//chromeos/ash/components/dbus/chunneld",
     "//chromeos/ash/components/dbus/cicerone",
     "//chromeos/ash/components/dbus/concierge",
     "//chromeos/ash/components/dbus/lorgnette_manager",
@@ -2200,7 +2201,6 @@
     "//chromeos/ash/components/dbus/userdataauth:userdataauth",
     "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
     "//chromeos/dbus:test_support",
-    "//chromeos/dbus/chunneld",
     "//chromeos/dbus/cros_disks",
     "//chromeos/dbus/cryptohome",
     "//chromeos/dbus/cryptohome:cryptohome_proto",
@@ -3173,6 +3173,7 @@
     "//chromeos/ash/components/dbus/services:test_support",
     "//chromeos/ash/components/dbus/session_manager",
     "//chromeos/ash/components/dbus/system_clock",
+    "//chromeos/ash/components/dbus/update_engine",
     "//chromeos/ash/components/dbus/upstart",
     "//chromeos/ash/components/dbus/virtual_file_provider",
     "//chromeos/ash/components/dbus/vm_plugin_dispatcher",
@@ -3195,7 +3196,6 @@
     "//chromeos/dbus/power",
     "//chromeos/dbus/smbprovider",
     "//chromeos/dbus/smbprovider:proto",
-    "//chromeos/dbus/update_engine",
     "//chromeos/ime:gencode",
     "//chromeos/login/login_state",
     "//chromeos/login/login_state:test_support",
diff --git a/chrome/browser/extensions/BUILD.gn b/chrome/browser/extensions/BUILD.gn
index e734a365..17407a1d 100644
--- a/chrome/browser/extensions/BUILD.gn
+++ b/chrome/browser/extensions/BUILD.gn
@@ -1155,6 +1155,7 @@
       "//chrome/browser/ui/webui/settings/chromeos/constants:mojom",
       "//chromeos/ash/components/dbus/cicerone:cicerone",
       "//chromeos/ash/components/dbus/cicerone:cicerone_proto",
+      "//chromeos/ash/components/dbus/update_engine",
       "//chromeos/ash/services/assistant/public/cpp",
       "//chromeos/components/remote_apps/mojom",
       "//chromeos/dbus",
@@ -1162,7 +1163,6 @@
       "//chromeos/dbus/cryptohome",
       "//chromeos/dbus/image_burner",
       "//chromeos/dbus/power",
-      "//chromeos/dbus/update_engine",
       "//chromeos/dbus/util",
       "//chromeos/language/language_packs",
       "//chromeos/language/public/mojom",
diff --git a/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.cc b/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.cc
index 29346dc..bfa24715 100644
--- a/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.cc
+++ b/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.cc
@@ -85,31 +85,20 @@
 const char kVolumeNotFoundError[] = "Volume not found.";
 
 // Fills a list of volumes mounted in the system.
-bool GetVolumeListForExtension(
-    const std::vector<base::WeakPtr<file_manager::Volume>>& available_volumes,
-    ConsentProvider* consent_provider,
-    const Extension& extension,
-    std::vector<file_system::Volume>* result_volumes) {
-  if (!consent_provider)
-    return false;
+void FillVolumeList(content::BrowserContext* browser_context,
+                    std::vector<file_system::Volume>* result) {
+  file_manager::VolumeManager* const volume_manager =
+      file_manager::VolumeManager::Get(browser_context);
+  DCHECK(volume_manager);
 
-  const FileSystemDelegate::GrantVolumesMode mode =
-      consent_provider->GetGrantVolumesMode(extension);
-  if (mode == FileSystemDelegate::kGrantNone)
-    return false;
-
-  // Convert available_volumes to result_volume_list.
-  for (const auto& volume : available_volumes) {
-    if (mode == FileSystemDelegate::kGrantAll ||
-        (mode == FileSystemDelegate::kGrantPerVolume &&
-         consent_provider->IsGrantableForVolume(extension, volume))) {
-      file_system::Volume result_volume;
-      result_volume.volume_id = volume->volume_id();
-      result_volume.writable = !volume->is_read_only();
-      result_volumes->push_back(std::move(result_volume));
-    }
+  const auto& volume_list = volume_manager->GetVolumeList();
+  // Convert volume_list to result_volume_list.
+  for (const auto& volume : volume_list) {
+    file_system::Volume result_volume;
+    result_volume.volume_id = volume->volume_id();
+    result_volume.writable = !volume->is_read_only();
+    result->push_back(std::move(result_volume));
   }
-  return true;
 }
 
 // Callback called when consent is granted or denied.
@@ -121,8 +110,8 @@
                        const base::WeakPtr<file_manager::Volume>& volume,
                        bool writable,
                        ConsentProvider::Consent result) {
-  using file_manager::VolumeManager;
   using file_manager::Volume;
+  using file_manager::VolumeManager;
 
   // Render frame host can be gone before this callback method is executed.
   if (!requester->render_frame_host()) {
@@ -226,15 +215,11 @@
       Profile::FromBrowserContext(browser_context));
   ConsentProvider consent_provider(&consent_provider_delegate);
 
-  const std::vector<base::WeakPtr<file_manager::Volume>> volume_list =
-      file_manager::VolumeManager::Get(browser_context)->GetVolumeList();
-
+  file_system::VolumeListChangedEvent event_args;
+  FillVolumeList(browser_context, &event_args.volumes);
   for (const auto& extension : registry->enabled_extensions()) {
-    file_system::VolumeListChangedEvent event_args;
-    if (!GetVolumeListForExtension(volume_list, &consent_provider,
-                                   *extension.get(), &event_args.volumes)) {
+    if (!consent_provider.IsGrantable(*extension.get()))
       continue;
-    }
 
     event_router->DispatchEventToExtension(
         extension->id(),
@@ -338,17 +323,14 @@
 }
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-FileSystemDelegate::GrantVolumesMode
-ChromeFileSystemDelegate::GetGrantVolumesMode(
+bool ChromeFileSystemDelegate::IsGrantable(
     content::BrowserContext* browser_context,
-    content::RenderFrameHost* render_frame_host,
     const Extension& extension) {
   // Only kiosk apps in kiosk sessions can use this API.
   // Additionally it is enabled for allowlisted component extensions and apps.
   ConsentProviderDelegate consent_provider_delegate(
       Profile::FromBrowserContext(browser_context));
-  return ConsentProvider(&consent_provider_delegate)
-      .GetGrantVolumesMode(extension);
+  return ConsentProvider(&consent_provider_delegate).IsGrantable(extension);
 }
 
 void ChromeFileSystemDelegate::RequestFileSystem(
@@ -363,8 +345,8 @@
       Profile::FromBrowserContext(browser_context));
   ConsentProvider consent_provider(&consent_provider_delegate);
 
-  using file_manager::VolumeManager;
   using file_manager::Volume;
+  using file_manager::VolumeManager;
   VolumeManager* const volume_manager = VolumeManager::Get(browser_context);
   DCHECK(volume_manager);
 
@@ -374,16 +356,14 @@
     return;
   }
 
-  if (consent_provider.GetGrantVolumesMode(extension) ==
-      FileSystemDelegate::kGrantNone) {
+  if (!consent_provider.IsGrantable(extension)) {
     std::move(error_callback).Run(kNotSupportedOnNonKioskSessionError);
     return;
   }
 
   base::WeakPtr<file_manager::Volume> volume =
       volume_manager->FindVolumeById(volume_id);
-  if (!volume.get() ||
-      !consent_provider.IsGrantableForVolume(extension, volume)) {
+  if (!volume.get()) {
     std::move(error_callback).Run(kVolumeNotFoundError);
     return;
   }
@@ -417,19 +397,11 @@
 
 void ChromeFileSystemDelegate::GetVolumeList(
     content::BrowserContext* browser_context,
-    const Extension& extension,
     VolumeListCallback success_callback,
     ErrorCallback error_callback) {
-  ConsentProviderDelegate consent_provider_delegate(
-      Profile::FromBrowserContext(browser_context));
-  ConsentProvider consent_provider(&consent_provider_delegate);
-
-  const std::vector<base::WeakPtr<file_manager::Volume>> volume_list =
-      file_manager::VolumeManager::Get(browser_context)->GetVolumeList();
   std::vector<file_system::Volume> result_volume_list;
+  FillVolumeList(browser_context, &result_volume_list);
 
-  GetVolumeListForExtension(volume_list, &consent_provider, extension,
-                            &result_volume_list);
   std::move(success_callback).Run(result_volume_list);
 }
 
diff --git a/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.h b/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.h
index 9be9c0d..9f69c045 100644
--- a/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.h
+++ b/chrome/browser/extensions/api/file_system/chrome_file_system_delegate.h
@@ -52,10 +52,8 @@
                                        base::OnceClosure on_cancel) override;
   int GetDescriptionIdForAcceptType(const std::string& accept_type) override;
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-  FileSystemDelegate::GrantVolumesMode GetGrantVolumesMode(
-      content::BrowserContext* browser_context,
-      content::RenderFrameHost* render_frame_host,
-      const Extension& extension) override;
+  bool IsGrantable(content::BrowserContext* browser_context,
+                   const Extension& extension) override;
   void RequestFileSystem(content::BrowserContext* browser_context,
                          scoped_refptr<ExtensionFunction> requester,
                          const Extension& extension,
@@ -64,7 +62,6 @@
                          FileSystemCallback success_callback,
                          ErrorCallback error_callback) override;
   void GetVolumeList(content::BrowserContext* browser_context,
-                     const Extension& extension,
                      VolumeListCallback success_callback,
                      ErrorCallback error_callback) override;
 #endif  // BUILDFLAG(IS_CHROMEOS_ASH)
diff --git a/chrome/browser/extensions/api/file_system/consent_provider.cc b/chrome/browser/extensions/api/file_system/consent_provider.cc
index 70ad936..8817cf12 100644
--- a/chrome/browser/extensions/api/file_system/consent_provider.cc
+++ b/chrome/browser/extensions/api/file_system/consent_provider.cc
@@ -23,7 +23,6 @@
 #include "extensions/browser/app_window/app_window_registry.h"
 #include "extensions/common/api/file_system.h"
 #include "extensions/common/manifest_handlers/kiosk_mode_info.h"
-#include "extensions/common/permissions/permissions_data.h"
 
 namespace extensions {
 
@@ -90,7 +89,7 @@
     const base::WeakPtr<file_manager::Volume>& volume,
     bool writable,
     ConsentCallback callback) {
-  DCHECK(IsGrantableForVolume(extension, volume));
+  DCHECK(IsGrantable(extension));
 
   // If a allowlisted component, then no need to ask or inform the user.
   if (extension.location() == mojom::ManifestLocation::kComponent &&
@@ -100,16 +99,6 @@
     return;
   }
 
-  // If a allowlisted app or extensions to access Downloads folder, then no
-  // need to ask or inform the user.
-  if (volume.get() &&
-      volume->type() == file_manager::VOLUME_TYPE_DOWNLOADS_DIRECTORY &&
-      delegate_->HasRequestDownloadsPermission(extension)) {
-    base::ThreadTaskRunnerHandle::Get()->PostTask(
-        FROM_HERE, base::BindOnce(std::move(callback), CONSENT_GRANTED));
-    return;
-  }
-
   // If auto-launched kiosk app, then no need to ask user either, but show the
   // notification.
   if (delegate_->IsAutoLaunched(extension)) {
@@ -132,8 +121,7 @@
   NOTREACHED() << "Cannot request consent for non-grantable extensions.";
 }
 
-FileSystemDelegate::GrantVolumesMode ConsentProvider::GetGrantVolumesMode(
-    const Extension& extension) {
+bool ConsentProvider::IsGrantable(const Extension& extension) {
   const bool is_allowlisted_component =
       delegate_->IsAllowlistedComponent(extension);
 
@@ -141,27 +129,7 @@
       KioskModeInfo::IsKioskOnly(&extension) &&
       user_manager::UserManager::Get()->IsLoggedInAsKioskApp();
 
-  if (is_allowlisted_component || is_running_in_kiosk_session) {
-    return FileSystemDelegate::kGrantAll;
-  }
-
-  const bool is_allowlisted_non_component =
-      delegate_->HasRequestDownloadsPermission(extension);
-
-  return is_allowlisted_non_component ? FileSystemDelegate::kGrantPerVolume
-                                      : FileSystemDelegate::kGrantNone;
-}
-
-bool ConsentProvider::IsGrantableForVolume(
-    const Extension& extension,
-    const base::WeakPtr<file_manager::Volume>& volume) {
-  if (volume.get() &&
-      volume->type() == file_manager::VOLUME_TYPE_DOWNLOADS_DIRECTORY &&
-      delegate_->HasRequestDownloadsPermission(extension)) {
-    return true;
-  }
-
-  return GetGrantVolumesMode(extension) == FileSystemDelegate::kGrantAll;
+  return is_allowlisted_component || is_running_in_kiosk_session;
 }
 
 ConsentProviderDelegate::ConsentProviderDelegate(Profile* profile)
@@ -253,11 +221,5 @@
   return false;
 }
 
-bool ConsentProviderDelegate::HasRequestDownloadsPermission(
-    const Extension& extension) {
-  return extension.permissions_data()->HasAPIPermission(
-      mojom::APIPermissionID::kFileSystemRequestDownloads);
-}
-
 }  // namespace file_system_api
 }  // namespace extensions
diff --git a/chrome/browser/extensions/api/file_system/consent_provider.h b/chrome/browser/extensions/api/file_system/consent_provider.h
index e6e7aa9..5862832 100644
--- a/chrome/browser/extensions/api/file_system/consent_provider.h
+++ b/chrome/browser/extensions/api/file_system/consent_provider.h
@@ -8,7 +8,6 @@
 #include "base/callback_forward.h"
 #include "base/memory/weak_ptr.h"
 #include "build/build_config.h"
-#include "extensions/browser/api/file_system/file_system_delegate.h"
 #include "ui/base/ui_base_types.h"
 
 class Profile;
@@ -62,9 +61,6 @@
 
     // Checks if the extension is a allowlisted component extension or app.
     virtual bool IsAllowlistedComponent(const Extension& extension) = 0;
-
-    // Checks if the extension has the permission to access Downloads.
-    virtual bool HasRequestDownloadsPermission(const Extension& extension) = 0;
   };
 
   explicit ConsentProvider(DelegateInterface* delegate);
@@ -76,21 +72,15 @@
 
   // Requests consent for granting |writable| permissions to the |volume|
   // volume by the |extension|. Must be called only if the extension is
-  // grantable, which can be checked with GetGrantVolumesMode() and
-  // IsGrantableForVolume().
+  // grantable, which can be checked with IsGrantable().
   void RequestConsent(const Extension& extension,
                       content::RenderFrameHost* host,
                       const base::WeakPtr<file_manager::Volume>& volume,
                       bool writable,
                       ConsentCallback callback);
 
-  // Returns granted access mode for the |extension|.
-  FileSystemDelegate::GrantVolumesMode GetGrantVolumesMode(
-      const Extension& extension);
-
-  // Checks whether the |extension| can be granted |volume| access.
-  bool IsGrantableForVolume(const Extension& extension,
-                            const base::WeakPtr<file_manager::Volume>& volume);
+  // Checks whether the |extension| can be granted access.
+  bool IsGrantable(const Extension& extension);
 
  private:
   DelegateInterface* const delegate_;
@@ -126,7 +116,6 @@
                         bool writable) override;
   bool IsAutoLaunched(const Extension& extension) override;
   bool IsAllowlistedComponent(const Extension& extension) override;
-  bool HasRequestDownloadsPermission(const Extension& extension) override;
 
   Profile* const profile_;
 };
diff --git a/chrome/browser/extensions/api/file_system/consent_provider_unittest.cc b/chrome/browser/extensions/api/file_system/consent_provider_unittest.cc
index c6c1994..3c0fa9c0 100644
--- a/chrome/browser/extensions/api/file_system/consent_provider_unittest.cc
+++ b/chrome/browser/extensions/api/file_system/consent_provider_unittest.cc
@@ -8,7 +8,6 @@
 #include <string>
 
 #include "base/bind.h"
-#include "base/files/scoped_temp_dir.h"
 #include "base/memory/ptr_util.h"
 #include "base/memory/ref_counted.h"
 #include "base/memory/weak_ptr.h"
@@ -20,11 +19,9 @@
 #include "components/user_manager/scoped_user_manager.h"
 #include "components/user_manager/user.h"
 #include "content/public/test/browser_task_environment.h"
-#include "extensions/browser/api/file_system/file_system_delegate.h"
 #include "extensions/common/extension.h"
 #include "extensions/common/extension_builder.h"
 #include "extensions/common/manifest.h"
-#include "extensions/common/permissions/permissions_data.h"
 #include "testing/gtest/include/gtest/gtest.h"
 
 using extensions::file_system_api::ConsentProvider;
@@ -91,11 +88,6 @@
     return allowlisted_component_id_.compare(extension.id()) == 0;
   }
 
-  bool HasRequestDownloadsPermission(const Extension& extension) override {
-    return extension.permissions_data()->HasAPIPermission(
-        mojom::APIPermissionID::kFileSystemRequestDownloads);
-  }
-
   int show_dialog_counter_;
   int show_notification_counter_;
   ui::DialogButton dialog_button_;
@@ -123,8 +115,6 @@
     scoped_user_manager_enabler_ =
         std::make_unique<user_manager::ScopedUserManager>(
             base::WrapUnique(user_manager_));
-    ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
-    download_volume_ = Volume::CreateForDownloads(temp_dir_.GetPath());
   }
 
   void TearDown() override {
@@ -140,8 +130,6 @@
   ash::FakeChromeUserManager* user_manager_;  // Owned by the scope enabler.
   std::unique_ptr<user_manager::ScopedUserManager> scoped_user_manager_enabler_;
   content::BrowserTaskEnvironment task_environment_;
-  base::ScopedTempDir temp_dir_;
-  std::unique_ptr<Volume> download_volume_;
 };
 
 TEST_F(FileSystemApiConsentProviderTest, ForNonKioskApps) {
@@ -153,8 +141,7 @@
             .Build());
     TestingConsentProviderDelegate delegate;
     ConsentProvider provider(&delegate);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*component_extension),
-              FileSystemDelegate::kGrantNone);
+    EXPECT_FALSE(provider.IsGrantable(*component_extension));
   }
 
   // Allowlisted component apps are instantly granted access without asking
@@ -167,8 +154,7 @@
     TestingConsentProviderDelegate delegate;
     delegate.SetComponentAllowlist(allowlisted_component_extension->id());
     ConsentProvider provider(&delegate);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*allowlisted_component_extension),
-              FileSystemDelegate::kGrantAll);
+    EXPECT_TRUE(provider.IsGrantable(*allowlisted_component_extension));
 
     ConsentProvider::Consent result = ConsentProvider::CONSENT_IMPOSSIBLE;
     provider.RequestConsent(*allowlisted_component_extension.get(), nullptr,
@@ -188,8 +174,7 @@
         ExtensionBuilder("Test").Build());
     TestingConsentProviderDelegate delegate;
     ConsentProvider provider(&delegate);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*non_component_extension),
-              FileSystemDelegate::kGrantNone);
+    EXPECT_FALSE(provider.IsGrantable(*non_component_extension));
   }
 }
 
@@ -210,8 +195,7 @@
     TestingConsentProviderDelegate delegate;
     delegate.SetIsAutoLaunched(true);
     ConsentProvider provider(&delegate);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*auto_launch_kiosk_app),
-              FileSystemDelegate::kGrantAll);
+    EXPECT_TRUE(provider.IsGrantable(*auto_launch_kiosk_app));
 
     ConsentProvider::Consent result = ConsentProvider::CONSENT_IMPOSSIBLE;
     provider.RequestConsent(*auto_launch_kiosk_app.get(), nullptr, volume_,
@@ -239,8 +223,7 @@
     TestingConsentProviderDelegate delegate;
     delegate.SetDialogButton(ui::DIALOG_BUTTON_OK);
     ConsentProvider provider(&delegate);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*manual_launch_kiosk_app),
-              FileSystemDelegate::kGrantAll);
+    EXPECT_TRUE(provider.IsGrantable(*manual_launch_kiosk_app));
 
     ConsentProvider::Consent result = ConsentProvider::CONSENT_IMPOSSIBLE;
     provider.RequestConsent(*manual_launch_kiosk_app.get(), nullptr, volume_,
@@ -259,8 +242,7 @@
     TestingConsentProviderDelegate delegate;
     ConsentProvider provider(&delegate);
     delegate.SetDialogButton(ui::DIALOG_BUTTON_CANCEL);
-    EXPECT_EQ(provider.GetGrantVolumesMode(*manual_launch_kiosk_app),
-              FileSystemDelegate::kGrantAll);
+    EXPECT_TRUE(provider.IsGrantable(*manual_launch_kiosk_app));
 
     ConsentProvider::Consent result = ConsentProvider::CONSENT_IMPOSSIBLE;
     provider.RequestConsent(*manual_launch_kiosk_app.get(), nullptr, volume_,
diff --git a/chrome/browser/extensions/api/file_system/file_system_apitest_chromeos.cc b/chrome/browser/extensions/api/file_system/file_system_apitest_chromeos.cc
index 0bac6c4d..e7cf3220 100644
--- a/chrome/browser/extensions/api/file_system/file_system_apitest_chromeos.cc
+++ b/chrome/browser/extensions/api/file_system/file_system_apitest_chromeos.cc
@@ -27,14 +27,12 @@
 #include "extensions/browser/api/file_system/file_system_api.h"
 #include "extensions/browser/event_router.h"
 #include "extensions/common/api/file_system.h"
-#include "extensions/common/switches.h"
 #include "storage/browser/file_system/external_mount_points.h"
 #include "ui/base/ui_base_types.h"
 
 // TODO(michaelpg): Port these tests to app_shell: crbug.com/505926.
 
 using file_manager::VolumeManager;
-using file_manager::VolumeType;
 
 namespace extensions {
 namespace {
@@ -42,7 +40,6 @@
 // Mount point names for chrome.fileSystem.requestFileSystem() tests.
 const char kWritableMountPointName[] = "writable";
 const char kReadOnlyMountPointName[] = "read-only";
-const char kDownloadsMountPointName[] = "downloads";
 
 // Child directory created in each of the mount points.
 const char kChildDirectory[] = "child-dir";
@@ -143,9 +140,7 @@
     PlatformAppBrowserTest::SetUpOnMainThread();
   }
 
-  void TearDown() override {
-    PlatformAppBrowserTest::TearDown();
-  }
+  void TearDown() override { PlatformAppBrowserTest::TearDown(); }
 
   base::FilePath GetDriveMountPoint() { return drivefs_mount_point_; }
 
@@ -213,12 +208,6 @@
     return drive::SetUpUserDataDirectoryForDriveFsTest();
   }
 
-  void SetUpCommandLine(base::CommandLine* command_line) override {
-    PlatformAppBrowserTest::SetUpCommandLine(command_line);
-    command_line->AppendSwitchASCII(
-        extensions::switches::kAllowlistedExtensionID, kTestingExtensionId);
-  }
-
   // Sets up fake Drive service for tests (this has to be injected before the
   // real DriveIntegrationService instance is created.)
   void SetUpInProcessBrowserTestFixture() override {
@@ -235,15 +224,8 @@
 
   void SetUpOnMainThread() override {
     ASSERT_TRUE(temp_dir_.CreateUniqueTempDir());
-    CreateTestingFileSystem(kWritableMountPointName,
-                            file_manager::VOLUME_TYPE_TESTING,
-                            false /* read_only */);
-    CreateTestingFileSystem(kReadOnlyMountPointName,
-                            file_manager::VOLUME_TYPE_TESTING,
-                            true /* read_only */);
-    CreateTestingFileSystem(kDownloadsMountPointName,
-                            file_manager::VOLUME_TYPE_DOWNLOADS_DIRECTORY,
-                            false /* read_only */);
+    CreateTestingFileSystem(kWritableMountPointName, false /* read_only */);
+    CreateTestingFileSystem(kReadOnlyMountPointName, true /* read_only */);
     PlatformAppBrowserTest::SetUpOnMainThread();
   }
 
@@ -270,7 +252,6 @@
 
   // Creates a testing file system in a testing directory.
   void CreateTestingFileSystem(const std::string& mount_point_name,
-                               VolumeType volume_type,
                                bool read_only) {
     const base::FilePath mount_point_path =
         temp_dir_.GetPath().Append(mount_point_name);
@@ -283,9 +264,9 @@
     VolumeManager* const volume_manager =
         VolumeManager::Get(browser()->profile());
     ASSERT_TRUE(volume_manager);
-    volume_manager->AddVolumeForTesting(mount_point_path, volume_type,
-                                        chromeos::DEVICE_TYPE_UNKNOWN,
-                                        read_only);
+    volume_manager->AddVolumeForTesting(
+        mount_point_path, file_manager::VOLUME_TYPE_TESTING,
+        chromeos::DEVICE_TYPE_UNKNOWN, read_only);
   }
 
   // Simulates entering the kiosk session.
@@ -447,7 +428,7 @@
 }
 
 IN_PROC_BROWSER_TEST_F(FileSystemApiTestForDrive,
-    FileSystemApiSaveNewFileWithWriteTest) {
+                       FileSystemApiSaveNewFileWithWriteTest) {
   base::FilePath test_file =
       GetDriveMountPoint().AppendASCII("root/save_new.txt");
   FileSystemChooseEntryFunction::SkipPickerAndAlwaysSelectPathForTest picker(
@@ -458,7 +439,7 @@
 }
 
 IN_PROC_BROWSER_TEST_F(FileSystemApiTestForDrive,
-    FileSystemApiSaveExistingFileWithWriteTest) {
+                       FileSystemApiSaveExistingFileWithWriteTest) {
   base::FilePath test_file =
       GetDriveMountPoint().AppendASCII("root/save_existing.txt");
   FileSystemChooseEntryFunction::SkipPickerAndAlwaysSelectPathForTest picker(
diff --git a/chrome/browser/extensions/api/networking_private/networking_private_chromeos_apitest.cc b/chrome/browser/extensions/api/networking_private/networking_private_chromeos_apitest.cc
index 6f230e7e..bae6384 100644
--- a/chrome/browser/extensions/api/networking_private/networking_private_chromeos_apitest.cc
+++ b/chrome/browser/extensions/api/networking_private/networking_private_chromeos_apitest.cc
@@ -24,6 +24,7 @@
 #include "chromeos/ash/components/dbus/userdataauth/userdataauth_client.h"
 #include "chromeos/ash/components/network/cellular_metrics_logger.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
@@ -32,7 +33,6 @@
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_certificate_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chrome/browser/extensions/api/networking_private/networking_private_ui_delegate_chromeos.cc b/chrome/browser/extensions/api/networking_private/networking_private_ui_delegate_chromeos.cc
index 506ab3b..bb234617 100644
--- a/chrome/browser/extensions/api/networking_private/networking_private_ui_delegate_chromeos.cc
+++ b/chrome/browser/extensions/api/networking_private/networking_private_ui_delegate_chromeos.cc
@@ -4,7 +4,7 @@
 
 #include "chrome/browser/extensions/api/networking_private/networking_private_ui_delegate_chromeos.h"
 
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 
diff --git a/chrome/browser/extensions/api/system_private/system_private_api.cc b/chrome/browser/extensions/api/system_private/system_private_api.cc
index 8b5709b..bd592cb5 100644
--- a/chrome/browser/extensions/api/system_private/system_private_api.cc
+++ b/chrome/browser/extensions/api/system_private/system_private_api.cc
@@ -19,7 +19,7 @@
 #include "google_apis/google_api_keys.h"
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #else
 #include "chrome/browser/upgrade_detector/upgrade_detector.h"
 #endif
@@ -71,7 +71,7 @@
   // With UpdateEngineClient, we can provide more detailed information about
   // system updates on ChromeOS.
   const update_engine::StatusResult status =
-      chromeos::UpdateEngineClient::Get()->GetLastStatus();
+      ash::UpdateEngineClient::Get()->GetLastStatus();
   // |download_progress| is set to 1 after download finishes
   // (i.e. verify, finalize and need-reboot phase) to indicate the progress
   // even though |status.download_progress| is 0 in these phases.
diff --git a/chrome/browser/extensions/api/system_private/system_private_apitest.cc b/chrome/browser/extensions/api/system_private/system_private_apitest.cc
index f7f7c1f..d20c2ab 100644
--- a/chrome/browser/extensions/api/system_private/system_private_apitest.cc
+++ b/chrome/browser/extensions/api/system_private/system_private_apitest.cc
@@ -12,10 +12,8 @@
 #include "content/public/test/browser_test.h"
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
-
-using chromeos::UpdateEngineClient;
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #endif
 
 namespace extensions {
@@ -40,7 +38,8 @@
 
   void SetUpInProcessBrowserTestFixture() override {
     ExtensionApiTest::SetUpInProcessBrowserTestFixture();
-    fake_update_engine_client_ = UpdateEngineClient::InitializeFakeForTest();
+    fake_update_engine_client_ =
+        ash::UpdateEngineClient::InitializeFakeForTest();
   }
 
   void TearDownInProcessBrowserTestFixture() override {
@@ -48,7 +47,7 @@
   }
 
  protected:
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
 };
 
 IN_PROC_BROWSER_TEST_F(GetUpdateStatusApiTest, Progress) {
diff --git a/chrome/browser/flag-metadata.json b/chrome/browser/flag-metadata.json
index 0cd8572..f507a56 100644
--- a/chrome/browser/flag-metadata.json
+++ b/chrome/browser/flag-metadata.json
@@ -4699,6 +4699,11 @@
     "expiry_milestone": 110
   },
   {
+    "name": "omnibox-paste-button",
+    "owners": [ "christianxu", "stkhapugin", "bling-flags@google.com" ],
+    "expiry_milestone": 108
+  },
+  {
     "name": "omnibox-retain-suggestions-with-headers",
     "owners": [ "ender@google.com", "mahmadi@google.com", "chrome-omnibox-team@google.com" ],
     "expiry_milestone": 112
@@ -6169,6 +6174,11 @@
     "expiry_milestone": -1
   },
   {
+    "name": "use-dns-https-svcb-alpn",
+    "owners": [ "horo" ],
+    "expiry_milestone": 115
+  },
+  {
     "name": "use-fake-device-for-media-stream",
     "owners": [ "mcasas", "chromeos-gfx@google.com" ],
     // This flag is used for ChromeOS media testing to mock a source device.
diff --git a/chrome/browser/flag_descriptions.cc b/chrome/browser/flag_descriptions.cc
index 9148258..110f7db 100644
--- a/chrome/browser/flag_descriptions.cc
+++ b/chrome/browser/flag_descriptions.cc
@@ -258,6 +258,11 @@
     "ClientHello, depending on server support and whether those features are "
     "enabled.";
 
+const char kUseDnsHttpsSvcbAlpnName[] = "Use DNS https alpn";
+const char kUseDnsHttpsSvcbAlpnDescription[] =
+    "When enabled, Chrome may try QUIC on the first connection using the ALPN"
+    " information in the DNS HTTPS record.";
+
 const char kEnableFirstPartySetsName[] = "Enable First-Party Sets";
 const char kEnableFirstPartySetsDescription[] =
     "When enabled, Chrome will apply First-Party Sets to features such as the "
diff --git a/chrome/browser/flag_descriptions.h b/chrome/browser/flag_descriptions.h
index 39c6889..39a1dfd 100644
--- a/chrome/browser/flag_descriptions.h
+++ b/chrome/browser/flag_descriptions.h
@@ -401,6 +401,9 @@
 extern const char kDnsHttpsSvcbName[];
 extern const char kDnsHttpsSvcbDescription[];
 
+extern const char kUseDnsHttpsSvcbAlpnName[];
+extern const char kUseDnsHttpsSvcbAlpnDescription[];
+
 extern const char kEditContextName[];
 extern const char kEditContextDescription[];
 
diff --git a/chrome/browser/lifetime/application_lifetime_chromeos.cc b/chrome/browser/lifetime/application_lifetime_chromeos.cc
index 8f420c5..07311cae 100644
--- a/chrome/browser/lifetime/application_lifetime_chromeos.cc
+++ b/chrome/browser/lifetime/application_lifetime_chromeos.cc
@@ -5,16 +5,16 @@
 #include "chrome/browser/lifetime/application_lifetime_chromeos.h"
 #include "chrome/browser/lifetime/application_lifetime.h"
 
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 
 namespace chrome {
 namespace {
 
-chromeos::UpdateEngineClient* GetUpdateEngineClient() {
-  chromeos::UpdateEngineClient* update_engine_client =
-      chromeos::UpdateEngineClient::Get();
+ash::UpdateEngineClient* GetUpdateEngineClient() {
+  ash::UpdateEngineClient* update_engine_client =
+      ash::UpdateEngineClient::Get();
   DCHECK(update_engine_client);
   return update_engine_client;
 }
diff --git a/chrome/browser/lifetime/application_lifetime_chromeos_browsertest.cc b/chrome/browser/lifetime/application_lifetime_chromeos_browsertest.cc
index 389c23c..e8c97b154 100644
--- a/chrome/browser/lifetime/application_lifetime_chromeos_browsertest.cc
+++ b/chrome/browser/lifetime/application_lifetime_chromeos_browsertest.cc
@@ -12,9 +12,9 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/in_process_browser_test.h"
 #include "chromeos/ash/components/dbus/session_manager/fake_session_manager_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/power/fake_power_manager_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/keep_alive_registry/keep_alive_registry.h"
 #include "components/prefs/pref_service.h"
 #include "content/public/test/browser_test.h"
@@ -30,7 +30,7 @@
   void SetUpInProcessBrowserTestFixture() override {
     InProcessBrowserTest::SetUpInProcessBrowserTestFixture();
     fake_update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+        ash::UpdateEngineClient::InitializeFakeForTest();
   }
 
   void SetUpOnMainThread() override {
@@ -74,7 +74,7 @@
   }
 
   absl::optional<base::RunLoop> quits_on_browser_closing_;
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_ = nullptr;
 };
 
 IN_PROC_BROWSER_TEST_F(ApplicationLifetimeTest,
diff --git a/chrome/browser/lifetime/termination_notification.cc b/chrome/browser/lifetime/termination_notification.cc
index 69727d8..0e1ff8a 100644
--- a/chrome/browser/lifetime/termination_notification.cc
+++ b/chrome/browser/lifetime/termination_notification.cc
@@ -17,9 +17,9 @@
 #include "ash/components/login/session/session_termination_manager.h"
 #include "chrome/browser/lifetime/application_lifetime_chromeos.h"
 #include "chromeos/ash/components/dbus/session_manager/session_manager_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"  // nogncheck
 #include "chromeos/dbus/power/power_policy_controller.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #endif
 
 namespace browser_shutdown {
diff --git a/chrome/browser/nearby_sharing/wifi_network_configuration/wifi_network_configuration_handler.cc b/chrome/browser/nearby_sharing/wifi_network_configuration/wifi_network_configuration_handler.cc
index 3da9e81..c61a7dd 100644
--- a/chrome/browser/nearby_sharing/wifi_network_configuration/wifi_network_configuration_handler.cc
+++ b/chrome/browser/nearby_sharing/wifi_network_configuration/wifi_network_configuration_handler.cc
@@ -6,7 +6,7 @@
 
 #include "chrome/browser/nearby_sharing/logging/logging.h"
 #include "chrome/browser/nearby_sharing/nearby_share_metrics_logger.h"
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/services/network_config/in_process_instance.h"
 #include "chromeos/services/network_config/public/mojom/cros_network_config.mojom.h"
 
diff --git a/chrome/browser/policy/networking/user_network_configuration_updater_ash.cc b/chrome/browser/policy/networking/user_network_configuration_updater_ash.cc
index 272c86f..000025c 100644
--- a/chrome/browser/policy/networking/user_network_configuration_updater_ash.cc
+++ b/chrome/browser/policy/networking/user_network_configuration_updater_ash.cc
@@ -18,11 +18,11 @@
 #include "chrome/browser/net/nss_service_factory.h"
 #include "chrome/browser/profiles/profile.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer_impl.h"
 #include "chromeos/components/onc/onc_parsed_certificates.h"
 #include "chromeos/components/onc/onc_utils.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "components/policy/policy_constants.h"
 #include "components/user_manager/user.h"
 #include "content/public/browser/browser_task_traits.h"
diff --git a/chrome/browser/policy/test/policy_certs_browsertest.cc b/chrome/browser/policy/test/policy_certs_browsertest.cc
index 635031d5b..d20a368 100644
--- a/chrome/browser/policy/test/policy_certs_browsertest.cc
+++ b/chrome/browser/policy/test/policy_certs_browsertest.cc
@@ -28,10 +28,10 @@
 #include "chrome/browser/ui/browser_list.h"
 #include "chrome/common/chrome_paths.h"
 #include "chrome/test/base/in_process_browser_test.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer_impl.h"
 #include "chromeos/components/onc/onc_test_utils.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/test/chromeos_test_utils.h"
 #include "components/onc/onc_constants.h"
 #include "components/policy/core/browser/browser_policy_connector.h"
diff --git a/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_km.xtb b/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_km.xtb
index 82ebc86c..81ea2b16 100644
--- a/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_km.xtb
+++ b/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_km.xtb
@@ -32,6 +32,7 @@
 <translation id="1197088940767939838">ទឹក​ក្រូច</translation>
 <translation id="1198865190323699001">ចលនាចុច</translation>
 <translation id="1201402288615127009">បន្ទាប់</translation>
+<translation id="1202112913213080585">បោះបង់</translation>
 <translation id="1206619573307042055">marquee</translation>
 <translation id="1207086294218137981">គ្មានផ្នែកក្បាលកម្រិតទី 4 បន្ទាប់ទេ</translation>
 <translation id="1212770441379271564">ផ្លូវកាត់​មួយចំនួន​បន្ទាប់មិនមែន​ជាបញ្ជា​របស់ ChromeVox ទេ ប៉ុន្តែផ្លូវកាត់ទាំងនេះនៅតែ​មានប្រយោជន៍ ដើម្បីទទួលបាន​អត្ថប្រយោជន៍​ច្រើនបំផុត​ពី Chrome។
@@ -43,6 +44,7 @@
     ដើម្បី​បើកម៉ឺនុយ​កម្មវិធី​រុករកតាម​អ៊ីនធឺណិត Chrome សូមចុច Alt+F។</translation>
 <translation id="1213216066620407844">ChromeVox - ការផ្តល់សម្លេងទៅ Chrome</translation>
 <translation id="1225969361094801578">ប្រផេះចាស់</translation>
+<translation id="122928249241119550">ផ្លាស់ទី​ទៅ​ប្រយោគមុន</translation>
 <translation id="1230503547248836149">ផ្នែកចាប់ផ្ដើមនៃការជ្រើសរើស</translation>
 <translation id="1236794971743289975">កំណត់​ចំណាំ​នៅខាងចុង</translation>
 <translation id="1237797094773582699">ស្រដៀងគ្នា​នេះដែរ ការអូស​ដោយប្រើម្រាមដៃបួន​ពីស្ដាំទៅឆ្វេង​អាចត្រូវបានប្រើ ដើម្បីទៅកាន់​ផ្នែកមុន។ សាកល្បង​ឥឡូវនេះ!</translation>
@@ -213,6 +215,7 @@
 <translation id="2435422727584637732">ខៀវខ្ចី</translation>
 <translation id="2438712309510062123">ណែនាំ</translation>
 <translation id="2450814015951372393">ប្រអប់ធីក</translation>
+<translation id="2450992626945324272">ផ្លាស់ទី​ទៅ​ប្រយោគ​បន្ទាប់</translation>
 <translation id="2461822463642141190">បច្ចុប្បន្ន</translation>
 <translation id="2462626033734746142">ប៊ូតុងក្រុមវិទ្យុ</translation>
 <translation id="2467741090055146971">ដក​ការ​ជ្រើសរើស</translation>
@@ -489,6 +492,7 @@
 <translation id="42164919740161077">ស៊ីលៀបចាស់</translation>
 <translation id="4217571870635786043">ការសរសេរ​តាមអាន​</translation>
 <translation id="4218529045364428769">{COUNT,plural, =1{សញ្ញាដាស}other{# សញ្ញាដាស}}</translation>
+<translation id="4220024144662591089">ជ្រើសរើស​ពី <ph name="START_PHRASE" /> ដល់ <ph name="END_PHRASE" /></translation>
 <translation id="4221012616705981690">គ្មានបញ្ជីមុនទេ</translation>
 <translation id="4225355998815256469">ការគ្រប់គ្រងទម្រង់បែបបទ</translation>
 <translation id="4230834257931120629">ប្រផេះស្រាល</translation>
@@ -759,6 +763,7 @@
 <translation id="611827076493383239">vtd</translation>
 <translation id="6122013438240733403">btn</translation>
 <translation id="6132506484792346370">ប្រអប់បញ្ជី ឬប្រអប់បន្សំ</translation>
+<translation id="613344593214611552">លុបប្រយោគមុន</translation>
 <translation id="6142308968191113180">ផ្នែកក្បាល 4</translation>
 <translation id="6150023170003443621">បៃតងខ្ចី</translation>
 <translation id="6158882249329863701">ជួរដេកទី <ph name="TABLECELLROWINDEX" /> ជួរឈរទី <ph name="TABLECELLCOLUMNINDEX" /></translation>
@@ -768,6 +773,7 @@
 <translation id="6186305613600865047">លោតទៅខាងក្រោមទំព័រ</translation>
 <translation id="6187190722927752226">បៃតងខ្ចី</translation>
 <translation id="6197361807490522975">ខៀវចាស់</translation>
+<translation id="6218813441317556731">ជំនួស <ph name="DELETE_PHRASE" /> ដោយ <ph name="INSERT_PHRASE" /></translation>
 <translation id="6236061028292614533">ផ្នែកក្បាលបន្ទាប់</translation>
 <translation id="6254901459154107917">តំបន់ដែលអាចកែប្រែអត្ថបទបានបន្ទាប់</translation>
 <translation id="6259464875943891919">បានចាកចេញ <ph name="TYPE" />។</translation>
@@ -921,6 +927,7 @@
 <translation id="7356610683936413584">ព័ត៌មានលម្អិត​អំពីបញ្ជីពណ៌នា</translation>
 <translation id="7370432716629432284">{COUNT,plural, =1{សញ្ញានឹង}other{# សញ្ញានឹង}}</translation>
 <translation id="737396357417333429">clk</translation>
+<translation id="7388656272362719103">លុប​តួអក្សរ​មុន</translation>
 <translation id="738899727977260036">ប្រផេះចាស់</translation>
 <translation id="7393979322571982935">សំឡេង និង​ការកំណត់</translation>
 <translation id="739763518212184081">បន្ទាត់ពីមុន</translation>
@@ -941,6 +948,7 @@
 <translation id="7533226154149229506">លឿងខ្ចី</translation>
 <translation id="7543255924852002459">លុបចោលស្លាក</translation>
 <translation id="7552432549459840808">ផ្លូវកាត់ Chrome ដែលមានប្រយោជន៍</translation>
+<translation id="7553679324939294712">បញ្ចូល <ph name="INSERT_PHRASE" /> នៅ​ពី​មុខ <ph name="BEFORE_PHRASE" /></translation>
 <translation id="7569983096843329377">ខ្មៅ</translation>
 <translation id="7579911500627256166">ចំណុច <ph name="DOT" /></translation>
 <translation id="7592060599656252486">មួយ​ចំនួន</translation>
@@ -964,6 +972,7 @@
 <translation id="7684431668231950609">កែប្រែអត្ថបទ ធាតុបញ្ចូល URL</translation>
 <translation id="7685589220304187312">tlbar</translation>
 <translation id="7693840228159394336">ប៊ូតុងវិទ្យុពីមុន</translation>
+<translation id="7696631298608145306">ផ្លាស់ទីទៅ​ពាក្យ​បន្ទាប់</translation>
 <translation id="7701040980221191251">គ្មាន</translation>
 <translation id="7701196182766842984">autolst</translation>
 <translation id="7713139339518499741">សំឡេងធម្មជាតិ</translation>
@@ -1071,6 +1080,7 @@
 <translation id="8455868257606149352">អតិបរមា <ph name="X" /></translation>
 <translation id="84575901236241018">មានពាក្យគន្លឹះចូលប្រើ <ph name="KEY" /></translation>
 <translation id="8463645336674919227">កំពុង​ចាកចេញពី​កំហុស​វេយ្យាករណ៍</translation>
+<translation id="8465573210279050749">លុប​ពាក្យ​មុន</translation>
 <translation id="847040613207937740">គ្មានប្រអប់ធីកបន្ទាប់ទេ</translation>
 <translation id="8473540203671727883">អានអត្ថបទនៅផ្នែកខាងក្រោម​កណ្ដុរ</translation>
 <translation id="8476408756881832830">ផ្អាក​ការ​ចាក់​នៅ​ពេល​ដែល​ ChromeVox កំពុង​និយាយ</translation>
@@ -1107,6 +1117,7 @@
 <translation id="8697111817566059991">{COUNT,plural, =1{បំពង់}other{# បំពង់ឈរ}}</translation>
 <translation id="8741370088760768424">តម្រុយ៖ ចុច​ស្វែងរក + ដកឃ្លា ដើម្បី​បើក​ធាតុ​បច្ចុប្បន្ន​។</translation>
 <translation id="8743786158317878347">ចូលមាតិការចនាសម្ព័ន្ធ ដូចជាតារាងជាដើម</translation>
+<translation id="8746846427395705317">ផ្លាស់ទី​ទៅ​ពាក្យ​មុន</translation>
 <translation id="8747966237988593539">បញ្ជីដែលបានតម្រៀប</translation>
 <translation id="8749988712346667988">ប្រាក់</translation>
 <translation id="875769700429317857">បាន​បញ្ចប់​ការទាញយក <ph name="FILE_NAME" /></translation>
@@ -1134,6 +1145,7 @@
 <translation id="8970172509886453271">គ្មានផ្នែកមុនទេ</translation>
 <translation id="89720367119469899">គេច</translation>
 <translation id="8978496506222343566">tltip</translation>
+<translation id="898089897833732740">លុប <ph name="PHRASE" /></translation>
 <translation id="8986362086234534611">បំភ្លេច</translation>
 <translation id="8989104346085848538">ដើម្បី​បញ្ឈប់​ការនិយាយ​បច្ចុប្បន្ន​របស់ ChromeVox សូមចុច​គ្រាប់ចុច Control។</translation>
 <translation id="8993737615451556423">ផ្ដល់ការគ្រប់គ្រង ដើម្បីបង្កើនល្បឿន បន្ថយល្បឿន និងផ្អាកសំឡេងអាន</translation>
diff --git a/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_uz.xtb b/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_uz.xtb
index 2ce2651..53ba3c2 100644
--- a/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_uz.xtb
+++ b/chrome/browser/resources/chromeos/accessibility/strings/accessibility_strings_uz.xtb
@@ -32,6 +32,7 @@
 <translation id="1197088940767939838">Apelsinrang</translation>
 <translation id="1198865190323699001">Sensorli ishoralar</translation>
 <translation id="1201402288615127009">Keyingisi</translation>
+<translation id="1202112913213080585">bekor qilish</translation>
 <translation id="1206619573307042055">marquee</translation>
 <translation id="1207086294218137981">Bundan keyin boshqa 2-darajali sarlavha mavjud emas</translation>
 <translation id="1212770441379271564">Quyidagi tezkor tugmalar ChromeVox buyruqlari emas, lekin Chrome bilan ishlashda juda foydali bo‘ladi:
@@ -42,6 +43,7 @@
     Chrome brauzeri menyusini ochish uchun “Alt + F” tugmalarini bosing.</translation>
 <translation id="1213216066620407844">ChromeVox - Chrome’ga ovoz baxsh etib</translation>
 <translation id="1225969361094801578">Koʻkimtir toʻq kulrang</translation>
+<translation id="122928249241119550">avvalgi gapga oʻtish</translation>
 <translation id="1230503547248836149">Matnni belgilashni boshlash</translation>
 <translation id="1236794971743289975">Yakuniy izoh</translation>
 <translation id="1237797094773582699">Toʻrt barmoq bilan oʻngdan chapga surish kabi avvalgi boʻlimga qaytish mumkin. Hoziroq sinang!</translation>
@@ -212,6 +214,7 @@
 <translation id="2435422727584637732">Xira koʻk</translation>
 <translation id="2438712309510062123">Taklif qilish</translation>
 <translation id="2450814015951372393">Belgilash katakchasi</translation>
+<translation id="2450992626945324272">keyingi gapga oʻtish</translation>
 <translation id="2461822463642141190">Ayni vaqtda</translation>
 <translation id="2462626033734746142">Tanlash tugmalari guruhi</translation>
 <translation id="2467741090055146971">tanlovni bekor qilish</translation>
@@ -488,6 +491,7 @@
 <translation id="42164919740161077">Eski gumbazrang</translation>
 <translation id="4217571870635786043">Ovoz bilan yozish</translation>
 <translation id="4218529045364428769">{COUNT,plural, =1{tire belgisi}other{# ta tire belgisi}}</translation>
+<translation id="4220024144662591089"><ph name="START_PHRASE" /> — <ph name="END_PHRASE" /> dan tanlash</translation>
 <translation id="4221012616705981690">Bundan oldin boshqa roʻyxat mavjud emas</translation>
 <translation id="4225355998815256469">Shakl sozlamalari</translation>
 <translation id="4230834257931120629">Och koʻkimtir kulrang</translation>
@@ -758,6 +762,7 @@
 <translation id="611827076493383239">vtd</translation>
 <translation id="6122013438240733403">btn</translation>
 <translation id="6132506484792346370">Oddiy yoki birlashgan ro‘yxat</translation>
+<translation id="613344593214611552">avvalgi gapni oʻchirish</translation>
 <translation id="6142308968191113180">4-darajali sarlavha</translation>
 <translation id="6150023170003443621">Yorqin yashil</translation>
 <translation id="6158882249329863701"><ph name="TABLECELLROWINDEX" />-qator <ph name="TABLECELLCOLUMNINDEX" />-ustun</translation>
@@ -767,6 +772,7 @@
 <translation id="6186305613600865047">Sahifaning oxiriga o‘tish</translation>
 <translation id="6187190722927752226">Och dengizrang</translation>
 <translation id="6197361807490522975">Toʻq moviy</translation>
+<translation id="6218813441317556731"><ph name="DELETE_PHRASE" /> iborasini <ph name="INSERT_PHRASE" />ga almashtirish</translation>
 <translation id="6236061028292614533">Keyingi sarlavha</translation>
 <translation id="6254901459154107917">Keyingi matn tahrirlash qatori</translation>
 <translation id="6259464875943891919"><ph name="TYPE" /> konteyneridan chiqish.</translation>
@@ -920,6 +926,7 @@
 <translation id="7356610683936413584">Tavsif roʻyxat elementi</translation>
 <translation id="7370432716629432284">{COUNT,plural, =1{ampersand}other{# ta ampersand}}</translation>
 <translation id="737396357417333429">clk</translation>
+<translation id="7388656272362719103">avvalgi belgini oʻchirish</translation>
 <translation id="738899727977260036">Koʻkimtir kulrang</translation>
 <translation id="7393979322571982935">Tovushlar va sozlamalar</translation>
 <translation id="739763518212184081">Avvalgi qator</translation>
@@ -940,6 +947,7 @@
 <translation id="7533226154149229506">Oqimtir sariq</translation>
 <translation id="7543255924852002459">“Bekor qilish” tugmasi</translation>
 <translation id="7552432549459840808">Foydali Chrome tezkor tugmalari</translation>
+<translation id="7553679324939294712"><ph name="INSERT_PHRASE" /> iborasini <ph name="BEFORE_PHRASE" /> dan avval joylash</translation>
 <translation id="7569983096843329377">Qora</translation>
 <translation id="7579911500627256166">nuqta <ph name="DOT" /></translation>
 <translation id="7592060599656252486">Ayrimlar</translation>
@@ -963,6 +971,7 @@
 <translation id="7684431668231950609">Matnni tahrirlash, URL manzil</translation>
 <translation id="7685589220304187312">tlbar</translation>
 <translation id="7693840228159394336">Avvalgi tanlash tugmasi</translation>
+<translation id="7696631298608145306">keyingi soʻzga oʻtish</translation>
 <translation id="7701040980221191251">Hech qanday</translation>
 <translation id="7701196182766842984">autolst</translation>
 <translation id="7713139339518499741">Tabiiy ovoz</translation>
@@ -1070,6 +1079,7 @@
 <translation id="8455868257606149352">Maks <ph name="X" /></translation>
 <translation id="84575901236241018"><ph name="KEY" /> ruxsat kaliti bor</translation>
 <translation id="8463645336674919227">Grammatik xatoni qoldirish</translation>
+<translation id="8465573210279050749">avvalgi soʻzni oʻchirish</translation>
 <translation id="847040613207937740">Keyingi belgilash katakchasi mavjud emas</translation>
 <translation id="8473540203671727883">Sichqoncha ostidagi matnni ovoz chiqarib oʻqish</translation>
 <translation id="8476408756881832830">ChromeVox ekrandan o‘qiyotganda media fayllar ijrosi vaqtincha to‘xtatilsin</translation>
@@ -1106,6 +1116,7 @@
 <translation id="8697111817566059991">{COUNT,plural, =1{vertikal chiziq}other{ # ta vertikal chiziq}}</translation>
 <translation id="8741370088760768424">Maslahat: Joriy elementni faollashtirish uchun Qidiruv + Boʻsh joy tugmalarini bosing.</translation>
 <translation id="8743786158317878347">jadval kabi tartiblangan ma’lumot kiritish</translation>
+<translation id="8746846427395705317">avvalgi soʻzga oʻtish</translation>
 <translation id="8747966237988593539">Tartibli ro‘yxat</translation>
 <translation id="8749988712346667988">Kumushrang</translation>
 <translation id="875769700429317857"><ph name="FILE_NAME" /> fayli yuklab olindi</translation>
@@ -1133,6 +1144,7 @@
 <translation id="8970172509886453271">Bundan oldin boshqa qism mavjud emas</translation>
 <translation id="89720367119469899">O‘chirib qo‘yish</translation>
 <translation id="8978496506222343566">tltip</translation>
+<translation id="898089897833732740"><ph name="PHRASE" /> iborasini oʻchirish</translation>
 <translation id="8986362086234534611">Olib tashlash</translation>
 <translation id="8989104346085848538">ChromeVox nutqini toʻxtatish uchun Control tugmasini bosing.</translation>
 <translation id="8993737615451556423">Oʻqish ovozini tezlatish, sekinlatish va pauza qilish kabi boshqaruv elementlarini chiqaradi</translation>
diff --git a/chrome/browser/resources/chromeos/emoji_picker/emoji_group.js b/chrome/browser/resources/chromeos/emoji_picker/emoji_group.js
index 04f148b..fd0fd15 100644
--- a/chrome/browser/resources/chromeos/emoji_picker/emoji_group.js
+++ b/chrome/browser/resources/chromeos/emoji_picker/emoji_group.js
@@ -34,6 +34,8 @@
     return {
       /** @type {!Array<EmojiVariants>} */
       data: {type: Array, readonly: true},
+      /** @type {?string} */
+      group: {type: String, value: null, readonly: true},
       /** @type {Object<string,string>} */
       preferred: {type: Object, value: () => ({})},
       /** @type {boolean} */
diff --git a/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.html b/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.html
index c53dba9..44871d2 100644
--- a/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.html
+++ b/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.html
@@ -360,19 +360,25 @@
       history is the "recently used" group and is populated in code,
       whereas the other groups are created from the emoji metadata.
     -->
-    <div data-group="history">
-      <template is="dom-if" if="[[emojiHistory.emoji.length]]">
-        <emoji-group data="[[emojiHistory.emoji]]"
-          group="[[emojiHistory.group]]" preferred="{}" clearable
-          class="group history" category="emoji">
+
+    <div data-group="emoji-history">
+      <template is="dom-if"
+        if="[[isHistoryGroupVisible(
+          categoryHistoryVisibility.emoji,
+          categoriesHistory.emoji.data.history)]]">
+        <emoji-group
+          data="[[getHistoryEmojis(categoriesHistory.emoji.data.history)]]"
+          group="Recently used"
+          preferred="{}" clearable class="group history"
+          category="emoji">
         </emoji-group>
       </template>
     </div>
     <template is="dom-repeat" items="[[emojiData]]">
       <div data-group$="[[getDataGroupIndex('emoji', index)]]">
         <emoji-group data="[[item.emoji]]" group="[[item.group]]"
-          preferred="[[preferenceMapping]]" class="group"
-          category="emoji">
+          preferred="{{categoriesHistory.emoji.data.preference}}"
+          class="group" category="emoji">
         </emoji-group>
       </div>
     </template>
@@ -381,11 +387,14 @@
     <template is="dom-if" if="[[v2Enabled]]">
       <div data-group="emoticon-history">
         <template is="dom-if"
-          if="[[_isHistoryReadyToPresent(
-            emojiGroupsFullyLoaded,emoticonHistory.emoji.length)]]">
-            <emoji-group data="[[emoticonHistory.emoji]]"
-              group="[[emoticonHistory.group]]"
-              clearable class="group history"
+          if="[[isHistoryGroupVisible(
+            categoryHistoryVisibility.emoticon,
+            categoriesHistory.emoticon.data.history)]]">
+            <emoji-group
+              data="[[getHistoryEmojis(
+                categoriesHistory.emoticon.data.history)]]"
+              group="Recently used"
+              preferred="{}" clearable class="group history"
               category="emoticon">
             </emoji-group>
         </template>
diff --git a/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.js b/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.js
index 22c9282..393ac77b 100644
--- a/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.js
+++ b/chrome/browser/resources/chromeos/emoji_picker/emoji_picker.js
@@ -21,20 +21,6 @@
 const EMOJI_ORDERING_JSON_TEMPLATE = '/emoji_14_0_ordering';
 const EMOTICON_ORDERING_JSON_TEMPLATE = '/emoticon_ordering.json';
 
-/**
- * Constructs the emoji group data structure from a given list of recent emoji
- * data from localstorage.
- *
- * @param {!Array<StoredItem>} recentEmoji list of recently used emoji strings.
- * @return {!Array<EmojiVariants>} list of emoji data structures
- */
-function makeRecentlyUsed(recentEmoji) {
-  return recentEmoji.map(
-      emoji => ({
-        base: {string: emoji.base, name: emoji.name, keywords: []},
-        alternates: emoji.alternates
-      }));
-}
 
 export class EmojiPicker extends PolymerElement {
   static get is() {
@@ -51,7 +37,7 @@
       emojiDataUrl: {type: String, value: EMOJI_ORDERING_JSON_TEMPLATE},
       /** {string} */
       emoticonDataUrl: {type: String, value: EMOTICON_ORDERING_JSON_TEMPLATE},
-      /** @private {string} */
+      /** @private {CategoryEnum} */
       category: {type: String, value: 'emoji', observer: 'onCategoryChanged'},
       /** @type {string} */
       /** @private {!Array<!SubcategoryData>} */
@@ -66,12 +52,8 @@
       categoriesData: {type: Array, value: () => ([])},
       /** @type {?EmojiGroupData} */
       emoticonData: {type: Array, value: () => ([])},
-      /** @private {Object<string,string>} */
-      preferenceMapping: {type: Object},
-      /** @private {!EmojiGroup} */
-      emojiHistory: {type: Object},
-      /** @private {!EmojiGroup} */
-      emoticonHistory: {type: Object},
+      /** @private {Object<CategoryEnum,RecentlyUsedStore>} */
+      categoriesHistory: {type: Object, value: () => ({})},
       /** @private {number} */
       pagination: {type: Number, value: 1, observer: 'onPaginationChanged'},
       /** @private {string} */
@@ -90,30 +72,21 @@
       /** @private {boolean} */
       searchExtensionEnabled: {type: Boolean, value: false},
       /** @private {boolean} */
-      emojiGroupsFullyLoaded: {type: Boolean, value: false},
+      incognito: {type: Boolean, value: true},
+      /** @private {Object<CategoryEnum,Boolean>} */
+      categoryHistoryVisibility: {type: Object, value: () => ({})},
     };
   }
 
   constructor() {
     super();
 
-    /** @type {!RecentlyUsedStore} */
-    this.recentEmojiStore = new RecentlyUsedStore('emoji-recently-used');
-    /** @type {!RecentlyUsedStore} */
-    this.recentEmoticonStore = new RecentlyUsedStore('emoticon-recently-used');
+    // Incognito mode is set based on the default value.
+    this.updateIncognitoState(this.incognito);
 
     this.emojiGroupTabs = EMOJI_GROUP_TABS;
     this.emojiData = [];
 
-    // TODO(b/216475720): rename the data structure below for a generic naming.
-    this.emojiHistory = {
-      'group': 'Recently used', 'emoji': [], 'category': CategoryEnum.EMOJI};
-    this.emoticonHistory = {
-      'group': 'Recently used', 'emoji': [],
-      'category': CategoryEnum.EMOTICON};
-
-    this.preferenceMapping = {};
-
     /** @private {?number} */
     this.scrollTimeout = null;
 
@@ -150,7 +123,6 @@
         ev => this.onShowEmojiVariants(
             /** @type {!events.EmojiVariantsShownEvent} */ (ev)));
     this.addEventListener('click', () => this.hideDialogs());
-    this.getHistory();
   }
 
   /**
@@ -163,20 +135,9 @@
     };
   }
 
-  async getHistory() {
-    const incognito = (await this.apiProxy_.isIncognitoTextField()).incognito;
-    if (incognito) {
-      this.set(['emojiHistory', 'emoji'], makeRecentlyUsed([]));
-      this.set(['emoticonHistory', 'emoji'], makeRecentlyUsed([]));
-    } else {
-      this.set(
-          ['emojiHistory', 'emoji'],
-          makeRecentlyUsed(this.recentEmojiStore.data.history || []));
-      this.set(
-          ['emoticonHistory', 'emoji'],
-          makeRecentlyUsed(this.recentEmoticonStore.data.history || []));
-      this.set(
-          ['preferenceMapping'], this.recentEmojiStore.getPreferenceMapping());
+  initHistoryUI(incognito) {
+    if (incognito !== this.incognito) {
+      this.updateIncognitoState(incognito);
     }
     this.updateHistoryTabDisabledProperty();
     // Make highlight bar visible (now we know where it should be) and
@@ -193,8 +154,11 @@
     const initializationPromise = Promise.all([
       this.apiProxy_.getFeatureList().then(
           (response) => this.setActiveFeatures(response.featureList)),
-      this.fetchOrderingData(this.emojiDataUrl + '_start.json')
-          .then(data => this.onEmojiDataLoaded(data))
+      this.fetchOrderingData(
+          this.emojiDataUrl + '_start.json').then(
+          data => this.onEmojiDataLoaded(data)),
+      this.apiProxy_.isIncognitoTextField().then(
+          (response) => this.initHistoryUI(response.incognito))
     ]);
 
     initializationPromise.then(() => {
@@ -275,6 +239,9 @@
       emojiGroup.category = category;
     });
 
+    // Allow history group to be visible.
+    this.updateHistoryVisibility(category, true);
+
     // TODO(b/235418846): Remove the following.
     // Update the data variable of the category.
     switch (category) {
@@ -320,36 +287,17 @@
 
   /**
    * @param {CategoryEnum} category
-   * @param {{emoji: string, isVariant: boolean, baseEmoji: string, allVariants:
-   *     !Array<!string>, name: string}} item
+   * @param {{emoji: string, isVariant: boolean, baseEmoji: string,
+   *  allVariants: ?Array<!string>, name: string}} item
    */
   async insertText(category, item) {
     const {text, isVariant, baseEmoji, allVariants, name} = item;
     this.$.message.textContent = text + ' inserted.';
-    const incognito = (await this.apiProxy_.isIncognitoTextField()).incognito;
 
-    if (!incognito) {
-      switch (category) {
-        case CategoryEnum.EMOJI:
-          this.recentEmojiStore.bumpItem(
-              {base: text, alternates: allVariants, name: name});
-          this.recentEmojiStore.savePreferredVariant(baseEmoji, text);
-          this.set(
-              ['emojiHistory', 'emoji'],
-              makeRecentlyUsed(this.recentEmojiStore.data.history));
-          break;
+    this.insertHistoryItem(category,
+      {selectedEmoji: text, baseEmoji: baseEmoji,
+        alternates: allVariants || [], name: name});
 
-        case CategoryEnum.EMOTICON:
-          this.recentEmoticonStore.bumpItem({base: text, name, alternates: []});
-          this.set(
-              ['emoticonHistory', 'emoji'],
-              makeRecentlyUsed(this.recentEmoticonStore.data.history));
-          break;
-
-        default:
-          throw new Error(`Unknown category "${category}."`);
-      }
-    }
     const searchLength =
         /** @type {!CrSearchFieldElement} */ (
             this.$['search-container'].shadowRoot.querySelector(
@@ -362,28 +310,13 @@
   }
 
   clearRecentEmoji(event) {
-    switch (event.detail.category) {
-      case CategoryEnum.EMOJI:
-        this.set(['emojiHistory', 'emoji'], makeRecentlyUsed([]));
-        this.recentEmojiStore.clearRecents();
-        break;
-
-      case CategoryEnum.EMOTICON:
-        this.set(['emoticonHistory', 'emoji'], makeRecentlyUsed([]));
-        this.recentEmoticonStore.clearRecents();
-        break;
-
-      default:
-        throw new Error(
-          'Clear history logic is not implemented ' +
-          `for category "${this.category}."`);
-    }
-
+    const category = event.detail.category;
+    this.clearHistoryData(category);
     afterNextRender(
         this, () => {
           this.updateActiveGroup(/*updateTabsScroll=*/ true);
           this.updateHistoryTabDisabledProperty();
-        });
+    });
   }
 
   /**
@@ -440,7 +373,7 @@
       this.$.tabs.scrollLeft = 0;
       this.scrollToGroup(EMOJI_GROUP_TABS[0].groupId);
       this.groupTabsMoving = true;
-      if (this.emojiHistory.emoji.length > 0) {
+      if (!this.isCategoryHistoryEmpty(CategoryEnum.EMOJI)) {
         this.$.bar.style.left = '0';
       } else {
         this.$.bar.style.left = constants.EMOJI_PICKER_TOTAL_EMOJI_WIDTH_PX;
@@ -534,7 +467,8 @@
     const activeGroup = groupElements.find(
         el => el.getBoundingClientRect().bottom - thisRect.top >= 10);
 
-    const activeGroupId = activeGroup ? activeGroup.dataset.group : 'history';
+    const activeGroupId = activeGroup ?
+        activeGroup.dataset.group : 'emoji-history';
 
     return activeGroupId;
   }
@@ -562,12 +496,8 @@
       this.set(['emojiGroupTabs', i, 'active'], isActive);
     });
 
-    const shouldDeactivateEmojiHistoryTab = this.category === 'emoji' &&
-        index === 0 && this.emojiHistory.emoji.length === 0;
-    const shouldDeactivateEmoticonHistoryTab = this.category === 'emoticon' &&
-        index === 0 && this.emoticonHistory.emoji.length === 0;
     // Ensure that the history tab is not set as active if it is empty.
-    if (shouldDeactivateEmojiHistoryTab || shouldDeactivateEmoticonHistoryTab) {
+    if (index === 0 && this.isCategoryHistoryEmpty(this.category)) {
       this.set(['emojiGroupTabs', 0, 'active'], false);
       this.set(['emojiGroupTabs', 1, 'active'], true);
       index = 1;
@@ -659,25 +589,13 @@
 
   hideDialogs() {
     this.hideEmojiVariants();
-    if (this.emojiHistory.emoji.length > 0) {
-      this.shadowRoot.querySelector(`div[data-group="history"]`)
-          .querySelector('emoji-group')
-          .showClearRecents = false;
-    }
 
-    if (this.emoticonHistory.emoji.length > 0) {
-      /**
-       * When disabling V2, V1 can still access the history even though there
-       * is be no emoticon-history element.
-       * For V2, emoticon can be there but emoji-groups can be loaded later.
-       */
-      const emoticonHistoryElement = this.shadowRoot.querySelector(
-        `div[data-group="emoticon-history"]`);
-      if (emoticonHistoryElement) {
-        const emoticonGroup = emoticonHistoryElement.querySelector(
-          'emoji-group');
-        if (emoticonGroup) {
-          emoticonGroup.showClearRecents = false;
+    for (const category of Object.values(CategoryEnum)) {
+      if (!this.isCategoryHistoryEmpty(category)) {
+        const historyButton = this.shadowRoot.querySelector(
+          `emoji-group.history[category=${category}]`);
+        if (historyButton) {
+          historyButton.showClearRecents = false;
         }
       }
     }
@@ -691,59 +609,155 @@
   }
 
   /**
-   * Returns true when there are history items ("Recently Used") and
-   * the previous groups (e.g. emoji) are already shown. This function
-   * is a helper to implement the logic in the UI components.
-   *
-   * @param {boolean} previousGroupShown A boolean denoting
-   *  whether the previous group is show.
-   * @param {number} historyLength Lengths of the history items.
-   * @returns {boolean}
-   */
-   _isHistoryReadyToPresent(previousGroupShown, historyLength) {
-    return previousGroupShown && historyLength > 0;
-  }
-
-  /**
    * Disables the history tab when there is no usage history for the
    * selected category and enables it otherwise.
    */
   updateHistoryTabDisabledProperty() {
     this.set(
       ['emojiGroupTabs', 0, 'disabled'],
-      this.isCategoryUsageHistoryEmpty(this.category)
-      );
+      this.isCategoryHistoryEmpty(this.category)
+    );
   }
 
   /**
-   * Returns whether the usage history of a give category is empty or not.
-   * @param {string} category Input category.
-   * @returns {boolean}
+   * Sets the visibility of the history group for a category.
+   *
+   * @param {CategoryEnum} category
+   * @param {boolean} visible If history group needs to be visible or hidden.
    */
-  isCategoryUsageHistoryEmpty(category) {
-    return this.getCategoryUsageHistory(this.category).emoji.length === 0;
+  updateHistoryVisibility(category, visible) {
+    // TODO(b/235418846): Remove the func when adding history to emoji groups.
+    this.set(['categoryHistoryVisibility', category], visible);
   }
 
   /**
-   * Returns the usage history instance for a given category.
-   * @param {string} category Input category.
-   * @returns {EmojiGroup} The history instance for the given category.
+   * Checks if history group need to be visible in the UI.
+   *
+   * @param {?boolean} visible True if the history group is allowed to be
+   *    visible.
+   * @param {?Array<StoredItem>} historyDataItems Array of history items.
+   * @returns {?boolean} True if there are history items and group is allowed
+   *    to be visible and False otherwise.
    */
-  getCategoryUsageHistory(category) {
-    // TODO(b/231500029): Simplify the logic after unifying `history` structs.
-    // Histories for different categories (e.g. emoticon and emoji) can be
-    // maintained as a dictionary of Object<CategoryEnum,EmojiGroup> to allow
-    // generalization to more categories without much code duplication. In that
-    // case, the following logic can be  simplified as a dictionary lookup.
+  isHistoryGroupVisible(visible, historyDataItems) {
+    // TODO(b/235418846): Remove the func when adding history to emoji groups.
+    return visible && historyDataItems && historyDataItems.length > 0;
+  }
 
-    switch (category) {
-      case CategoryEnum.EMOJI:
-        return this.emojiHistory;
-      case CategoryEnum.EMOTICON:
-        return this.emoticonHistory;
-      default:
-        throw new Error(`Unknown category "${category}."`);
+  /**
+   * Converts history stored items to list of emojis.
+   *
+   * @param {!Array<StoredItem>} storedItems List of recently used stored
+   *    items.
+   * @return {!Array<EmojiVariants>} List of emojis.
+   */
+  getHistoryEmojis(storedItems) {
+    // TODO(b/235418846): Change the argument to category.
+    if (!storedItems) {
+      return [];
     }
+
+    return storedItems.map(
+      emoji => ({
+        base: {string: emoji.base, name: emoji.name, keywords: []},
+        alternates: emoji.alternates
+    }));
+  }
+
+  /**
+   * Handles the event where history or preferences are modified for a
+   * category.
+   *
+   * @param {CategoryEnum} category Category of the modified history.
+   * @param {boolean} historyUpdated True only if history items are updated.
+   * @param {boolean} preferenceUpdated True only if preferences are updated.
+   */
+  categoryHistoryUpdated(category,
+      historyUpdated = true, preferenceUpdated = true) {
+
+    // TODO(b/235418846): Remove the notifications.
+    // Notify the path that is updated. Manual update is required given
+    // history storage is outside Polymer but HTML depends on it.
+    if(historyUpdated) {
+      this.notifyPath(`categoriesHistory.${category}.data.history`);
+    }
+    if(preferenceUpdated) {
+      this.notifyPath(`categoriesHistory.${category}.data.preference`);
+    }
+  }
+
+  /**
+   * Updates incognito state and variables that needs to be updated by the
+   * change of incognito state.
+   *
+   * @param {boolean} incognito True for incognito mode.
+   */
+  updateIncognitoState(incognito) {
+    this.incognito = incognito;
+
+    // TODO(b/235418846): Remove the dummy history.
+    // Set the recently used to a dummy history for incognito state.
+    // This is used to reduce the complexity for handling of special
+    // case of empty history when rendering the UI.
+    // Note: no data must be saved in the dummy history.
+    const dummyRecentlyUsed = incognito ?
+      new RecentlyUsedStore('dummy-empty-recently-used') : null;
+
+    // Load the history items for each category.
+    for (const category of Object.values(CategoryEnum)) {
+      this.categoriesHistory[category] = incognito ?
+        dummyRecentlyUsed : new RecentlyUsedStore(`${category}-recently-used`);
+      this.categoryHistoryUpdated(category, true, true);
+    }
+  }
+
+  /**
+   * Inserts a new item to the history of a category. It will do nothing during
+   * incognito state.
+   *
+   * @param {CategoryEnum} category
+   * @param {{selectedEmoji: string, baseEmoji: string,
+   *         alternates: !Array<!string>, name: string}} item
+   */
+  insertHistoryItem(category, item) {
+    if (this.incognito) {
+      return;
+    }
+
+    const {selectedEmoji, baseEmoji, alternates, name} = item;
+
+    this.categoriesHistory[category].bumpItem({
+      base: selectedEmoji, alternates: alternates, name: name});
+
+    const preferenceUpdated = this.categoriesHistory[category]
+      .savePreferredVariant(baseEmoji, selectedEmoji);
+
+    this.categoryHistoryUpdated(category, true, preferenceUpdated);
+  }
+
+  /**
+   * Clears history items for a category.
+   *
+   * @param {CategoryEnum} category Category of the history items.
+   */
+  clearHistoryData(category) {
+    if (this.incognito) {
+      return;
+    }
+
+    this.categoriesHistory[category].clearRecents();
+    this.categoryHistoryUpdated(category, true, false);
+  }
+
+  /**
+   * Check if the history items of a category is empty.
+   *
+   * @param {CategoryEnum} category Input category.
+   * @returns {boolean} True for empty history.
+   */
+  isCategoryHistoryEmpty(category) {
+    return this.incognito ||
+        this.categoriesHistory[category].data.history.length == 0;
   }
 
   /**
@@ -825,9 +839,6 @@
     this.updateCategoryData(data, CategoryEnum.EMOJI, !this.v2Enabled);
     this.dispatchEvent(events.createCustomEvent(
       events.EMOJI_REMAINING_DATA_LOADED));
-    afterNextRender(this, () => {
-      this.emojiGroupsFullyLoaded = true;
-    });
   }
 
   /**
@@ -885,15 +896,6 @@
   }
 
   /**
-   * @private
-   * @param {SubcategoryData} tab
-   * @return {boolean}
-   */
-  isNonHistoryTab(tab) {
-    return tab.groupId !== 'history';
-  }
-
-  /**
    * Returns true if the subcategory bar requires text group buttons.
    * @private
    * @param {boolean} v2Enabled
@@ -934,6 +936,7 @@
    * @returns
    */
   getDataGroupIndex(category, offsetIndex) {
+    // TODO(b/235418846): Remove the func after adding history to emoji groups.
     const firstTabByCategory = V2_SUBCATEGORY_TABS.find(
         tab => tab.category === category && !tab.groupId.includes('history'));
     return parseInt(firstTabByCategory.groupId, 10) + offsetIndex;
diff --git a/chrome/browser/resources/chromeos/emoji_picker/metadata_extension.js b/chrome/browser/resources/chromeos/emoji_picker/metadata_extension.js
index 609d023..a85d518a 100644
--- a/chrome/browser/resources/chromeos/emoji_picker/metadata_extension.js
+++ b/chrome/browser/resources/chromeos/emoji_picker/metadata_extension.js
@@ -28,7 +28,7 @@
     name: 'Recently Used',
     icon: 'emoji_picker:schedule',
     category: 'emoji',
-    groupId: 'history',
+    groupId: 'emoji-history',
     active: false,
     disabled: true,
     pagination: 1
diff --git a/chrome/browser/resources/chromeos/emoji_picker/store.js b/chrome/browser/resources/chromeos/emoji_picker/store.js
index b08411a..f1f24457 100644
--- a/chrome/browser/resources/chromeos/emoji_picker/store.js
+++ b/chrome/browser/resources/chromeos/emoji_picker/store.js
@@ -35,12 +35,32 @@
     this.data = load(name);
   }
 
+  /**
+   * Saves preferences for a base emoji.
+   *
+   * @param {string} baseEmoji
+   * @param {string} variant
+   * @returns {boolean} True if any preferences are updated and false
+   *    otherwise.
+   */
   savePreferredVariant(baseEmoji, variant) {
     if (!baseEmoji) {
-      return;
+      return false;
     }
-    this.data.preference[baseEmoji] = variant;
+
+    // Base emoji must not be set as preference. So, store it only
+    // if variant and baseEmoji are different and remove it from preference
+    // otherwise.
+    if (baseEmoji !== variant && variant) {
+      this.data.preference[baseEmoji] = variant;
+    } else if (baseEmoji in this.data.preference) {
+      delete this.data.preference[baseEmoji];
+    } else {
+      return false;
+    }
+
     save(this.storeName, this.data);
+    return true;
   }
 
   getPreferenceMapping() {
diff --git a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.html b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.html
index 6a9157b..fb81c9f 100644
--- a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.html
+++ b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.html
@@ -1,7 +1,31 @@
-<style include="settings-shared"></style>
-<div id="export" class="settings-box first">
+<style include="settings-shared">
+  .container-select {
+    padding: 0 8px;
+  }
+
+  .two-line-settings-box {
+    min-height: 80px;
+  }
+
+  #secondaryText {
+    padding: 3px 0;
+  }
+</style>
+<div id="export"
+  class$="settings-box first [[getSettingsBoxClass_(allContainers_)]]">
   <div id="exportCrostiniLabel" class="start">
     $i18n{crostiniExportLabel}
+    <template is="dom-if" if="[[showContainerSelect_]]" restamp>
+      <div class="secondary" id="secondaryText">
+        Container to backup
+        <settings-crostini-container-select
+          class="container-select"
+          id="exportContainerSelect"
+          containers="[[allContainers_]]"
+          selected-container-id="{{exportContainerId_}}">
+        </settings-crostini-container-select>
+      </div>
+    </template>
   </div>
   <cr-button on-click="onExportClick_" disabled="[[!enableButtons_]]"
     aria-labelledby="exportCrostiniLabel"
@@ -9,9 +33,20 @@
     $i18n{crostiniExport}
   </cr-button>
 </div>
-<div id="import" class="settings-box hr">
+<div id="import" class$="settings-box [[getSettingsBoxClass_(allContainers_)]]">
   <div id="importCrostiniLabel" class="start">
     $i18n{crostiniImportLabel}
+    <template is="dom-if" if="[[showContainerSelect_]]" restamp>
+      <div class="secondary" id="secondaryText">
+        Container to restore
+        <settings-crostini-container-select
+          class="container-select"
+          id="importContainerSelect"
+          containers="[[allContainers_]]"
+          selected-container-id="{{importContainerId_}}">
+        </settings-crostini-container-select>
+      </div>
+    </template>
   </div>
   <cr-button on-click="onImportClick_" disabled="[[!enableButtons_]]"
     aria-labelledby="importCrostiniLabel"
@@ -21,6 +56,7 @@
 </div>
 <template is="dom-if" if="[[showImportConfirmationDialog_]]" restamp>
   <settings-crostini-import-confirmation-dialog
-      on-close="onImportConfirmationDialogClose_">
+      on-close="onImportConfirmationDialogClose_"
+      import-container-id="{{importContainerId_}}">
   </settings-crostini-import-confirmation-dialog>
 </template>
diff --git a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.js b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.js
index 9d0df3a8..365f3b0 100644
--- a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.js
+++ b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_export_import.js
@@ -20,7 +20,8 @@
 import {routes} from '../os_route.js';
 import {RouteObserverBehavior, RouteObserverBehaviorInterface} from '../route_observer_behavior.js';
 
-import {CrostiniBrowserProxy, CrostiniBrowserProxyImpl, DEFAULT_CROSTINI_CONTAINER, DEFAULT_CROSTINI_VM} from './crostini_browser_proxy.js';
+import {ContainerInfo, CrostiniBrowserProxy, CrostiniBrowserProxyImpl, DEFAULT_CONTAINER_ID, GuestId} from './crostini_browser_proxy.js';
+import {equalContainerId} from './crostini_container_select.js';
 
 /**
  * @constructor
@@ -60,7 +61,16 @@
       enableButtons_: {
         type: Boolean,
         computed:
-            'setEnableButtons_(installerShowing_, exportImportInProgress_)',
+            'isEnabledButtons_(installerShowing_, exportImportInProgress_)',
+      },
+
+      /**
+       * Whether the container select element is displayed.
+       * @private {boolean}
+       */
+      showContainerSelect_: {
+        type: Boolean,
+        computed: 'isMultiContainer_(allContainers_)',
       },
 
       /** @private */
@@ -76,6 +86,41 @@
       },
 
       /**
+       * The known containers for display in the UI.
+       * @private {!Array<!ContainerInfo>}
+       */
+      allContainers_: {
+        type: Array,
+        notify: true,
+        value() {
+          return [];
+        },
+      },
+
+      /**
+       * The GuestId of the container to be exported.
+       * @private {!GuestId}
+       */
+      exportContainerId_: {
+        type: Object,
+        value() {
+          return DEFAULT_CONTAINER_ID;
+        },
+      },
+
+      /**
+       * The GuestId of the container to be overwritten by an imported
+       * container file.
+       * @private {!GuestId}
+       */
+      importContainerId_: {
+        type: Object,
+        value() {
+          return DEFAULT_CONTAINER_ID;
+        },
+      },
+
+      /**
        * Used by DeepLinkingBehavior to focus this page's deep links.
        * @type {!Set<!chromeos.settings.mojom.Setting>}
        */
@@ -96,9 +141,9 @@
     this.browserProxy_ = CrostiniBrowserProxyImpl.getInstance();
   }
 
+  /** @override */
   connectedCallback() {
     super.connectedCallback();
-
     this.addWebUIListener(
         'crostini-export-import-operation-status-changed', inProgress => {
           this.exportImportInProgress_ = inProgress;
@@ -107,9 +152,12 @@
         'crostini-installer-status-changed', installerShowing => {
           this.installerShowing_ = installerShowing;
         });
+    this.addWebUIListener(
+        'crostini-container-info', (infos) => this.onContainerInfo_(infos));
 
     this.browserProxy_.requestCrostiniExportImportOperationStatus();
     this.browserProxy_.requestCrostiniInstallerStatus();
+    this.browserProxy_.requestContainerInfo();
   }
 
   /**
@@ -125,12 +173,21 @@
     this.attemptDeepLink();
   }
 
+  /**
+   * @param {!Array<!ContainerInfo>} containerInfos
+   * @private
+   */
+  onContainerInfo_(containerInfos) {
+    this.allContainers_ = containerInfos;
+    if (!this.isMultiContainer_(containerInfos)) {
+      this.exportContainerId_ = DEFAULT_CONTAINER_ID;
+      this.importContainerId_ = DEFAULT_CONTAINER_ID;
+    }
+  }
+
   /** @private */
   onExportClick_() {
-    this.browserProxy_.exportCrostiniContainer({
-      vm_name: DEFAULT_CROSTINI_VM,
-      container_name: DEFAULT_CROSTINI_CONTAINER
-    });
+    this.browserProxy_.exportCrostiniContainer(this.exportContainerId_);
   }
 
   /** @private */
@@ -144,13 +201,29 @@
   }
 
   /**
-   * @param {boolean} installerShowing
-   * @param {boolean} exportImportInProgress
+   * @param {!Boolean} installerShowing
+   * @param {!Boolean} exportImportInProgress
    * @private
    */
-  setEnableButtons_(installerShowing, exportImportInProgress) {
+  isEnabledButtons_(installerShowing, exportImportInProgress) {
     return !(installerShowing || exportImportInProgress);
   }
+
+
+  /**
+   * @param {!Array<!ContainerInfo>} allContainers
+   * @return boolean
+   * @private
+   */
+  isMultiContainer_(allContainers) {
+    return !(
+        allContainers.length === 1 &&
+        equalContainerId(allContainers[0].id, DEFAULT_CONTAINER_ID));
+  }
+
+  getSettingsBoxClass_(allContainers) {
+    return this.isMultiContainer_(allContainers) ? 'two-line-settings-box' : '';
+  }
 }
 
 customElements.define(
diff --git a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_import_confirmation_dialog.js b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_import_confirmation_dialog.js
index d43a26d..51aa8c9 100644
--- a/chrome/browser/resources/settings/chromeos/crostini_page/crostini_import_confirmation_dialog.js
+++ b/chrome/browser/resources/settings/chromeos/crostini_page/crostini_import_confirmation_dialog.js
@@ -13,7 +13,7 @@
 
 import {html, PolymerElement} from 'chrome://resources/polymer/v3_0/polymer/polymer_bundled.min.js';
 
-import {CrostiniBrowserProxy, CrostiniBrowserProxyImpl, DEFAULT_CROSTINI_CONTAINER, DEFAULT_CROSTINI_VM} from './crostini_browser_proxy.js';
+import {CrostiniBrowserProxy, CrostiniBrowserProxyImpl, GuestId} from './crostini_browser_proxy.js';
 
 /** @polymer */
 class SettingsCrostiniImportConfirmationDialogElement extends PolymerElement {
@@ -25,6 +25,15 @@
     return html`{__html_template__}`;
   }
 
+  static get properties() {
+    return {
+      /** @type {!GuestId} */
+      importContainerId: {
+        type: Object,
+      },
+    };
+  }
+
   constructor() {
     super();
 
@@ -46,10 +55,7 @@
 
   /** @private */
   onContinueTap_() {
-    this.browserProxy_.importCrostiniContainer({
-      vm_name: DEFAULT_CROSTINI_VM,
-      container_name: DEFAULT_CROSTINI_CONTAINER
-    });
+    this.browserProxy_.importCrostiniContainer(this.importContainerId);
     this.$.dialog.close();
   }
 }
diff --git a/chrome/browser/resources/settings/privacy_page/privacy_guide/privacy_guide_dialog.html b/chrome/browser/resources/settings/privacy_page/privacy_guide/privacy_guide_dialog.html
index 10651c33..69308ae 100644
--- a/chrome/browser/resources/settings/privacy_page/privacy_guide/privacy_guide_dialog.html
+++ b/chrome/browser/resources/settings/privacy_page/privacy_guide/privacy_guide_dialog.html
@@ -12,7 +12,6 @@
   #dialog {
     background-color: var(--cr-card-background-color);
     border: 0;
-    display: block;
     height: 100vh;
     margin: 0;
     max-height: 100vh;
@@ -21,6 +20,10 @@
     width: 100vw;
   }
 
+  #dialog[open] {
+    display: block;
+  }
+
   settings-privacy-guide-page::part(privacyGuideCard) {
     background-color: transparent;
     box-shadow: none;
diff --git a/chrome/browser/resources/settings/privacy_page/privacy_page.ts b/chrome/browser/resources/settings/privacy_page/privacy_page.ts
index 98a6d4a2..58f04f7 100644
--- a/chrome/browser/resources/settings/privacy_page/privacy_page.ts
+++ b/chrome/browser/resources/settings/privacy_page/privacy_page.ts
@@ -353,7 +353,7 @@
   }
 
   private onPrivacyGuideDialogClosed_() {
-    Router.getInstance().navigateTo(routes.PRIVACY_GUIDE.parent!);
+    Router.getInstance().navigateToPreviousRoute();
     const toFocus = this.shadowRoot!.querySelector('#privacyGuideLinkRow');
     assert(toFocus);
     focusWithoutInk(toFocus);
diff --git a/chrome/browser/shared_highlighting/shared_highlighting_browsertest.cc b/chrome/browser/shared_highlighting/shared_highlighting_browsertest.cc
index 7194878..4c6f321f 100644
--- a/chrome/browser/shared_highlighting/shared_highlighting_browsertest.cc
+++ b/chrome/browser/shared_highlighting/shared_highlighting_browsertest.cc
@@ -252,9 +252,10 @@
   base::RunLoop run_loop_;
 };
 
-#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN) || BUILDFLAG(IS_CHROMEOS_LACROS)
+#if BUILDFLAG(IS_MAC) || BUILDFLAG(IS_WIN) || BUILDFLAG(IS_CHROMEOS_LACROS) || \
+    BUILDFLAG(IS_LINUX)
 // Disabled because it fails for mac specific context menu:
-// TODO(crbug.com/1275253): Flakily crashes under Windows and Mac.
+// TODO(crbug.com/1275253): Flakily crashes under Windows and Mac & Linux.
 // TODO(crbug.com/1276463): Flakily crashes under lacros.
 #define MAYBE_LinkGenerationTest DISABLED_LinkGenerationTest
 #else
diff --git a/chrome/browser/ui/BUILD.gn b/chrome/browser/ui/BUILD.gn
index 5b6801d..b93b7391 100644
--- a/chrome/browser/ui/BUILD.gn
+++ b/chrome/browser/ui/BUILD.gn
@@ -3139,6 +3139,7 @@
       "//chromeos/ash/components/dbus/session_manager",
       "//chromeos/ash/components/dbus/spaced",
       "//chromeos/ash/components/dbus/system_clock",
+      "//chromeos/ash/components/dbus/update_engine",
       "//chromeos/ash/components/dbus/upstart",
       "//chromeos/ash/components/dbus/userdataauth",
       "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
@@ -3169,7 +3170,6 @@
       "//chromeos/dbus/power",
       "//chromeos/dbus/tpm_manager",
       "//chromeos/dbus/tpm_manager:tpm_manager_proto",
-      "//chromeos/dbus/update_engine",
       "//chromeos/dbus/util",
       "//chromeos/login/login_state",
       "//chromeos/network",
diff --git a/chrome/browser/ui/android/strings/translations/android_chrome_strings_it.xtb b/chrome/browser/ui/android/strings/translations/android_chrome_strings_it.xtb
index 4c44dffd..fc6df9c 100644
--- a/chrome/browser/ui/android/strings/translations/android_chrome_strings_it.xtb
+++ b/chrome/browser/ui/android/strings/translations/android_chrome_strings_it.xtb
@@ -912,10 +912,10 @@
 <translation id="6000203700195075278">Segui di nuovo</translation>
 <translation id="6002122790816966947">I tuoi dispositivi</translation>
 <translation id="6005538289190791541">Password consigliata</translation>
-<translation id="6032091552407840792">Questa prova è attiva soltanto in <ph name="BEGIN_LINK" />alcune aree geografiche<ph name="END_LINK" />.</translation>
+<translation id="6032091552407840792">Questa prova è attiva soltanto in <ph name="BEGIN_LINK" />alcune regioni<ph name="END_LINK" />.</translation>
 <translation id="6033245666633565791">Con <ph name="BEGIN_LINK" />Privacy Sandbox<ph name="END_LINK" />, Chrome sviluppa nuove tecnologie che ti tutelano dai meccanismi di tracciamento tra siti salvaguardando al contempo il Web aperto.
 
-Le prove di Privacy Sandbox sono ancora in fase di sviluppo attivo e sono disponibili soltanto in alcune aree geografiche. Per il momento i siti possono provare Privacy Sandbox continuando a usare le attuali tecnologie web quali i cookie di terze parti.</translation>
+Le prove di Privacy Sandbox sono ancora in fase di sviluppo attivo e sono disponibili soltanto in alcune regioni. Per il momento i siti possono provare Privacy Sandbox continuando a usare le attuali tecnologie web quali i cookie di terze parti.</translation>
 <translation id="6039379616847168523">Vai alla scheda successiva</translation>
 <translation id="6040143037577758943">Chiudi</translation>
 <translation id="604124094241169006">Automatico</translation>
diff --git a/chrome/browser/ui/android/strings/translations/android_chrome_strings_km.xtb b/chrome/browser/ui/android/strings/translations/android_chrome_strings_km.xtb
index f02fcc6b..7033e0af6ef 100644
--- a/chrome/browser/ui/android/strings/translations/android_chrome_strings_km.xtb
+++ b/chrome/browser/ui/android/strings/translations/android_chrome_strings_km.xtb
@@ -443,6 +443,7 @@
 <translation id="3334729583274622784">ប្ដូរកន្ទុយ​ឯកសារឬ?</translation>
 <translation id="3341262203274374114">មិនអាចឈប់​តាមដានបានទេ។ មានអ្វីមួយខុសប្រក្រតី។</translation>
 <translation id="3359667936385849800">ប្រើ​ក្រុមហ៊ុនផ្ដល់សេវាបច្ចុប្បន្ន​របស់អ្នក</translation>
+<translation id="3365271666488085187">Chrome អាច​ពិចារណា​ចំណាប់​អារម្មណ៍​នេះ</translation>
 <translation id="3367813778245106622">ចូលគណនីម្តងទៀតដើម្បីចាប់ផ្តើមសមកាលកម្ម</translation>
 <translation id="3373979091428520308">ដើម្បី​ចែករំលែក​ទំព័រនេះជាមួយឧបករណ៍​ផ្សេង សូមបើក​សមកាលកម្មនៅក្នុងការកំណត់ Chrome នៅលើឧបករណ៍​ផ្សេងទៀត</translation>
 <translation id="3374023511497244703">ចំណាំ​ ប្រវត្តិ ​ពាក្យសម្ងាត់ និងទិន្នន័យ Chrome ផ្សេងទៀត​របស់អ្នកនឹងមិន​ធ្វើ​សម​កាល​កម្មទៅក្នុងគណនី​ Google របស់អ្នកទៀតទេ</translation>
@@ -476,6 +477,7 @@
 <translation id="3542235761944717775">ទំនេរ <ph name="KILOBYTES" /> KB</translation>
 <translation id="3549657413697417275">ស្វែងរក​ប្រវត្តិ​របស់អ្នក</translation>
 <translation id="3557336313807607643">បញ្ចូល​ទៅ​ក្នុង​ទំនាក់ទំនង</translation>
+<translation id="3560491354538957576">គេហទំព័រ​អាច​កំណត់​ចំណាប់​អារម្មណ៍</translation>
 <translation id="3563767357928833671">ខ្លឹមសារឃ្លីបបតត្រូវបានបង្ហាញ</translation>
 <translation id="3566923219790363270">Chrome កំពុងរៀបចំសម្រាប់ VR នៅឡើយ។ ចាប់ផ្តើម Chrome ឡើងវិញនៅពេលក្រោយ។</translation>
 <translation id="3568688522516854065">ដើម្បីទទួលបានផ្ទាំងរបស់អ្នកពីឧបករណ៍ផ្សេងទៀតរបស់អ្នក សូមចូល​គណនី និងបើកសមកាលកម្ម</translation>
diff --git a/chrome/browser/ui/android/strings/translations/android_chrome_strings_uz.xtb b/chrome/browser/ui/android/strings/translations/android_chrome_strings_uz.xtb
index 9bd9c6e..afe4f55 100644
--- a/chrome/browser/ui/android/strings/translations/android_chrome_strings_uz.xtb
+++ b/chrome/browser/ui/android/strings/translations/android_chrome_strings_uz.xtb
@@ -443,6 +443,7 @@
 <translation id="3334729583274622784">Fayl kengaytmasi oʻzgartirilsinmi?</translation>
 <translation id="3341262203274374114">Obuna bekor qilinmadi. Xatolik yuz berdi.</translation>
 <translation id="3359667936385849800">Joriy xizmat provayderingiz orqali</translation>
+<translation id="3365271666488085187">Chrome bu qiziqishni taxmin qilishi mumkin</translation>
 <translation id="3367813778245106622">Yana sinxronlashni boshlash uchun hisobingizga kiring</translation>
 <translation id="3373979091428520308">Bu sahifani boshqa qurilmaga ulashish uchun oʻsha qurilmadagi Chrome sozlamalarida sinxronizatsiyani yoqing</translation>
 <translation id="3374023511497244703">Bukmarklar, tarix, parollar va boshqa Chrome maʼlumotlaringiz bilan Google hisobingiz sinxronizatsiyasi uziladi</translation>
@@ -476,6 +477,7 @@
 <translation id="3542235761944717775"><ph name="KILOBYTES" /> KB bo‘sh</translation>
 <translation id="3549657413697417275">Tarix ichidan qidirish</translation>
 <translation id="3557336313807607643">Kontaktlarga saqlash</translation>
+<translation id="3560491354538957576">Sayt qiziqishlarni taxmin qilishi mumkin</translation>
 <translation id="3563767357928833671">Vaqtincha xotira kontenti chiqarildi</translation>
 <translation id="3566923219790363270">Chrome hali ham VR rejimga tayyorlanmoqda. Chromeni keyinroq qayta ishga tushirish.</translation>
 <translation id="3568688522516854065">Boshqa qurilmalaringizdagi brauzer sahifalarini ko‘rish uchun hisobingizga kiring va sinxronizatsiyani yoqing</translation>
diff --git a/chrome/browser/ui/app_list/search/app_search_provider_unittest.cc b/chrome/browser/ui/app_list/search/app_search_provider_unittest.cc
index 993235f..d458cb3 100644
--- a/chrome/browser/ui/app_list/search/app_search_provider_unittest.cc
+++ b/chrome/browser/ui/app_list/search/app_search_provider_unittest.cc
@@ -41,10 +41,10 @@
 #include "chrome/browser/web_applications/web_app_id_constants.h"
 #include "chrome/common/chrome_constants.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/crx_file/id_util.h"
 #include "components/services/app_service/public/cpp/app_types.h"
@@ -644,7 +644,7 @@
  public:
   void SetUp() override {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -663,7 +663,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 };
diff --git a/chrome/browser/ui/ash/chrome_browser_main_extra_parts_ash.cc b/chrome/browser/ui/ash/chrome_browser_main_extra_parts_ash.cc
index e6051e6..2e17e6d5 100644
--- a/chrome/browser/ui/ash/chrome_browser_main_extra_parts_ash.cc
+++ b/chrome/browser/ui/ash/chrome_browser_main_extra_parts_ash.cc
@@ -61,10 +61,10 @@
 #include "chrome/browser/ui/views/select_file_dialog_extension.h"
 #include "chrome/browser/ui/views/select_file_dialog_extension_factory.h"
 #include "chrome/browser/ui/views/tabs/tab_scrubber_chromeos.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/components/quick_answers/public/cpp/controller/quick_answers_controller.h"
 #include "chromeos/components/quick_answers/quick_answers_client.h"
-#include "chromeos/network/network_connect.h"
 #include "chromeos/services/bluetooth_config/fast_pair_delegate.h"
 #include "chromeos/services/bluetooth_config/in_process_instance.h"
 #include "components/crash/core/common/crash_key.h"
diff --git a/chrome/browser/ui/ash/clipboard_history_browsertest.cc b/chrome/browser/ui/ash/clipboard_history_browsertest.cc
index 9e724afc..a9f44d1e 100644
--- a/chrome/browser/ui/ash/clipboard_history_browsertest.cc
+++ b/chrome/browser/ui/ash/clipboard_history_browsertest.cc
@@ -1093,8 +1093,9 @@
 
 // Verify that the clipboard data history is recorded as expected in the
 // Multiuser environment.
+// TODO(http://crbug.com/1341601): Flakily crashes under ChromeOS
 IN_PROC_BROWSER_TEST_F(ClipboardHistoryMultiProfileBrowserTest,
-                       VerifyClipboardHistoryAcrossMultiUser) {
+                       DISABLED_VerifyClipboardHistoryAcrossMultiUser) {
   EXPECT_TRUE(GetClipboardItems().empty());
 
   // Store text when the user1 is active.
diff --git a/chrome/browser/ui/ash/network/mobile_data_notifications.cc b/chrome/browser/ui/ash/network/mobile_data_notifications.cc
index bf241346..2b42a88 100644
--- a/chrome/browser/ui/ash/network/mobile_data_notifications.cc
+++ b/chrome/browser/ui/ash/network/mobile_data_notifications.cc
@@ -17,8 +17,8 @@
 #include "chrome/browser/ui/ash/system_tray_client_impl.h"
 #include "chrome/common/pref_names.h"
 #include "chrome/grit/generated_resources.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_type_pattern.h"
 #include "components/prefs/pref_service.h"
diff --git a/chrome/browser/ui/ash/network/mobile_data_notifications.h b/chrome/browser/ui/ash/network/mobile_data_notifications.h
index 86bee78..f0551aa5 100644
--- a/chrome/browser/ui/ash/network/mobile_data_notifications.h
+++ b/chrome/browser/ui/ash/network/mobile_data_notifications.h
@@ -11,7 +11,7 @@
 #include "base/memory/weak_ptr.h"
 #include "base/scoped_observation.h"
 #include "base/timer/timer.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "components/session_manager/core/session_manager_observer.h"
diff --git a/chrome/browser/ui/ash/network/mobile_data_notifications_unittest.cc b/chrome/browser/ui/ash/network/mobile_data_notifications_unittest.cc
index 75e1c42..e665606 100644
--- a/chrome/browser/ui/ash/network/mobile_data_notifications_unittest.cc
+++ b/chrome/browser/ui/ash/network/mobile_data_notifications_unittest.cc
@@ -18,10 +18,10 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile_manager.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_connect.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/pref_service.h"
 #include "components/session_manager/core/session_manager.h"
diff --git a/chrome/browser/ui/ash/network/network_connect_delegate_chromeos.h b/chrome/browser/ui/ash/network/network_connect_delegate_chromeos.h
index a0435a92..d1429a0 100644
--- a/chrome/browser/ui/ash/network/network_connect_delegate_chromeos.h
+++ b/chrome/browser/ui/ash/network/network_connect_delegate_chromeos.h
@@ -8,7 +8,7 @@
 #include <memory>
 #include <string>
 
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 
 namespace ash {
 class SystemTrayClient;
diff --git a/chrome/browser/ui/ash/network/network_state_notifier.cc b/chrome/browser/ui/ash/network/network_state_notifier.cc
index 4099d27..dd3e3c3a 100644
--- a/chrome/browser/ui/ash/network/network_state_notifier.cc
+++ b/chrome/browser/ui/ash/network/network_state_notifier.cc
@@ -17,9 +17,9 @@
 #include "chrome/browser/notifications/system_notification_helper.h"
 #include "chrome/grit/generated_resources.h"
 #include "chromeos/ash/components/network/cellular_esim_profile_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connect.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_name_util.h"
 #include "chromeos/network/network_state.h"
diff --git a/chrome/browser/ui/ash/network/network_state_notifier.h b/chrome/browser/ui/ash/network/network_state_notifier.h
index 34ef79db3..a92e55b 100644
--- a/chrome/browser/ui/ash/network/network_state_notifier.h
+++ b/chrome/browser/ui/ash/network/network_state_notifier.h
@@ -14,7 +14,7 @@
 #include "base/scoped_observation.h"
 #include "base/time/time.h"
 #include "base/values.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/chrome/browser/ui/ash/network/network_state_notifier_unittest.cc b/chrome/browser/ui/ash/network/network_state_notifier_unittest.cc
index 7a9c239b..975d881 100644
--- a/chrome/browser/ui/ash/network/network_state_notifier_unittest.cc
+++ b/chrome/browser/ui/ash/network/network_state_notifier_unittest.cc
@@ -16,12 +16,12 @@
 #include "chrome/test/base/browser_with_test_window_test.h"
 #include "chrome/test/base/testing_browser_process.h"
 #include "chromeos/ash/components/network/cellular_metrics_logger.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_connect.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/testing_pref_service.h"
diff --git a/chrome/browser/ui/ash/network/tether_notification_presenter.cc b/chrome/browser/ui/ash/network/tether_notification_presenter.cc
index 37dd4e20e..625f8b7 100644
--- a/chrome/browser/ui/ash/network/tether_notification_presenter.cc
+++ b/chrome/browser/ui/ash/network/tether_notification_presenter.cc
@@ -22,7 +22,7 @@
 #include "chrome/common/url_constants.h"
 #include "chrome/common/webui_url_constants.h"
 #include "chrome/grit/generated_resources.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "ui/base/l10n/l10n_util.h"
 #include "ui/gfx/color_palette.h"
 #include "ui/gfx/image/image.h"
diff --git a/chrome/browser/ui/ash/network/tether_notification_presenter_unittest.cc b/chrome/browser/ui/ash/network/tether_notification_presenter_unittest.cc
index e33b3b34..726279a 100644
--- a/chrome/browser/ui/ash/network/tether_notification_presenter_unittest.cc
+++ b/chrome/browser/ui/ash/network/tether_notification_presenter_unittest.cc
@@ -15,7 +15,7 @@
 #include "chrome/common/url_constants.h"
 #include "chrome/test/base/browser_with_test_window_test.h"
 #include "chrome/test/base/testing_profile.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 
 namespace {
 const int kTestNetworkSignalStrength = 50;
diff --git a/chrome/browser/ui/ash/shelf/shelf_context_menu_unittest.cc b/chrome/browser/ui/ash/shelf/shelf_context_menu_unittest.cc
index bad84465..329439f 100644
--- a/chrome/browser/ui/ash/shelf/shelf_context_menu_unittest.cc
+++ b/chrome/browser/ui/ash/shelf/shelf_context_menu_unittest.cc
@@ -50,10 +50,10 @@
 #include "chrome/common/chrome_switches.h"
 #include "chrome/test/base/chrome_ash_test_base.h"
 #include "chrome/test/base/testing_profile.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 #include "chromeos/ash/components/dbus/cicerone/cicerone_client.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
 #include "chromeos/ash/components/dbus/seneschal/seneschal_client.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "components/exo/shell_surface_util.h"
 #include "components/prefs/pref_service.h"
@@ -106,7 +106,7 @@
 
   void SetUp() override {
     chromeos::DBusThreadManager::Initialize();
-    chromeos::ChunneldClient::InitializeFake();
+    ash::ChunneldClient::InitializeFake();
     ash::CiceroneClient::InitializeFake();
     ash::ConciergeClient::InitializeFake();
     ash::SeneschalClient::InitializeFake();
@@ -212,7 +212,7 @@
     ash::SeneschalClient::Shutdown();
     ash::ConciergeClient::Shutdown();
     ash::CiceroneClient::Shutdown();
-    chromeos::ChunneldClient::Shutdown();
+    ash::ChunneldClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
diff --git a/chrome/browser/ui/find_bar/find_bar_host_browsertest.cc b/chrome/browser/ui/find_bar/find_bar_host_browsertest.cc
index f4f0b05..6fae00f 100644
--- a/chrome/browser/ui/find_bar/find_bar_host_browsertest.cc
+++ b/chrome/browser/ui/find_bar/find_bar_host_browsertest.cc
@@ -1476,8 +1476,15 @@
             popup->window()->GetBounds().width());
 }
 
+#if BUILDFLAG(IS_CHROMEOS_LACROS)
+// TODO(crbug.com/1341599): Flakily crashes on Lacros.
+#define MAYBE_FindMovesOnTabClose_Issue1343052 \
+  DISABLED_FindMovesOnTabClose_Issue1343052
+#else
+#define MAYBE_FindMovesOnTabClose_Issue1343052 FindMovesOnTabClose_Issue1343052
+#endif
 IN_PROC_BROWSER_TEST_F(FindInPageControllerTest,
-                       FindMovesOnTabClose_Issue1343052) {
+                       MAYBE_FindMovesOnTabClose_Issue1343052) {
   EnsureFindBoxOpen();
   content::RunAllPendingInMessageLoop();  // Needed on Linux.
 
diff --git a/chrome/browser/ui/views/frame/browser_non_client_frame_view.cc b/chrome/browser/ui/views/frame/browser_non_client_frame_view.cc
index cfb9a2f..de46593 100644
--- a/chrome/browser/ui/views/frame/browser_non_client_frame_view.cc
+++ b/chrome/browser/ui/views/frame/browser_non_client_frame_view.cc
@@ -6,6 +6,7 @@
 
 #include "base/metrics/histogram_macros.h"
 #include "build/build_config.h"
+#include "build/buildflag.h"
 #include "build/chromeos_buildflags.h"
 #include "chrome/app/vector_icons/vector_icons.h"
 #include "chrome/browser/browser_process.h"
@@ -39,6 +40,8 @@
 
 #if BUILDFLAG(IS_WIN)
 #include "chrome/browser/taskbar/taskbar_decorator_win.h"
+#include "ui/display/win/screen_win.h"
+#include "ui/views/win/hwnd_util.h"
 #endif
 
 // static
@@ -325,6 +328,25 @@
 }
 
 #if BUILDFLAG(IS_WIN)
+// Sending the WM_NCPOINTERDOWN, WM_NCPOINTERUPDATE, and WM_NCPOINTERUP to the
+// default window proc does not bring up the system menu on long press, so we
+// use the gesture recognizer to turn it into a LONG_TAP gesture and handle it
+// here. See https://crbug.com/1327506 for more info.
+void BrowserNonClientFrameView::OnGestureEvent(ui::GestureEvent* event) {
+  gfx::Point event_loc = event->location();
+  // This opens the title bar system context menu on long press in the titlebar.
+  // NonClientHitTest returns HTCAPTION if `event_loc` is in the empty space on
+  // the titlebar.
+  if (event->type() == ui::ET_GESTURE_LONG_TAP &&
+      NonClientHitTest(event_loc) == HTCAPTION) {
+    views::View::ConvertPointToScreen(this, &event_loc);
+    event_loc = display::win::ScreenWin::DIPToScreenPoint(event_loc);
+    views::ShowSystemMenuAtScreenPixelLocation(views::HWNDForView(this),
+                                               event_loc);
+    event->SetHandled();
+  }
+}
+
 int BrowserNonClientFrameView::GetSystemMenuY() const {
   if (!browser_view()->GetTabStripVisible())
     return GetTopInset(false);
@@ -333,7 +355,7 @@
              .bottom() -
          GetLayoutConstant(TABSTRIP_TOOLBAR_OVERLAP);
 }
-#endif
+#endif  // BUILDFLAG(IS_WIN)
 
 BEGIN_METADATA(BrowserNonClientFrameView, views::NonClientFrameView)
 END_METADATA
diff --git a/chrome/browser/ui/views/frame/browser_non_client_frame_view.h b/chrome/browser/ui/views/frame/browser_non_client_frame_view.h
index 9e106494..d113479 100644
--- a/chrome/browser/ui/views/frame/browser_non_client_frame_view.h
+++ b/chrome/browser/ui/views/frame/browser_non_client_frame_view.h
@@ -180,10 +180,13 @@
   }
 
  private:
-  // views::NonClientFrameView:
 #if BUILDFLAG(IS_WIN)
+  // ui::EventHandler:
+  void OnGestureEvent(ui::GestureEvent* event) override;
+
+  // views::NonClientFrameView:
   int GetSystemMenuY() const override;
-#endif
+#endif  // BUILDFLAG(IS_WIN)
 
   // The frame that hosts this view.
   const raw_ptr<BrowserFrame> frame_;
diff --git a/chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.cc b/chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.cc
index d4648e1..a628c17 100644
--- a/chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.cc
+++ b/chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.cc
@@ -2117,8 +2117,15 @@
   EXPECT_FALSE(tab_strip->GetWidget()->HasCapture());
 }
 
+// TODO(crbug.com/1341444) Flaky on lacros.
+#if BUILDFLAG(IS_CHROMEOS_LACROS)
+#define MAYBE_TabDragContextOwnsDraggedTabs \
+  DISABLED_TabDragContextOwnsDraggedTabs
+#else
+#define MAYBE_TabDragContextOwnsDraggedTabs TabDragContextOwnsDraggedTabs
+#endif
 IN_PROC_BROWSER_TEST_P(DetachToBrowserTabDragControllerTest,
-                       TabDragContextOwnsDraggedTabs) {
+                       MAYBE_TabDragContextOwnsDraggedTabs) {
   AddTabsAndResetBrowser(browser(), 1);
 
   TabStrip* tab_strip = GetTabStripForBrowser(browser());
diff --git a/chrome/browser/ui/web_applications/web_app_browsertest.cc b/chrome/browser/ui/web_applications/web_app_browsertest.cc
index c891c24..3e7a2824 100644
--- a/chrome/browser/ui/web_applications/web_app_browsertest.cc
+++ b/chrome/browser/ui/web_applications/web_app_browsertest.cc
@@ -333,69 +333,78 @@
   EXPECT_EQ(provider->registrar().GetAppThemeColor(app_id), SK_ColorGREEN);
 }
 
-// Enumeration of test modes for `BackgroundColorChangeWebAppBrowserTest`s.
-enum class BackgroundColorChangeTestMode {
-  kSWA,
-  kNonSWA,
-};
+// Also see BackgroundColorChangeSystemWebAppBrowserTest.BackgroundColorChange
+// below.
+IN_PROC_BROWSER_TEST_F(WebAppBrowserTest, BackgroundColorChange) {
+  const GURL app_url = GetSecureAppURL();
+  auto web_app_info = std::make_unique<WebAppInstallInfo>();
+  web_app_info->start_url = app_url;
+  web_app_info->scope = app_url.GetWithoutFilename();
+  web_app_info->theme_color = SK_ColorWHITE;
+  web_app_info->dark_mode_theme_color = SK_ColorBLACK;
+  web_app_info->background_color = SK_ColorWHITE;
+  web_app_info->dark_mode_background_color = SK_ColorBLACK;
 
-// Base class for `BackgroundColorChange` tests, parameterized by test mode and
-// whether to prefer manifest background color.
-class BackgroundColorChangeWebAppBrowserTest
+  const AppId app_id = InstallWebApp(std::move(web_app_info));
+
+  Browser* const app_browser = LaunchWebAppBrowser(app_id);
+  content::WebContents* const web_contents =
+      app_browser->tab_strip_model()->GetActiveWebContents();
+
+  // Wait for original background color to load.
+  {
+    content::BackgroundColorChangeWaiter waiter(web_contents);
+    waiter.Wait();
+    EXPECT_EQ(app_browser->app_controller()->GetBackgroundColor().value(),
+              SK_ColorWHITE);
+  }
+  content::AwaitDocumentOnLoadCompleted(web_contents);
+
+  // Changing background color should update the toolbar color.
+  {
+    content::BackgroundColorChangeWaiter waiter(web_contents);
+    EXPECT_TRUE(content::ExecuteScript(
+        web_contents, "document.body.style.backgroundColor = 'cyan';"));
+    waiter.Wait();
+    EXPECT_EQ(app_browser->app_controller()->GetBackgroundColor().value(),
+              SK_ColorCYAN);
+    SkColor download_shelf_color;
+    app_browser->app_controller()->GetThemeSupplier()->GetColor(
+        ThemeProperties::COLOR_TOOLBAR, &download_shelf_color);
+    EXPECT_EQ(download_shelf_color, SK_ColorCYAN);
+  }
+}
+
+// TODO(crbug.com/1321984): Make is Ash only using BUILDFLAG(IS_CHROMEOS_ASH).
+class BackgroundColorChangeSystemWebAppBrowserTest
     : public WebAppBrowserTest,
       public testing::WithParamInterface<
-          std::tuple<BackgroundColorChangeTestMode,
-                     /*prefer_manifest_background_color=*/bool>> {
+          /*prefer_manifest_background_color=*/bool> {
  public:
-  BackgroundColorChangeWebAppBrowserTest() {
+  BackgroundColorChangeSystemWebAppBrowserTest() {
 #if BUILDFLAG(IS_CHROMEOS_LACROS)
     web_app::EnableSystemWebAppsInLacrosForTesting();
 #endif  // BUILDFLAG(IS_CHROMEOS_LACROS)
-    switch (GetBackgroundColorChangeTestMode()) {
-      case BackgroundColorChangeTestMode::kSWA:
-        system_web_app_installation_ =
-            ash::TestSystemWebAppInstallation::SetUpAppWithColors(
-                /*theme_color=*/SK_ColorWHITE,
-                /*dark_mode_theme_color=*/SK_ColorBLACK,
-                /*background_color=*/SK_ColorWHITE,
-                /*dark_mode_background_color=*/SK_ColorBLACK);
-        static_cast<ash::UnittestingSystemAppDelegate*>(
-            system_web_app_installation_->GetDelegate())
-            ->SetPreferManifestBackgroundColor(PreferManifestBackgroundColor());
-        break;
-      case BackgroundColorChangeTestMode::kNonSWA:
-        break;
-    }
-  }
-
-  // Returns test mode given test parameterization.
-  BackgroundColorChangeTestMode GetBackgroundColorChangeTestMode() const {
-    return std::get<0>(GetParam());
+    system_web_app_installation_ =
+        ash::TestSystemWebAppInstallation::SetUpAppWithColors(
+            /*theme_color=*/SK_ColorWHITE,
+            /*dark_mode_theme_color=*/SK_ColorBLACK,
+            /*background_color=*/SK_ColorWHITE,
+            /*dark_mode_background_color=*/SK_ColorBLACK);
+    static_cast<ash::UnittestingSystemAppDelegate*>(
+        system_web_app_installation_->GetDelegate())
+        ->SetPreferManifestBackgroundColor(PreferManifestBackgroundColor());
   }
 
   // Returns whether the web app under test prefers manifest background colors
   // over web contents background colors.
-  bool PreferManifestBackgroundColor() const { return std::get<1>(GetParam()); }
+  bool PreferManifestBackgroundColor() const { return GetParam(); }
 
   // Installs the web app under test, blocking until installation is complete,
   // and returning the `AppId` for the installed web app.
-  AppId WaitForAppInstall() {
-    switch (GetBackgroundColorChangeTestMode()) {
-      case BackgroundColorChangeTestMode::kSWA:
-        system_web_app_installation_->WaitForAppInstall();
-        return system_web_app_installation_->GetAppId();
-      case BackgroundColorChangeTestMode::kNonSWA: {
-        const GURL app_url = GetSecureAppURL();
-        auto web_app_info = std::make_unique<WebAppInstallInfo>();
-        web_app_info->start_url = app_url;
-        web_app_info->scope = app_url.GetWithoutFilename();
-        web_app_info->theme_color = SK_ColorWHITE;
-        web_app_info->dark_mode_theme_color = SK_ColorBLACK;
-        web_app_info->background_color = SK_ColorWHITE;
-        web_app_info->dark_mode_background_color = SK_ColorBLACK;
-        return InstallWebApp(std::move(web_app_info));
-      }
-    }
+  AppId WaitForSwaInstall() {
+    system_web_app_installation_->WaitForAppInstall();
+    return system_web_app_installation_->GetAppId();
   }
 
  private:
@@ -403,43 +412,19 @@
       system_web_app_installation_;
 };
 
-INSTANTIATE_TEST_SUITE_P(
-    Mode,
-    BackgroundColorChangeWebAppBrowserTest,
-    testing::Combine(testing::Values(BackgroundColorChangeTestMode::kSWA,
-                                     BackgroundColorChangeTestMode::kNonSWA),
-                     /*prefer_manifest_background_color=*/testing::Bool()),
-    [](const testing::TestParamInfo<
-        std::tuple<BackgroundColorChangeTestMode,
-                   /*prefer_manifest_background_color=*/bool>>& info) {
-      BackgroundColorChangeTestMode test_mode = std::get<0>(info.param);
-      bool prefer_manifest_background_color = std::get<1>(info.param);
+INSTANTIATE_TEST_SUITE_P(All,
+                         BackgroundColorChangeSystemWebAppBrowserTest,
+                         /*prefer_manifest_background_color=*/testing::Bool(),
+                         [](const testing::TestParamInfo<
+                             /*prefer_manifest_background_color=*/bool>& info) {
+                           return info.param ? "PreferManifestBackgroundColor"
+                                             : "WebContentsBackgroundColor";
+                         });
 
-      std::stringstream name;
-      switch (test_mode) {
-        case BackgroundColorChangeTestMode::kSWA:
-          name << "kSWA";
-          break;
-        case BackgroundColorChangeTestMode::kNonSWA:
-          name << "kNonSWA";
-          break;
-      }
-
-      if (prefer_manifest_background_color)
-        name << "_PreferManifestBackgroundColor";
-
-      return name.str();
-    });
-
-IN_PROC_BROWSER_TEST_P(BackgroundColorChangeWebAppBrowserTest,
+// Also see WebAppBrowserTest.BackgroundColorChange above.
+IN_PROC_BROWSER_TEST_P(BackgroundColorChangeSystemWebAppBrowserTest,
                        BackgroundColorChange) {
-  const bool is_non_swa = GetBackgroundColorChangeTestMode() ==
-                          BackgroundColorChangeTestMode::kNonSWA;
-  // Skip test parameterizations for non-system web apps that don't make sense.
-  if (is_non_swa && PreferManifestBackgroundColor())
-    GTEST_SKIP();
-
-  const AppId app_id = WaitForAppInstall();
+  const AppId app_id = WaitForSwaInstall();
   Browser* const app_browser = LaunchWebAppBrowser(app_id);
   content::WebContents* const web_contents =
       app_browser->tab_strip_model()->GetActiveWebContents();
@@ -450,9 +435,8 @@
   {
     content::BackgroundColorChangeWaiter waiter(web_contents);
     waiter.Wait();
-    EXPECT_EQ(
-        app_browser->app_controller()->GetBackgroundColor().value(),
-        !is_non_swa && is_dark_mode_state ? SK_ColorBLACK : SK_ColorWHITE);
+    EXPECT_EQ(app_browser->app_controller()->GetBackgroundColor().value(),
+              is_dark_mode_state ? SK_ColorBLACK : SK_ColorWHITE);
   }
   content::AwaitDocumentOnLoadCompleted(web_contents);
 
diff --git a/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_captive_portal_dialog.cc b/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_captive_portal_dialog.cc
index b0978c3..fef0228 100644
--- a/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_captive_portal_dialog.cc
+++ b/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_captive_portal_dialog.cc
@@ -7,7 +7,7 @@
 #include "ash/constants/ash_features.h"
 #include "chrome/browser/profiles/profile.h"
 #include "chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_reauth_dialogs.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "components/captive_portal/core/captive_portal_detector.h"
 
 namespace chromeos {
diff --git a/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_reauth_dialogs.cc b/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_reauth_dialogs.cc
index 2a5818e..01bba02 100644
--- a/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_reauth_dialogs.cc
+++ b/chrome/browser/ui/webui/chromeos/in_session_password_change/lock_screen_reauth_dialogs.cc
@@ -30,7 +30,7 @@
 #include "chrome/common/webui_url_constants.h"
 #include "chrome/grit/browser_resources.h"
 #include "chrome/grit/generated_resources.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/web_modal/web_contents_modal_dialog_manager.h"
diff --git a/chrome/browser/ui/webui/chromeos/network_ui.cc b/chrome/browser/ui/webui/chromeos/network_ui.cc
index 3659bdca..3c02ef23 100644
--- a/chrome/browser/ui/webui/chromeos/network_ui.cc
+++ b/chrome/browser/ui/webui/chromeos/network_ui.cc
@@ -38,8 +38,8 @@
 #include "chromeos/ash/components/network/cellular_utils.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chrome/browser/ui/webui/help/version_updater.h b/chrome/browser/ui/webui/help/version_updater.h
index 2c2450a..7eab1c2 100644
--- a/chrome/browser/ui/webui/help/version_updater.h
+++ b/chrome/browser/ui/webui/help/version_updater.h
@@ -12,7 +12,7 @@
 #include "build/chromeos_buildflags.h"
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 #include "third_party/cros_system_api/dbus/update_engine/dbus-constants.h"
 #endif  // BUILDFLAG(IS_CHROMEOS_ASH)
@@ -53,7 +53,7 @@
 #if BUILDFLAG(IS_CHROMEOS_ASH)
   typedef base::OnceCallback<void(const std::string&)> ChannelCallback;
   using EolInfoCallback =
-      base::OnceCallback<void(chromeos::UpdateEngineClient::EolInfo eol_info)>;
+      base::OnceCallback<void(ash::UpdateEngineClient::EolInfo eol_info)>;
   using IsFeatureEnabledCallback =
       base::OnceCallback<void(absl::optional<bool>)>;
 #endif
diff --git a/chrome/browser/ui/webui/help/version_updater_chromeos.cc b/chrome/browser/ui/webui/help/version_updater_chromeos.cc
index 65a0642..d62d6652 100644
--- a/chrome/browser/ui/webui/help/version_updater_chromeos.cc
+++ b/chrome/browser/ui/webui/help/version_updater_chromeos.cc
@@ -20,8 +20,8 @@
 #include "chrome/browser/browser_process.h"
 #include "chrome/browser/ui/webui/help/help_utils_chromeos.h"
 #include "chrome/grit/generated_resources.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
@@ -34,9 +34,9 @@
 
 namespace {
 
+using ::ash::UpdateEngineClient;
 using ::chromeos::OwnerSettingsServiceAsh;
 using ::chromeos::OwnerSettingsServiceAshFactory;
-using ::chromeos::UpdateEngineClient;
 
 // Network status in the context of device update.
 enum NetworkStatus {
@@ -240,9 +240,8 @@
                      weak_ptr_factory_.GetWeakPtr(), std::move(cb)));
 }
 
-void VersionUpdaterCros::OnGetEolInfo(
-    EolInfoCallback cb,
-    chromeos::UpdateEngineClient::EolInfo eol_info) {
+void VersionUpdaterCros::OnGetEolInfo(EolInfoCallback cb,
+                                      UpdateEngineClient::EolInfo eol_info) {
   std::move(cb).Run(std::move(eol_info));
 }
 
diff --git a/chrome/browser/ui/webui/help/version_updater_chromeos.h b/chrome/browser/ui/webui/help/version_updater_chromeos.h
index 8eaa940..5af757a 100644
--- a/chrome/browser/ui/webui/help/version_updater_chromeos.h
+++ b/chrome/browser/ui/webui/help/version_updater_chromeos.h
@@ -15,7 +15,7 @@
 }
 
 class VersionUpdaterCros : public VersionUpdater,
-                           public chromeos::UpdateEngineClient::Observer {
+                           public ash::UpdateEngineClient::Observer {
  public:
   VersionUpdaterCros(const VersionUpdaterCros&) = delete;
   VersionUpdaterCros& operator=(const VersionUpdaterCros&) = delete;
@@ -49,7 +49,7 @@
   void UpdateStatusChanged(const update_engine::StatusResult& status) override;
 
   // Callback from UpdateEngineClient::RequestUpdateCheck().
-  void OnUpdateCheck(chromeos::UpdateEngineClient::UpdateCheckResult result);
+  void OnUpdateCheck(ash::UpdateEngineClient::UpdateCheckResult result);
 
   // Callback from UpdateEngineClient::SetUpdateOverCellularOneTimePermission().
   void OnSetUpdateOverCellularOneTimePermission(bool success);
@@ -59,7 +59,7 @@
 
   // Callback from UpdateEngineClient::GetEolInfo().
   void OnGetEolInfo(EolInfoCallback cb,
-                    chromeos::UpdateEngineClient::EolInfo eol_info);
+                    ash::UpdateEngineClient::EolInfo eol_info);
 
   // Callback from UpdateEngineClient::IsFeatureEnabled().
   void OnIsFeatureEnabled(IsFeatureEnabledCallback callback,
diff --git a/chrome/browser/ui/webui/help/version_updater_chromeos_unittest.cc b/chrome/browser/ui/webui/help/version_updater_chromeos_unittest.cc
index 4b88a6e7..616ef54b 100644
--- a/chrome/browser/ui/webui/help/version_updater_chromeos_unittest.cc
+++ b/chrome/browser/ui/webui/help/version_updater_chromeos_unittest.cc
@@ -13,10 +13,10 @@
 #include "base/test/mock_callback.h"
 #include "chrome/browser/ash/login/users/mock_user_manager.h"
 #include "chrome/browser/ash/settings/scoped_cros_settings_test_helper.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
 #include "components/user_manager/scoped_user_manager.h"
 #include "content/public/test/browser_task_environment.h"
 #include "testing/gmock/include/gmock/gmock.h"
@@ -61,7 +61,8 @@
 
   void SetUp() override {
     DBusThreadManager::Initialize();
-    fake_update_engine_client_ = UpdateEngineClient::InitializeFakeForTest();
+    fake_update_engine_client_ =
+        ash::UpdateEngineClient::InitializeFakeForTest();
 
     EXPECT_CALL(*mock_user_manager_, IsCurrentUserOwner())
         .WillRepeatedly(Return(false));
@@ -96,7 +97,7 @@
   void TearDown() override {
     network_handler_test_helper_.reset();
     version_updater_.reset();
-    UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     DBusThreadManager::Shutdown();
   }
 
@@ -104,7 +105,7 @@
   std::unique_ptr<NetworkHandlerTestHelper> network_handler_test_helper_;
   std::unique_ptr<VersionUpdater> version_updater_;
   VersionUpdaterCros* version_updater_cros_ptr_;
-  FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
 
   MockUserManager* mock_user_manager_;  // Not owned.
   user_manager::ScopedUserManager user_manager_enabler_;
diff --git a/chrome/browser/ui/webui/settings/about_handler.cc b/chrome/browser/ui/webui/settings/about_handler.cc
index 1c09def..b2ee5511e 100644
--- a/chrome/browser/ui/webui/settings/about_handler.cc
+++ b/chrome/browser/ui/webui/settings/about_handler.cc
@@ -66,8 +66,8 @@
 #include "chrome/browser/ui/webui/help/help_utils_chromeos.h"
 #include "chrome/browser/ui/webui/help/version_updater_chromeos.h"
 #include "chrome/browser/ui/webui/webui_util.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/power/power_manager_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/util/version_loader.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
@@ -653,7 +653,7 @@
 
 void AboutHandler::OnGetEndOfLifeInfo(
     std::string callback_id,
-    chromeos::UpdateEngineClient::EolInfo eol_info) {
+    ash::UpdateEngineClient::EolInfo eol_info) {
   base::Value response(base::Value::Type::DICTIONARY);
   if (!eol_info.eol_date.is_null()) {
     bool has_eol_passed = eol_info.eol_date <= clock_->Now();
diff --git a/chrome/browser/ui/webui/settings/about_handler.h b/chrome/browser/ui/webui/settings/about_handler.h
index 16e63ed..da737e2 100644
--- a/chrome/browser/ui/webui/settings/about_handler.h
+++ b/chrome/browser/ui/webui/settings/about_handler.h
@@ -182,7 +182,7 @@
 
   // Callbacks for version_updater_->GetEolInfo calls.
   void OnGetEndOfLifeInfo(std::string callback_id,
-                          chromeos::UpdateEngineClient::EolInfo eol_info);
+                          ash::UpdateEngineClient::EolInfo eol_info);
 
   // Get the managed auto update cros setting.
   void HandleIsManagedAutoUpdateEnabled(const base::Value::List& args);
diff --git a/chrome/browser/ui/webui/settings/about_handler_unittest.cc b/chrome/browser/ui/webui/settings/about_handler_unittest.cc
index 45e6ac45..424db6a 100644
--- a/chrome/browser/ui/webui/settings/about_handler_unittest.cc
+++ b/chrome/browser/ui/webui/settings/about_handler_unittest.cc
@@ -8,9 +8,9 @@
 #include "chrome/test/base/testing_browser_process.h"
 #include "chrome/test/base/testing_profile.h"
 #include "chromeos/ash/components/dbus/concierge/concierge_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "content/public/test/browser_task_environment.h"
 #include "content/public/test/test_web_ui.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -41,7 +41,8 @@
 
   void SetUp() override {
     DBusThreadManager::Initialize();
-    fake_update_engine_client_ = UpdateEngineClient::InitializeFakeForTest();
+    fake_update_engine_client_ =
+        ash::UpdateEngineClient::InitializeFakeForTest();
     ConciergeClient::InitializeFake(/*fake_cicerone_client=*/nullptr);
 
     handler_ = std::make_unique<TestAboutHandler>(&profile_);
@@ -57,7 +58,7 @@
     handler_.reset();
     TestingBrowserProcess::GetGlobal()->SetLocalState(nullptr);
     ConciergeClient::Shutdown();
-    UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     DBusThreadManager::Shutdown();
   }
 
@@ -102,7 +103,7 @@
   TestingProfile profile_;
   content::TestWebUI web_ui_;
   std::unique_ptr<TestAboutHandler> handler_;
-  FakeUpdateEngineClient* fake_update_engine_client_;
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;
   std::unique_ptr<base::SimpleTestClock> clock_;
 };
 
diff --git a/chrome/browser/ui/webui/settings/chromeos/internet_handler.cc b/chrome/browser/ui/webui/settings/chromeos/internet_handler.cc
index 8138071..ae545ef 100644
--- a/chrome/browser/ui/webui/settings/chromeos/internet_handler.cc
+++ b/chrome/browser/ui/webui/settings/chromeos/internet_handler.cc
@@ -21,7 +21,7 @@
 #include "chrome/browser/profiles/profile.h"
 #include "chrome/browser/ui/app_list/arc/arc_app_list_prefs.h"
 #include "chrome/browser/ui/app_list/arc/arc_app_utils.h"
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chrome/browser/upgrade_detector/installed_version_updater_chromeos.cc b/chrome/browser/upgrade_detector/installed_version_updater_chromeos.cc
index 5571643..7a1adec 100644
--- a/chrome/browser/upgrade_detector/installed_version_updater_chromeos.cc
+++ b/chrome/browser/upgrade_detector/installed_version_updater_chromeos.cc
@@ -8,7 +8,7 @@
 #include "base/logging.h"
 #include "base/metrics/histogram_functions.h"
 #include "chrome/browser/upgrade_detector/build_state.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 namespace {
 
@@ -24,12 +24,12 @@
 
 InstalledVersionUpdater::InstalledVersionUpdater(BuildState* build_state)
     : build_state_(build_state) {
-  chromeos::UpdateEngineClient::Get()->AddObserver(this);
+  ash::UpdateEngineClient::Get()->AddObserver(this);
 }
 
 InstalledVersionUpdater::~InstalledVersionUpdater() {
   DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);
-  chromeos::UpdateEngineClient::Get()->RemoveObserver(this);
+  ash::UpdateEngineClient::Get()->RemoveObserver(this);
 }
 
 void InstalledVersionUpdater::UpdateStatusChanged(
diff --git a/chrome/browser/upgrade_detector/installed_version_updater_chromeos.h b/chrome/browser/upgrade_detector/installed_version_updater_chromeos.h
index c23fd7a..5bfdd5a5 100644
--- a/chrome/browser/upgrade_detector/installed_version_updater_chromeos.h
+++ b/chrome/browser/upgrade_detector/installed_version_updater_chromeos.h
@@ -9,20 +9,20 @@
 
 #include "base/memory/weak_ptr.h"
 #include "base/sequence_checker.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 class BuildState;
 
 // Observes the system UpdateEngineClient for updates that require a device
 // restart. Update information is pushed to the given BuildState as it happens.
-class InstalledVersionUpdater : public chromeos::UpdateEngineClient::Observer {
+class InstalledVersionUpdater : public ash::UpdateEngineClient::Observer {
  public:
   explicit InstalledVersionUpdater(BuildState* build_state);
   InstalledVersionUpdater(const InstalledVersionUpdater&) = delete;
   InstalledVersionUpdater& operator=(const InstalledVersionUpdater&) = delete;
   ~InstalledVersionUpdater() override;
 
-  // chromeos::UpdateEngineClient::Observer:
+  // ash::UpdateEngineClient::Observer:
   void UpdateStatusChanged(const update_engine::StatusResult& status) override;
 
  private:
diff --git a/chrome/browser/upgrade_detector/installed_version_updater_chromeos_unittest.cc b/chrome/browser/upgrade_detector/installed_version_updater_chromeos_unittest.cc
index 2e577815..c78532f 100644
--- a/chrome/browser/upgrade_detector/installed_version_updater_chromeos_unittest.cc
+++ b/chrome/browser/upgrade_detector/installed_version_updater_chromeos_unittest.cc
@@ -10,10 +10,10 @@
 #include "base/test/task_environment.h"
 #include "chrome/browser/upgrade_detector/build_state.h"
 #include "chrome/browser/upgrade_detector/mock_build_state_observer.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "testing/gmock/include/gmock/gmock.h"
 #include "testing/gtest/include/gtest/gtest.h"
 
@@ -28,7 +28,7 @@
   InstalledVersionUpdaterTest() {
     chromeos::DBusThreadManager::Initialize();
     fake_update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+        ash::UpdateEngineClient::InitializeFakeForTest();
 
     build_state_.AddObserver(&mock_observer_);
   }
@@ -37,7 +37,7 @@
     build_state_.RemoveObserver(&mock_observer_);
 
     // Be kind; rewind.
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
@@ -50,7 +50,7 @@
   BuildState build_state_;
 
  private:
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
 };
 
 // Tests that an unrelated status change notification does not push data to the
diff --git a/chrome/browser/upgrade_detector/upgrade_detector_chromeos.cc b/chrome/browser/upgrade_detector/upgrade_detector_chromeos.cc
index c4571dd..e494d1dd 100644
--- a/chrome/browser/upgrade_detector/upgrade_detector_chromeos.cc
+++ b/chrome/browser/upgrade_detector/upgrade_detector_chromeos.cc
@@ -20,16 +20,16 @@
 #include "chrome/browser/browser_process.h"
 #include "chrome/browser/upgrade_detector/build_state.h"
 #include "chrome/common/pref_names.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/pref_registry_simple.h"
 #include "components/prefs/pref_service.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 #include "third_party/icu/source/i18n/unicode/timezone.h"
 
-using chromeos::UpdateEngineClient;
-
 namespace {
 
+using ::ash::UpdateEngineClient;
+
 // How long to wait (each cycle) before checking which severity level we should
 // be at. Once we reach the highest severity, the timer will stop.
 constexpr base::TimeDelta kNotifyCycleDelta = base::Minutes(20);
diff --git a/chrome/browser/upgrade_detector/upgrade_detector_chromeos.h b/chrome/browser/upgrade_detector/upgrade_detector_chromeos.h
index c083b5e3..cdbbd4c 100644
--- a/chrome/browser/upgrade_detector/upgrade_detector_chromeos.h
+++ b/chrome/browser/upgrade_detector/upgrade_detector_chromeos.h
@@ -11,7 +11,7 @@
 #include "chrome/browser/upgrade_detector/build_state_observer.h"
 #include "chrome/browser/upgrade_detector/installed_version_updater_chromeos.h"
 #include "chrome/browser/upgrade_detector/upgrade_detector.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 class PrefRegistrySimple;
 namespace base {
@@ -21,7 +21,7 @@
 
 class UpgradeDetectorChromeos : public UpgradeDetector,
                                 public BuildStateObserver,
-                                public chromeos::UpdateEngineClient::Observer {
+                                public ash::UpdateEngineClient::Observer {
  public:
   UpgradeDetectorChromeos(const UpgradeDetectorChromeos&) = delete;
   UpgradeDetectorChromeos& operator=(const UpgradeDetectorChromeos&) = delete;
@@ -65,7 +65,7 @@
   // UpgradeDetector:
   void OnMonitoredPrefsChanged() override;
 
-  // chromeos::UpdateEngineClient::Observer implementation.
+  // ash::UpdateEngineClient::Observer implementation.
   void UpdateStatusChanged(const update_engine::StatusResult& status) override;
   void OnUpdateOverCellularOneTimePermissionGranted() override;
 
diff --git a/chrome/browser/upgrade_detector/upgrade_detector_chromeos_unittest.cc b/chrome/browser/upgrade_detector/upgrade_detector_chromeos_unittest.cc
index 7ec1880..7fef34d8 100644
--- a/chrome/browser/upgrade_detector/upgrade_detector_chromeos_unittest.cc
+++ b/chrome/browser/upgrade_detector/upgrade_detector_chromeos_unittest.cc
@@ -19,9 +19,9 @@
 #include "chrome/common/pref_names.h"
 #include "chrome/test/base/scoped_testing_local_state.h"
 #include "chrome/test/base/testing_browser_process.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "chromeos/dbus/dbus_thread_manager.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
 #include "components/prefs/testing_pref_service.h"
 #include "testing/gmock/include/gmock/gmock.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -100,7 +100,7 @@
 
     chromeos::DBusThreadManager::Initialize();
     fake_update_engine_client_ =
-        chromeos::UpdateEngineClient::InitializeFakeForTest();
+        ash::UpdateEngineClient::InitializeFakeForTest();
 
     // Fast forward to set current time to local 2am . This is done to align the
     // relaunch deadline within the default relaunch window of 2am to 4am so
@@ -122,7 +122,7 @@
     }
     tzset();
 
-    chromeos::UpdateEngineClient::Shutdown();
+    ash::UpdateEngineClient::Shutdown();
     chromeos::DBusThreadManager::Shutdown();
   }
 
@@ -208,7 +208,7 @@
   std::unique_ptr<base::Environment> env_;
   absl::optional<std::string> original_tz_;
 
-  chromeos::FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
+  ash::FakeUpdateEngineClient* fake_update_engine_client_;  // Not owned.
 };
 
 TEST_F(UpgradeDetectorChromeosTest, PolicyNotEnabled) {
diff --git a/chrome/browser/web_applications/user_uninstalled_preinstalled_web_app_prefs_browsertest.cc b/chrome/browser/web_applications/user_uninstalled_preinstalled_web_app_prefs_browsertest.cc
index 657d1bce..c533b9c 100644
--- a/chrome/browser/web_applications/user_uninstalled_preinstalled_web_app_prefs_browsertest.cc
+++ b/chrome/browser/web_applications/user_uninstalled_preinstalled_web_app_prefs_browsertest.cc
@@ -103,8 +103,9 @@
   EXPECT_EQ(absl::nullopt, preinstalled_prefs.LookUpAppIdByInstallUrl(url2));
 }
 
+// TODO(crbug.com/1341391): Flakily crashes on Mac, Windows, Chrome OS, Linux.
 IN_PROC_BROWSER_TEST_F(UserUninstalledPreinstalledWebAppPrefsBrowserTest,
-                       PrefsPropagateProperlyOnDefaultUninstall) {
+                       DISABLED_PrefsPropagateProperlyOnDefaultUninstall) {
   auto app_info1 = std::make_unique<WebAppInstallInfo>();
   app_info1->start_url = GURL("https://example_url1.com/");
   app_info1->title = u"Example App1";
diff --git a/chrome/build/linux.pgo.txt b/chrome/build/linux.pgo.txt
index 437616b..2fb6dc81 100644
--- a/chrome/build/linux.pgo.txt
+++ b/chrome/build/linux.pgo.txt
@@ -1 +1 @@
-chrome-linux-main-1656870358-f420b0848cbfe76959495f9cfaf588cfe179626c.profdata
+chrome-linux-main-1656914368-5001a8b9b8044ee35db01ee492cabbd1f395b5b0.profdata
diff --git a/chrome/build/mac-arm.pgo.txt b/chrome/build/mac-arm.pgo.txt
index 12a8008..3e87d7f 100644
--- a/chrome/build/mac-arm.pgo.txt
+++ b/chrome/build/mac-arm.pgo.txt
@@ -1 +1 @@
-chrome-mac-arm-main-1656870358-930e15f5c5c80025f6e29f2b3b51a83317c44f9e.profdata
+chrome-mac-arm-main-1656914368-b3c0f85b2f944b6fe9ef2bd7ff7718f75238f9c9.profdata
diff --git a/chrome/build/mac.pgo.txt b/chrome/build/mac.pgo.txt
index 3981d671e..72fa882 100644
--- a/chrome/build/mac.pgo.txt
+++ b/chrome/build/mac.pgo.txt
@@ -1 +1 @@
-chrome-mac-main-1656870358-1d7fec7ba548023443997da4db9ed043cab88946.profdata
+chrome-mac-main-1656914368-9e11ca866685478cd0552483fe965b102fa6ea9a.profdata
diff --git a/chrome/build/win32.pgo.txt b/chrome/build/win32.pgo.txt
index d811050..f0674d9 100644
--- a/chrome/build/win32.pgo.txt
+++ b/chrome/build/win32.pgo.txt
@@ -1 +1 @@
-chrome-win32-main-1656870358-d9900044feaba18506b65e4bc4bead034a276254.profdata
+chrome-win32-main-1656924679-1489720740e0ed53dceee8e75fd004fada5af955.profdata
diff --git a/chrome/build/win64.pgo.txt b/chrome/build/win64.pgo.txt
index 455deef..da4b91a 100644
--- a/chrome/build/win64.pgo.txt
+++ b/chrome/build/win64.pgo.txt
@@ -1 +1 @@
-chrome-win64-main-1656870358-e42489b188d5f34447123a95fbf1b534cbebb79c.profdata
+chrome-win64-main-1656924679-f2572f186d1f9a201ba710fbe839c2e4b1145827.profdata
diff --git a/chrome/common/extensions/permissions/permission_set_unittest.cc b/chrome/common/extensions/permissions/permission_set_unittest.cc
index 390dca74..0960abc 100644
--- a/chrome/common/extensions/permissions/permission_set_unittest.cc
+++ b/chrome/common/extensions/permissions/permission_set_unittest.cc
@@ -863,7 +863,6 @@
   skip.insert(APIPermissionID::kHid);
   skip.insert(APIPermissionID::kFileSystem);
   skip.insert(APIPermissionID::kFileSystemProvider);
-  skip.insert(APIPermissionID::kFileSystemRequestDownloads);
   skip.insert(APIPermissionID::kFileSystemRequestFileSystem);
   skip.insert(APIPermissionID::kFileSystemRetainEntries);
   skip.insert(APIPermissionID::kFileSystemWrite);
diff --git a/chrome/services/sharing/nearby/platform/DEPS b/chrome/services/sharing/nearby/platform/DEPS
index f597e0b..9194d40e 100644
--- a/chrome/services/sharing/nearby/platform/DEPS
+++ b/chrome/services/sharing/nearby/platform/DEPS
@@ -12,8 +12,8 @@
   '+unicode/locid.h',
   '+chromeos/ash/components/network/proxy/ui_proxy_config_service.h',
   '+chromeos/ash/components/network/managed_network_configuration_handler.h',
+  '+chromeos/ash/components/network/network_configuration_handler.h',
   '+chromeos/login/login_state/login_state.h',
-  '+chromeos/network/network_configuration_handler.h',
   '+chromeos/network/network_profile_handler.h',
   '+components/onc/onc_constants.h',
   '+components/onc/onc_pref_names.h',
diff --git a/chrome/services/sharing/nearby/platform/wifi_lan_medium_unittest.cc b/chrome/services/sharing/nearby/platform/wifi_lan_medium_unittest.cc
index b7a18814..434ff80 100644
--- a/chrome/services/sharing/nearby/platform/wifi_lan_medium_unittest.cc
+++ b/chrome/services/sharing/nearby/platform/wifi_lan_medium_unittest.cc
@@ -16,9 +16,9 @@
 #include "base/threading/thread_restrictions.h"
 #include "chrome/services/sharing/nearby/platform/wifi_lan_server_socket.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/services/network_config/in_process_instance.h"
 #include "chromeos/services/network_config/public/cpp/cros_network_config_test_helper.h"
diff --git a/chrome/test/BUILD.gn b/chrome/test/BUILD.gn
index f5d96cf..fbfceb1 100644
--- a/chrome/test/BUILD.gn
+++ b/chrome/test/BUILD.gn
@@ -4125,6 +4125,7 @@
         "//chromeos/ash/components/dbus/system_clock",
         "//chromeos/ash/components/dbus/system_proxy",
         "//chromeos/ash/components/dbus/system_proxy:system_proxy_proto",
+        "//chromeos/ash/components/dbus/update_engine",
         "//chromeos/ash/components/dbus/upstart",
         "//chromeos/ash/components/dbus/vm_plugin_dispatcher",
         "//chromeos/ash/components/network/portal_detector",
@@ -4144,7 +4145,6 @@
         "//chromeos/dbus/dlp",
         "//chromeos/dbus/image_burner",
         "//chromeos/dbus/power",
-        "//chromeos/dbus/update_engine",
         "//chromeos/login/login_state:test_support",
         "//chromeos/process_proxy",
         "//chromeos/services/assistant/public/proto",
@@ -7267,6 +7267,8 @@
       "//chromeos/ash/components/dbus/cicerone",
       "//chromeos/ash/components/dbus/concierge",
       "//chromeos/ash/components/dbus/seneschal",
+      "//chromeos/ash/components/dbus/update_engine",
+      "//chromeos/ash/components/dbus/update_engine:proto",
       "//chromeos/ash/services/assistant/public/cpp",
       "//chromeos/components/feature_usage:feature_usage",
       "//chromeos/components/onc",
@@ -7285,8 +7287,6 @@
       "//chromeos/dbus/power",
       "//chromeos/dbus/shill",
       "//chromeos/dbus/u2f",
-      "//chromeos/dbus/update_engine",
-      "//chromeos/dbus/update_engine:proto",
       "//chromeos/ime:gencode",
       "//chromeos/login/login_state:test_support",
       "//chromeos/services/assistant/public/shared",
diff --git a/chrome/test/data/extensions/api_test/file_system/get_volume_list/background.js b/chrome/test/data/extensions/api_test/file_system/get_volume_list/background.js
index a02c0a0..fd7a5de 100644
--- a/chrome/test/data/extensions/api_test/file_system/get_volume_list/background.js
+++ b/chrome/test/data/extensions/api_test/file_system/get_volume_list/background.js
@@ -12,21 +12,19 @@
           // Whether Drive is available in the real kiosk session is tested
           // separately in:
           // chrome/browser/ash/login/app_mode/kiosk_browsertest.cc.
-          chrome.test.assertEq(6, volumeList.length);
+          chrome.test.assertEq(5, volumeList.length);
           chrome.test.assertTrue(/^downloads:.*/.test(volumeList[0].volumeId));
           chrome.test.assertTrue(volumeList[0].writable);
-          chrome.test.assertEq('downloads:downloads', volumeList[1].volumeId);
+          chrome.test.assertEq('drive:drive-user', volumeList[1].volumeId);
           chrome.test.assertTrue(volumeList[1].writable);
-          chrome.test.assertEq('drive:drive-user', volumeList[2].volumeId);
-          chrome.test.assertTrue(volumeList[2].writable);
           chrome.test.assertEq(
-              'system_internal:ShareCache', volumeList[3].volumeId);
-          chrome.test.assertFalse(volumeList[3].writable);
+              'system_internal:ShareCache', volumeList[2].volumeId);
+          chrome.test.assertFalse(volumeList[2].writable);
 
-          chrome.test.assertEq('testing:read-only', volumeList[4].volumeId);
-          chrome.test.assertFalse(volumeList[4].writable);
-          chrome.test.assertEq('testing:writable', volumeList[5].volumeId);
-          chrome.test.assertTrue(volumeList[5].writable);
+          chrome.test.assertEq('testing:read-only', volumeList[3].volumeId);
+          chrome.test.assertFalse(volumeList[3].writable);
+          chrome.test.assertEq('testing:writable', volumeList[4].volumeId);
+          chrome.test.assertTrue(volumeList[4].writable);
         }));
   }
 ]);
diff --git a/chrome/test/data/extensions/api_test/file_system/on_volume_list_changed/background.js b/chrome/test/data/extensions/api_test/file_system/on_volume_list_changed/background.js
index c4c3156..bf68199 100644
--- a/chrome/test/data/extensions/api_test/file_system/on_volume_list_changed/background.js
+++ b/chrome/test/data/extensions/api_test/file_system/on_volume_list_changed/background.js
@@ -7,16 +7,16 @@
     function onVolumeListChanged() {
       chrome.fileSystem.getVolumeList(
          chrome.test.callbackPass(function(volumeList) {
-           chrome.test.assertEq(6, volumeList.length);
+           chrome.test.assertEq(5, volumeList.length);
 
            // Confirm that adding a newly mounted volume emits an event, and
            // that the volume list is updated.
            chrome.fileSystem.onVolumeListChanged.addListener(
                chrome.test.callbackPass(function(event) {
-                 chrome.test.assertEq(7, event.volumes.length);
+                 chrome.test.assertEq(6, event.volumes.length);
                  chrome.fileSystem.getVolumeList(
                      chrome.test.callbackPass(function(volumeList) {
-                       chrome.test.assertEq(7, volumeList.length);
+                       chrome.test.assertEq(6, volumeList.length);
                      }));
                }));
       }));
diff --git a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/background.js b/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/background.js
deleted file mode 100644
index d2dd402..0000000
--- a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/background.js
+++ /dev/null
@@ -1,7 +0,0 @@
-// Copyright 2018 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-chrome.app.runtime.onLaunched.addListener(function() {
-  chrome.app.window.create('test.html');
-});
diff --git a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/manifest.json b/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/manifest.json
deleted file mode 100644
index 234fe55b..0000000
--- a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/manifest.json
+++ /dev/null
@@ -1,18 +0,0 @@
-{
-  // chrome-extension://pkplfbidichfdicaijlchgnapepdginl
-  "manifest_version": 2,
-  "key": "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAtDfX9dHNh948bt00YhZBm3P6E5QLaOt+v8kXVtibQfiPtOD2FTScB/f0wX/EQWVO7BkaSOsRkTPcPIgocyMPYr2FLgqGLFlYT9nQpKJZUFNF5oJ5rG6Nv7ppf4zEB3j6da1IBRTz2yOZ+6O1TMZxol/V62/QcqrJeggsHTEPGLdr9Ua4b1Ka0xKJnJngZljsbw93FI1o+P9dAh5BS6wTPiZI/vmJVjvMTkSTnaZ3n9Go2t7A0XLcSxLcVyuLAd2mAvSN0mIviOukdM66wr7llif71nKuUt+4qvlr/r9HfwzN6pA4jkwhtS1UD+3CmB+wsHwsnohNcuu4FIQ6rgq/7QIDAQAB",
-  "name": "chrome.fileSystem.requestFileSystem test for whitelisted extensions",
-  "version": "0.1",
-  "description": "Test for requesting Downloads via chrome.fileSystem.requestFileSystem by whitelisted extensions.",
-  "app": {
-    "background": {
-      "scripts": ["background.js"]
-    }
-  },
-  "permissions": [
-    {
-      "fileSystem": ["requestDownloads"]
-    }
-  ]
-}
diff --git a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.html b/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.html
deleted file mode 100644
index 8d7d1db..0000000
--- a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.html
+++ /dev/null
@@ -1,3 +0,0 @@
-<html>
-<script src="test.js"></script>
-</html>
diff --git a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.js b/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.js
deleted file mode 100644
index d58ea34..0000000
--- a/chrome/test/data/extensions/api_test/file_system/request_downloads_allowed_extension/test.js
+++ /dev/null
@@ -1,13 +0,0 @@
-// Copyright 2018 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-chrome.test.runTests([
-  function readOnlyVolume() {
-    chrome.fileSystem.requestFileSystem(
-        {volumeId: 'downloads:downloads'},
-        chrome.test.callbackPass(function(fileSystem) {
-          chrome.test.assertTrue(!!fileSystem);
-        }));
-  }
-]);
diff --git a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_extension_test.js b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_extension_test.js
index 11fa1da..16778ce4 100644
--- a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_extension_test.js
+++ b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_extension_test.js
@@ -35,6 +35,10 @@
     document.body.innerHTML = '';
     window.localStorage.clear();
 
+     // Set default incognito state to False.
+    EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
+        new Promise((resolve) => resolve({incognito: false}));
+
     emojiPicker =
         /** @type {!EmojiPicker} */ (document.createElement('emoji-picker'));
     emojiPicker.emojiDataUrl = '/emoji_test_ordering';
@@ -185,8 +189,7 @@
       'clicking at recently used emoticon buttons should trigger emoticon ' +
           'insertion.',
       async () => {
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: false}));
+        emojiPicker.updateIncognitoState(false);
 
         const emoticonButton = findEmojiFirstButton(emoticonGroupSelector);
         emoticonButton.click();
@@ -212,9 +215,7 @@
       'recently used emoticon group should contain the correct emoticon ' +
           'after it is clicked.',
       async () => {
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: false}));
-
+        emojiPicker.updateIncognitoState(false);
         const emoticonButton = findEmojiFirstButton(emoticonGroupSelector);
         emoticonButton.click();
 
diff --git a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test.js b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test.js
index f2a42c0..2e9faf7 100644
--- a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test.js
+++ b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test.js
@@ -29,6 +29,10 @@
     document.body.innerHTML = '';
     window.localStorage.clear();
 
+    // Set default incognito state to False.
+    EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
+            new Promise((resolve) => resolve({incognito: false}));
+
     emojiPicker =
         /** @type {!EmojiPicker} */ (document.createElement('emoji-picker'));
     emojiPicker.emojiDataUrl = '/emoji_test_ordering';
@@ -57,7 +61,7 @@
 
   test('first non-chevron, tab should be active by default', async () => {
     const button = findInEmojiPicker(
-        'emoji-group-button[data-group="history"]', 'cr-icon-button');
+        'emoji-group-button[data-group="emoji-history"]', 'cr-icon-button');
     assertFalse(isGroupButtonActive(button));
   });
 
@@ -82,7 +86,7 @@
     // the first non-history group (0) may not trigger a scroll, so scroll to
     // group (1).
     const firstButton = findInEmojiPicker(
-        'emoji-group-button[data-group="history"]', 'cr-icon-button');
+        'emoji-group-button[data-group="emoji-history"]', 'cr-icon-button');
     const thirdButton = findInEmojiPicker(
         'emoji-group-button[data-group="1"]', 'cr-icon-button');
 
@@ -107,15 +111,14 @@
 
   test('recently used should be hidden when empty', () => {
     const recentlyUsed =
-        findInEmojiPicker('[data-group=history] > emoji-group');
+        findInEmojiPicker('[data-group="emoji-history"] > emoji-group');
     assert(!recentlyUsed);
   });
 
   test(
       'recently used should be populated after emoji is clicked normally',
       async () => {
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: false}));
+        emojiPicker.updateIncognitoState(false);
         // yield to allow emoji-group and emoji buttons to render.
         const emojiButton = await waitForCondition(
             () => findEmojiFirstButton(
@@ -124,8 +127,8 @@
 
         // wait until emoji exists in recently used section.
         const recentlyUsed = await waitForCondition(
-            () => findEmojiFirstButton(
-                '[data-group=history] > emoji-group'));
+          () => findEmojiFirstButton(
+            '[data-group="emoji-history"] > emoji-group'));
 
         // check text is correct.
         const recentText = recentlyUsed.innerText;
@@ -135,10 +138,7 @@
   test(
       'clicking an emoji with no text field should copy it to the clipboard',
       async () => {
-        // Note: this whole test has no text field, so we should always copy to
-        // the clipboard.
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: false}));
+        emojiPicker.updateIncognitoState(false);
         // yield to allow emoji-group and emoji buttons to render.
         const emojiButton = await waitForCondition(
             () => findEmojiFirstButton(
@@ -148,7 +148,7 @@
         // wait until emoji exists in recently used section.
         const recentlyUsed = await waitForCondition(
             () => findEmojiFirstButton(
-                '[data-group=history] > emoji-group'));
+              '[data-group="emoji-history"] > emoji-group'));
 
         // check text is correct.
         await (waitForCondition(async () => {
@@ -158,8 +158,7 @@
       });
 
   test('recently-used should have variants for variant emoji', async () => {
-    EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-        new Promise((resolve) => resolve({incognito: false}));
+    emojiPicker.updateIncognitoState(false);
     // yield to allow emoji-group and emoji buttons to render.
     const emojiButton = (await waitForCondition(
                              () => findInEmojiPicker(
@@ -171,7 +170,7 @@
     const recentlyUsed =
         (await waitForCondition(
              () => findEmojiFirstButton(
-                 '[data-group=history] > emoji-group')));
+                 '[data-group="emoji-history"] > emoji-group')));
 
     // check variants class is applied
     assertTrue(recentlyUsed.classList.contains('has-variants'));
@@ -180,8 +179,7 @@
   test(
       'recently-used should have no variants for non-variant emoji',
       async () => {
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: false}));
+        emojiPicker.updateIncognitoState(false);
         // yield to allow emoji-group and emoji buttons to render.
         const emojiButton = (await waitForCondition(
                                  () => findInEmojiPicker(
@@ -193,7 +191,7 @@
         const recentlyUsed =
             (await waitForCondition(
                  () => findEmojiFirstButton(
-                     '[data-group=history] > emoji-group')));
+                     '[data-group="emoji-history"] > emoji-group')));
 
         // check variants class is not applied
         assertFalse(recentlyUsed.classList.contains('has-variants'));
@@ -202,8 +200,7 @@
   test(
       'recently-used should be empty after emoji is clicked in incognito mode',
       async () => {
-        EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-            new Promise((resolve) => resolve({incognito: true}));
+        emojiPicker.updateIncognitoState(true);
         // yield to allow emoji-group and emoji buttons to render.
         const emojiButton = await waitForCondition(
             () => findEmojiFirstButton('[data-group="0"] > emoji-group'));
@@ -213,14 +210,12 @@
         await timeout(1000);
 
         const recentlyUsed =
-            findInEmojiPicker('[data-group=history] > emoji-group');
+            findInEmojiPicker('[data-group="emoji-history"] > emoji-group');
         assert(!recentlyUsed);
       });
 
   test('recently used should be empty after clearing', async () => {
-    EmojiPickerApiProxyImpl.getInstance().isIncognitoTextField = () =>
-        // first - insert an emoji to populate recently used
-        new Promise((resolve) => resolve({incognito: false}));
+    emojiPicker.updateIncognitoState(false);
     // yield to allow emoji-group and emoji buttons to render.
     const emojiButton = (await waitForCondition(
                              () => findInEmojiPicker(
@@ -232,7 +227,7 @@
     const recentlyUsed =
         (await waitForCondition(
              () => findEmojiFirstButton(
-               '[data-group=history] > emoji-group')));
+                 '[data-group="emoji-history"] > emoji-group')));
 
     // click show clear button
     findInEmojiPicker('.group', '#show-clear').click();
@@ -243,7 +238,7 @@
 
     // Expect no more history.
     await waitForCondition(
-        () => findInEmojiPicker('[data-group=history] > emoji-group')
+        () => findInEmojiPicker('[data-group="emoji-history"] > emoji-group')
                   .style.display === 'none',
         'history failed to disappear');
   });
diff --git a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test_util.js b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test_util.js
index cb6659d..af2e77e 100644
--- a/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test_util.js
+++ b/chrome/test/data/webui/chromeos/emoji_picker/emoji_picker_test_util.js
@@ -87,7 +87,8 @@
 export function waitWithTimeout(promise, ms, message) {
   message = message || 'waiting for promise timed out after ' + ms + ' ms.';
   return Promise.race(
-      [promise, timeout(ms).then((resolve, reject) => reject(message))]);
+      [promise, timeout(ms).then(
+        () => Promise.reject(new Error(message)))]);
 }
 
 /**
diff --git a/chrome/test/data/webui/settings/chromeos/crostini_page_test.js b/chrome/test/data/webui/settings/chromeos/crostini_page_test.js
index 12d552ca..9d595da 100644
--- a/chrome/test/data/webui/settings/chromeos/crostini_page_test.js
+++ b/chrome/test/data/webui/settings/chromeos/crostini_page_test.js
@@ -26,6 +26,36 @@
 
 const MIC_ALLOWED_PATH = 'prefs.crostini.mic_allowed.value';
 
+const singleContainer = /** @type {!Array<!ContainerInfo>}*/
+    ([
+      {
+        id: {
+          vm_name: 'termina',
+          container_name: 'penguin',
+        },
+        ipv4: '1.2.3.4',
+      },
+    ]);
+
+const multipleContainers = /** @type {!Array<!ContainerInfo>}*/
+    ([
+      {
+        id: {
+          vm_name: 'termina',
+          container_name: 'penguin',
+        },
+        ipv4: '1.2.3.4',
+      },
+      {
+        id: {
+          vm_name: 'not-termina',
+          container_name: 'not-penguin',
+
+        },
+        ipv4: '1.2.3.5',
+      }
+    ]);
+
 function setCrostiniPrefs(enabled, optional = {}) {
   const {
     sharedPaths = {},
@@ -308,126 +338,6 @@
                 'requestCrostiniInstallerStatus') >= 1);
       });
 
-      test('Export', async function() {
-        assertTrue(
-            !!subpage.shadowRoot.querySelector('#crostini-export-import'));
-        subpage.shadowRoot.querySelector('#crostini-export-import').click();
-
-        await flushTasks();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-        assertTrue(!!subpage.shadowRoot.querySelector('#export cr-button'));
-        subpage.shadowRoot.querySelector('#export cr-button').click();
-        assertEquals(
-            1, crostiniBrowserProxy.getCallCount('exportCrostiniContainer'));
-      });
-
-      test('Deep link to backup linux', async () => {
-        const params = new URLSearchParams();
-        params.append('settingId', '802');
-        Router.getInstance().navigateTo(
-            routes.CROSTINI_EXPORT_IMPORT, params);
-
-        flush();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-
-        const deepLinkElement =
-            subpage.shadowRoot.querySelector('#export cr-button');
-        await waitAfterNextRender(deepLinkElement);
-        assertEquals(
-            deepLinkElement, getDeepActiveElement(),
-            'Export button should be focused for settingId=802.');
-      });
-
-      test('Import', async function() {
-        assertTrue(
-            !!subpage.shadowRoot.querySelector('#crostini-export-import'));
-        subpage.shadowRoot.querySelector('#crostini-export-import').click();
-
-        await flushTasks();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-        subpage.shadowRoot.querySelector('#import cr-button').click();
-
-        await flushTasks();
-        subpage = subpage.shadowRoot.querySelector(
-            'settings-crostini-import-confirmation-dialog');
-        subpage.shadowRoot.querySelector('cr-dialog cr-button[id="continue"]')
-            .click();
-        assertEquals(
-            1, crostiniBrowserProxy.getCallCount('importCrostiniContainer'));
-      });
-
-      test('ExportImportButtonsGetDisabledOnOperationStatus', async function() {
-        assertTrue(
-            !!subpage.shadowRoot.querySelector('#crostini-export-import'));
-        subpage.shadowRoot.querySelector('#crostini-export-import').click();
-
-        await flushTasks();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-        assertFalse(
-            subpage.shadowRoot.querySelector('#export cr-button').disabled);
-        assertFalse(
-            subpage.shadowRoot.querySelector('#import cr-button').disabled);
-        webUIListenerCallback(
-            'crostini-export-import-operation-status-changed', true);
-
-        await flushTasks();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-        assertTrue(
-            subpage.shadowRoot.querySelector('#export cr-button').disabled);
-        assertTrue(
-            subpage.shadowRoot.querySelector('#import cr-button').disabled);
-        webUIListenerCallback(
-            'crostini-export-import-operation-status-changed', false);
-
-        await flushTasks();
-        subpage = crostiniPage.shadowRoot.querySelector(
-            'settings-crostini-export-import');
-        assertFalse(
-            subpage.shadowRoot.querySelector('#export cr-button').disabled);
-        assertFalse(
-            subpage.shadowRoot.querySelector('#import cr-button').disabled);
-      });
-
-      test(
-          'ExportImportButtonsDisabledOnWhenInstallingCrostini',
-          async function() {
-            assertTrue(
-                !!subpage.shadowRoot.querySelector('#crostini-export-import'));
-            subpage.shadowRoot.querySelector('#crostini-export-import').click();
-
-            await flushTasks();
-            subpage = crostiniPage.shadowRoot.querySelector(
-                'settings-crostini-export-import');
-            assertFalse(
-                subpage.shadowRoot.querySelector('#export cr-button').disabled);
-            assertFalse(
-                subpage.shadowRoot.querySelector('#import cr-button').disabled);
-            webUIListenerCallback('crostini-installer-status-changed', true);
-
-            await flushTasks();
-            subpage = crostiniPage.shadowRoot.querySelector(
-                'settings-crostini-export-import');
-            assertTrue(
-                subpage.shadowRoot.querySelector('#export cr-button').disabled);
-            assertTrue(
-                subpage.shadowRoot.querySelector('#import cr-button').disabled);
-            webUIListenerCallback(
-                'crostini-installer-status-changed', false);
-
-            await flushTasks();
-            subpage = crostiniPage.shadowRoot.querySelector(
-                'settings-crostini-export-import');
-            assertFalse(
-                subpage.shadowRoot.querySelector('#export cr-button').disabled);
-            assertFalse(
-                subpage.shadowRoot.querySelector('#import cr-button').disabled);
-          });
-
       test('ToggleCrostiniMicPermissionCancel', async function() {
         // Crostini is assumed to be running when the page is loaded.
         assertTrue(!!subpage.shadowRoot.querySelector(
@@ -580,6 +490,184 @@
       });
     });
 
+    suite('subPageBackupRestore', function() {
+      /** @type {?SettingsCrostiniExportImportElement} */
+      let subpage;
+
+      setup(async function() {
+        const requestInstallerStatusCallCount =
+            crostiniBrowserProxy.getCallCount('requestCrostiniInstallerStatus');
+
+        loadTimeData.overrideValues({
+          showCrostiniExportImport: true,
+          showCrostiniContainerUpgrade: true,
+          showCrostiniPortForwarding: true,
+          showCrostiniDiskResize: true,
+          arcAdbSideloadingSupported: true,
+          showCrostiniExtraContainers: true,
+        });
+        crostiniBrowserProxy.containerInfo = singleContainer;
+        await flushTasks();
+
+        Router.getInstance().navigateTo(routes.CROSTINI_EXPORT_IMPORT);
+
+        await flushTasks();
+        subpage = crostiniPage.shadowRoot.querySelector(
+            'settings-crostini-export-import');
+
+        assertTrue(!!subpage);
+        assertEquals(
+            1,
+            crostiniBrowserProxy.getCallCount(
+                'requestCrostiniExportImportOperationStatus'));
+        assertEquals(
+            requestInstallerStatusCallCount + 1,
+            crostiniBrowserProxy.getCallCount(
+                'requestCrostiniInstallerStatus'));
+        assertEquals(
+            1, crostiniBrowserProxy.getCallCount('requestContainerInfo'));
+      });
+
+      test('Deep link to backup linux', async () => {
+        const params = new URLSearchParams();
+        params.append('settingId', '802');
+        Router.getInstance().navigateTo(routes.CROSTINI_EXPORT_IMPORT, params);
+
+        flush();
+        subpage = crostiniPage.shadowRoot.querySelector(
+            'settings-crostini-export-import');
+
+        const deepLinkElement =
+            subpage.shadowRoot.querySelector('#export cr-button');
+        await waitAfterNextRender(deepLinkElement);
+        assertEquals(
+            deepLinkElement, getDeepActiveElement(),
+            'Export button should be focused for settingId=802.');
+      });
+
+      test('ExportSingleContainer', async function() {
+        assertFalse(!!subpage.shadowRoot.querySelector(
+            '#exportCrostiniLabel .secondary'));
+        assertTrue(!!subpage.shadowRoot.querySelector('#export cr-button'));
+        subpage.shadowRoot.querySelector('#export cr-button').click();
+        assertEquals(
+            1, crostiniBrowserProxy.getCallCount('exportCrostiniContainer'));
+      });
+
+      test('ExportMultiContainer', async function() {
+        crostiniBrowserProxy.containerInfo = multipleContainers;
+        webUIListenerCallback('crostini-container-info', multipleContainers);
+        await flushTasks();
+
+        assertTrue(!!subpage.shadowRoot.querySelector(
+            '#exportCrostiniLabel .secondary'));
+        const select = subpage.root.querySelector('#exportContainerSelect');
+        selectContainerByIndex(select, 1);
+
+        assertTrue(!!subpage.shadowRoot.querySelector('#export cr-button'));
+        subpage.shadowRoot.querySelector('#export cr-button').click();
+        assertEquals(
+            1, crostiniBrowserProxy.getCallCount('exportCrostiniContainer'));
+        const args = crostiniBrowserProxy.getArgs('exportCrostiniContainer');
+        assertEquals(1, args.length);
+        assertEquals(args[0].vm_name, 'not-termina');
+        assertEquals(args[0].container_name, 'not-penguin');
+      });
+
+      test('ImportSingleContainer', async function() {
+        assertFalse(!!subpage.shadowRoot.querySelector(
+            '#importCrostiniLabel .secondary'));
+        subpage.shadowRoot.querySelector('#import cr-button').click();
+
+        await flushTasks();
+        subpage = subpage.shadowRoot.querySelector(
+            'settings-crostini-import-confirmation-dialog');
+        subpage.shadowRoot.querySelector('cr-dialog cr-button[id="continue"]')
+            .click();
+        assertEquals(
+            1, crostiniBrowserProxy.getCallCount('importCrostiniContainer'));
+      });
+
+      test('ImportMultiContainer', async function() {
+        crostiniBrowserProxy.containerInfo = multipleContainers;
+        webUIListenerCallback('crostini-container-info', multipleContainers);
+        await flushTasks();
+
+        assertTrue(!!subpage.shadowRoot.querySelector(
+            '#importCrostiniLabel .secondary'));
+        const select = subpage.root.querySelector('#importContainerSelect');
+        selectContainerByIndex(select, 1);
+
+        assertTrue(!!subpage.shadowRoot.querySelector('#import cr-button'));
+        subpage.shadowRoot.querySelector('#import cr-button').click();
+        await flushTasks();
+        subpage = subpage.shadowRoot.querySelector(
+            'settings-crostini-import-confirmation-dialog');
+        subpage.shadowRoot.querySelector('cr-dialog cr-button[id="continue"]')
+            .click();
+        assertEquals(
+            1, crostiniBrowserProxy.getCallCount('importCrostiniContainer'));
+        const args = crostiniBrowserProxy.getArgs('importCrostiniContainer');
+        assertEquals(1, args.length);
+        assertEquals(args[0].vm_name, 'not-termina');
+        assertEquals(args[0].container_name, 'not-penguin');
+      });
+
+      test('ExportImportButtonsGetDisabledOnOperationStatus', async function() {
+        assertFalse(
+            subpage.shadowRoot.querySelector('#export cr-button').disabled);
+        assertFalse(
+            subpage.shadowRoot.querySelector('#import cr-button').disabled);
+        webUIListenerCallback(
+            'crostini-export-import-operation-status-changed', true);
+
+        await flushTasks();
+        subpage = crostiniPage.shadowRoot.querySelector(
+            'settings-crostini-export-import');
+        assertTrue(
+            subpage.shadowRoot.querySelector('#export cr-button').disabled);
+        assertTrue(
+            subpage.shadowRoot.querySelector('#import cr-button').disabled);
+        webUIListenerCallback(
+            'crostini-export-import-operation-status-changed', false);
+
+        await flushTasks();
+        subpage = crostiniPage.shadowRoot.querySelector(
+            'settings-crostini-export-import');
+        assertFalse(
+            subpage.shadowRoot.querySelector('#export cr-button').disabled);
+        assertFalse(
+            subpage.shadowRoot.querySelector('#import cr-button').disabled);
+      });
+
+      test(
+          'ExportImportButtonsDisabledOnWhenInstallingCrostini',
+          async function() {
+            assertFalse(
+                subpage.shadowRoot.querySelector('#export cr-button').disabled);
+            assertFalse(
+                subpage.shadowRoot.querySelector('#import cr-button').disabled);
+            webUIListenerCallback('crostini-installer-status-changed', true);
+
+            await flushTasks();
+            subpage = crostiniPage.shadowRoot.querySelector(
+                'settings-crostini-export-import');
+            assertTrue(
+                subpage.shadowRoot.querySelector('#export cr-button').disabled);
+            assertTrue(
+                subpage.shadowRoot.querySelector('#import cr-button').disabled);
+            webUIListenerCallback('crostini-installer-status-changed', false);
+
+            await flushTasks();
+            subpage = crostiniPage.shadowRoot.querySelector(
+                'settings-crostini-export-import');
+            assertFalse(
+                subpage.shadowRoot.querySelector('#export cr-button').disabled);
+            assertFalse(
+                subpage.shadowRoot.querySelector('#import cr-button').disabled);
+          });
+    });
+
     suite('SubPagePortForwarding', function() {
       /** @type {?SettingsCrostiniPortForwarding} */
       let subpage;
diff --git a/chrome/test/data/webui/settings/chromeos/test_crostini_browser_proxy.js b/chrome/test/data/webui/settings/chromeos/test_crostini_browser_proxy.js
index e244f75..c0d7410 100644
--- a/chrome/test/data/webui/settings/chromeos/test_crostini_browser_proxy.js
+++ b/chrome/test/data/webui/settings/chromeos/test_crostini_browser_proxy.js
@@ -38,6 +38,7 @@
       'requestContainerInfo',
       'setContainerBadgeColor',
       'stopContainer',
+      'requestCrostiniExportImportOperationStatus',
     ]);
     this.crostiniMicSharingEnabled = false;
     this.crostiniIsRunning = true;
@@ -100,6 +101,7 @@
 
   /** @override */
   requestCrostiniExportImportOperationStatus() {
+    this.methodCalled('requestCrostiniExportImportOperationStatus');
     webUIListenerCallback(
         'crostini-export-import-operation-status-changed', false);
   }
diff --git a/chromeos/ash/components/dbus/BUILD.gn b/chromeos/ash/components/dbus/BUILD.gn
index 014b6cce..36670ef 100644
--- a/chromeos/ash/components/dbus/BUILD.gn
+++ b/chromeos/ash/components/dbus/BUILD.gn
@@ -26,6 +26,7 @@
     "//chromeos/ash/components/dbus/services:unit_tests",
     "//chromeos/ash/components/dbus/session_manager",
     "//chromeos/ash/components/dbus/system_clock:unit_tests",
+    "//chromeos/ash/components/dbus/update_engine:unit_tests",
     "//chromeos/ash/components/dbus/userdataauth",
     "//chromeos/ash/components/dbus/userdataauth:userdataauth_proto",
     "//chromeos/dbus:test_support",
diff --git a/chromeos/dbus/chunneld/BUILD.gn b/chromeos/ash/components/dbus/chunneld/BUILD.gn
similarity index 73%
rename from chromeos/dbus/chunneld/BUILD.gn
rename to chromeos/ash/components/dbus/chunneld/BUILD.gn
index 74d4328..7854b510 100644
--- a/chromeos/dbus/chunneld/BUILD.gn
+++ b/chromeos/ash/components/dbus/chunneld/BUILD.gn
@@ -5,11 +5,12 @@
 import("//build/config/chromeos/ui_mode.gni")
 import("//third_party/protobuf/proto_library.gni")
 
-assert(is_chromeos_ash, "Non-Chrome-OS builds must not depend on //chromeos")
+assert(is_chromeos_ash,
+       "Non-Chrome-OS builds must not depend on //chromeos/ash")
 
 component("chunneld") {
-  output_name = "chromeos_chunneld"
-  defines = [ "IS_CHROMEOS_DBUS_CHUNNELD_IMPL" ]
+  output_name = "ash_chunneld"
+  defines = [ "IS_ASH_DBUS_CHUNNELD_IMPL" ]
   deps = [
     ":proto",
     "//base",
@@ -28,5 +29,5 @@
   sources =
       [ "//third_party/cros_system_api/dbus/chunneld/chunneld_service.proto" ]
 
-  proto_out_dir = "chromeos/dbus/chunneld"
+  proto_out_dir = "chromeos/ash/components/dbus/chunneld"
 }
diff --git a/chromeos/dbus/chunneld/chunneld_client.cc b/chromeos/ash/components/dbus/chunneld/chunneld_client.cc
similarity index 94%
rename from chromeos/dbus/chunneld/chunneld_client.cc
rename to chromeos/ash/components/dbus/chunneld/chunneld_client.cc
index ed4050ba..14f0b95 100644
--- a/chromeos/dbus/chunneld/chunneld_client.cc
+++ b/chromeos/ash/components/dbus/chunneld/chunneld_client.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/dbus/chunneld/chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 
 #include <memory>
 
@@ -12,12 +12,12 @@
 #include "base/memory/weak_ptr.h"
 #include "base/observer_list.h"
 #include "base/threading/thread_task_runner_handle.h"
-#include "chromeos/dbus/chunneld/fake_chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h"
 #include "dbus/bus.h"
 #include "dbus/message.h"
 #include "third_party/cros_system_api/dbus/chunneld/dbus-constants.h"
 
-namespace chromeos {
+namespace ash {
 namespace {
 
 ChunneldClient* g_instance = nullptr;
@@ -129,4 +129,4 @@
   g_instance = nullptr;
 }
 
-}  // namespace chromeos
+}  // namespace ash
diff --git a/chromeos/dbus/chunneld/chunneld_client.h b/chromeos/ash/components/dbus/chunneld/chunneld_client.h
similarity index 83%
rename from chromeos/dbus/chunneld/chunneld_client.h
rename to chromeos/ash/components/dbus/chunneld/chunneld_client.h
index e6f7af8c..9beaf751 100644
--- a/chromeos/dbus/chunneld/chunneld_client.h
+++ b/chromeos/ash/components/dbus/chunneld/chunneld_client.h
@@ -2,21 +2,20 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
-#define CHROMEOS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
+#define CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
 
 #include "base/component_export.h"
 #include "base/observer_list_types.h"
-#include "chromeos/dbus/chunneld/chunneld_service.pb.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_service.pb.h"
 #include "chromeos/dbus/common/dbus_client.h"
 #include "chromeos/dbus/common/dbus_method_call_status.h"
 #include "dbus/object_proxy.h"
 
-namespace chromeos {
+namespace ash {
 
 // ChunneldClient is used to communicate with chunneld and monitor chunneld.
-class COMPONENT_EXPORT(CHROMEOS_DBUS_CHUNNELD) ChunneldClient
-    : public DBusClient {
+class COMPONENT_EXPORT(ASH_DBUS_CHUNNELD) ChunneldClient : public DBusClient {
  public:
   class Observer : public base::CheckedObserver {
    public:
@@ -62,6 +61,6 @@
   ~ChunneldClient() override;
 };
 
-}  // namespace chromeos
+}  // namespace ash
 
-#endif  // CHROMEOS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_CHUNNELD_CLIENT_H_
diff --git a/chromeos/dbus/chunneld/fake_chunneld_client.cc b/chromeos/ash/components/dbus/chunneld/fake_chunneld_client.cc
similarity index 90%
rename from chromeos/dbus/chunneld/fake_chunneld_client.cc
rename to chromeos/ash/components/dbus/chunneld/fake_chunneld_client.cc
index e44b71f..0fc6def 100644
--- a/chromeos/dbus/chunneld/fake_chunneld_client.cc
+++ b/chromeos/ash/components/dbus/chunneld/fake_chunneld_client.cc
@@ -2,14 +2,14 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/dbus/chunneld/fake_chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h"
 
 #include <utility>
 
 #include "base/bind.h"
 #include "base/threading/thread_task_runner_handle.h"
 
-namespace chromeos {
+namespace ash {
 
 FakeChunneldClient::FakeChunneldClient() {}
 
@@ -40,4 +40,4 @@
       FROM_HERE, base::BindOnce(std::move(callback), true));
 }
 
-}  // namespace chromeos
+}  // namespace ash
diff --git a/chromeos/dbus/chunneld/fake_chunneld_client.h b/chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h
similarity index 72%
rename from chromeos/dbus/chunneld/fake_chunneld_client.h
rename to chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h
index ea4e20d..63dfd79 100644
--- a/chromeos/dbus/chunneld/fake_chunneld_client.h
+++ b/chromeos/ash/components/dbus/chunneld/fake_chunneld_client.h
@@ -2,18 +2,18 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
-#define CHROMEOS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
+#define CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
 
 #include "base/component_export.h"
 #include "base/observer_list.h"
-#include "chromeos/dbus/chunneld/chunneld_client.h"
+#include "chromeos/ash/components/dbus/chunneld/chunneld_client.h"
 
-namespace chromeos {
+namespace ash {
 
 // FakeChunneldClient is a stub implementation of ChunneldClient used for
 // testing.
-class COMPONENT_EXPORT(CHROMEOS_DBUS_CHUNNELD) FakeChunneldClient
+class COMPONENT_EXPORT(ASH_DBUS_CHUNNELD) FakeChunneldClient
     : public ChunneldClient {
  public:
   FakeChunneldClient();
@@ -37,6 +37,6 @@
   base::ObserverList<Observer> observer_list_;
 };
 
-}  // namespace chromeos
+}  // namespace ash
 
-#endif  // CHROMEOS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_DBUS_CHUNNELD_FAKE_CHUNNELD_CLIENT_H_
diff --git a/chromeos/dbus/update_engine/BUILD.gn b/chromeos/ash/components/dbus/update_engine/BUILD.gn
similarity index 84%
rename from chromeos/dbus/update_engine/BUILD.gn
rename to chromeos/ash/components/dbus/update_engine/BUILD.gn
index 94032d4..08cfea3 100644
--- a/chromeos/dbus/update_engine/BUILD.gn
+++ b/chromeos/ash/components/dbus/update_engine/BUILD.gn
@@ -8,14 +8,13 @@
 assert(is_chromeos_ash, "Non-Chrome-OS builds must not depend on //chromeos")
 
 component("update_engine") {
-  output_name = "chromeos_update_engine"
-  defines = [ "IS_CHROMEOS_DBUS_UPDATE_ENGINE_IMPL" ]
+  output_name = "ash_update_engine"
+  defines = [ "IS_ASH_DBUS_UPDATE_ENGINE_IMPL" ]
   deps = [
     ":proto",
     "//base",
     "//chromeos/dbus/common",
     "//chromeos/dbus/constants",
-    "//chromeos/dbus/util",
     "//dbus",
   ]
   sources = [
@@ -40,5 +39,5 @@
   sources =
       [ "//third_party/cros_system_api/dbus/update_engine/update_engine.proto" ]
 
-  proto_out_dir = "chromeos/dbus/update_engine"
+  proto_out_dir = "chromeos/ash/components/dbus/update_engine"
 }
diff --git a/chromeos/dbus/update_engine/fake_update_engine_client.cc b/chromeos/ash/components/dbus/update_engine/fake_update_engine_client.cc
similarity index 97%
rename from chromeos/dbus/update_engine/fake_update_engine_client.cc
rename to chromeos/ash/components/dbus/update_engine/fake_update_engine_client.cc
index c2d6b2c6..7391a89 100644
--- a/chromeos/dbus/update_engine/fake_update_engine_client.cc
+++ b/chromeos/ash/components/dbus/update_engine/fake_update_engine_client.cc
@@ -2,14 +2,14 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 
 #include "base/bind.h"
 #include "base/callback.h"
 #include "base/threading/thread_task_runner_handle.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 
-namespace chromeos {
+namespace ash {
 
 FakeUpdateEngineClient::FakeUpdateEngineClient() {}
 
@@ -137,4 +137,4 @@
   features_[feature] = opt_enabled;
 }
 
-}  // namespace chromeos
+}  // namespace ash
diff --git a/chromeos/dbus/update_engine/fake_update_engine_client.h b/chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h
similarity index 91%
rename from chromeos/dbus/update_engine/fake_update_engine_client.h
rename to chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h
index d2289fb..e6c7832 100644
--- a/chromeos/dbus/update_engine/fake_update_engine_client.h
+++ b/chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
-#define CHROMEOS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
+#define CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
 
 #include <map>
 #include <string>
@@ -13,16 +13,16 @@
 #include "base/containers/queue.h"
 #include "base/observer_list.h"
 #include "base/time/time.h"
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 
-namespace chromeos {
+namespace ash {
 
 // A fake implementation of UpdateEngineClient. The user of this class can
 // use set_update_engine_client_status() to set a fake last Status and
 // GetLastStatus() returns the fake with no modification. Other methods do
 // nothing.
-class COMPONENT_EXPORT(CHROMEOS_DBUS_UPDATE_ENGINE) FakeUpdateEngineClient
+class COMPONENT_EXPORT(ASH_DBUS_UPDATE_ENGINE) FakeUpdateEngineClient
     : public UpdateEngineClient {
  public:
   FakeUpdateEngineClient();
@@ -150,12 +150,6 @@
   base::Time eol_date_;
 };
 
-}  // namespace chromeos
+}  // namespace ash
 
-// TODO(https://crbug.com/1164001): remove when Chrome OS code migration is
-// done.
-namespace ash {
-using ::chromeos::FakeUpdateEngineClient;
-}
-
-#endif  // CHROMEOS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_FAKE_UPDATE_ENGINE_CLIENT_H_
diff --git a/chromeos/dbus/update_engine/update_engine_client.cc b/chromeos/ash/components/dbus/update_engine/update_engine_client.cc
similarity index 98%
rename from chromeos/dbus/update_engine/update_engine_client.cc
rename to chromeos/ash/components/dbus/update_engine/update_engine_client.cc
index 1e637209..898526b 100644
--- a/chromeos/dbus/update_engine/update_engine_client.cc
+++ b/chromeos/ash/components/dbus/update_engine/update_engine_client.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 #include <stdint.h>
 
@@ -19,16 +19,15 @@
 #include "base/strings/string_util.h"
 #include "base/task/single_thread_task_runner.h"
 #include "base/threading/thread_task_runner_handle.h"
+#include "chromeos/ash/components/dbus/update_engine/fake_update_engine_client.h"
 #include "chromeos/dbus/constants/dbus_switches.h"
-#include "chromeos/dbus/update_engine/fake_update_engine_client.h"
-#include "chromeos/dbus/util/version_loader.h"
 #include "dbus/bus.h"
 #include "dbus/message.h"
 #include "dbus/object_path.h"
 #include "dbus/object_proxy.h"
 #include "third_party/cros_system_api/dbus/service_constants.h"
 
-namespace chromeos {
+namespace ash {
 
 namespace {
 
@@ -801,4 +800,4 @@
   g_instance = nullptr;
 }
 
-}  // namespace chromeos
+}  // namespace ash
diff --git a/chromeos/dbus/update_engine/update_engine_client.h b/chromeos/ash/components/dbus/update_engine/update_engine_client.h
similarity index 94%
rename from chromeos/dbus/update_engine/update_engine_client.h
rename to chromeos/ash/components/dbus/update_engine/update_engine_client.h
index c168d60..9516a62 100644
--- a/chromeos/dbus/update_engine/update_engine_client.h
+++ b/chromeos/ash/components/dbus/update_engine/update_engine_client.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
-#define CHROMEOS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
+#define CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
 
 #include <stdint.h>
 
@@ -12,18 +12,18 @@
 #include "base/callback.h"
 #include "base/component_export.h"
 #include "base/time/time.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine.pb.h"
 #include "chromeos/dbus/common/dbus_client.h"
-#include "chromeos/dbus/update_engine/update_engine.pb.h"
 #include "dbus/message.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 #include "third_party/cros_system_api/dbus/update_engine/dbus-constants.h"
 
-namespace chromeos {
+namespace ash {
 
 class FakeUpdateEngineClient;
 
 // UpdateEngineClient is used to communicate with the update engine.
-class COMPONENT_EXPORT(CHROMEOS_DBUS_UPDATE_ENGINE) UpdateEngineClient
+class COMPONENT_EXPORT(ASH_DBUS_UPDATE_ENGINE) UpdateEngineClient
     : public DBusClient {
  public:
   // The result code used for RequestUpdateCheck().
@@ -195,12 +195,6 @@
   ~UpdateEngineClient() override;
 };
 
-}  // namespace chromeos
+}  // namespace ash
 
-// TODO(https://crbug.com/1164001): remove when Chrome OS code migration is
-// done.
-namespace ash {
-using ::chromeos::UpdateEngineClient;
-}
-
-#endif  // CHROMEOS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_DBUS_UPDATE_ENGINE_UPDATE_ENGINE_CLIENT_H_
diff --git a/chromeos/dbus/update_engine/update_engine_client_unittest.cc b/chromeos/ash/components/dbus/update_engine/update_engine_client_unittest.cc
similarity index 96%
rename from chromeos/dbus/update_engine/update_engine_client_unittest.cc
rename to chromeos/ash/components/dbus/update_engine/update_engine_client_unittest.cc
index f5d23a09..4f92137 100644
--- a/chromeos/dbus/update_engine/update_engine_client_unittest.cc
+++ b/chromeos/ash/components/dbus/update_engine/update_engine_client_unittest.cc
@@ -2,11 +2,11 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/dbus/update_engine/update_engine_client.h"
+#include "chromeos/ash/components/dbus/update_engine/update_engine_client.h"
 
 #include "testing/gtest/include/gtest/gtest.h"
 
-namespace chromeos {
+namespace ash {
 
 TEST(UpdateEngineClientTest, IsTargetChannelMoreStable) {
   EXPECT_FALSE(UpdateEngineClient::IsTargetChannelMoreStable("stable-channel",
@@ -53,4 +53,4 @@
       "other-invalid-channel", "invalid-channel"));
 }
 
-}  // namespace chromeos
+}  // namespace ash
diff --git a/chromeos/ash/components/network/BUILD.gn b/chromeos/ash/components/network/BUILD.gn
index 1474db5..9bc81c5 100644
--- a/chromeos/ash/components/network/BUILD.gn
+++ b/chromeos/ash/components/network/BUILD.gn
@@ -20,6 +20,7 @@
     "//chromeos/ash/components/network/proxy",
     "//chromeos/components/feature_usage",
     "//chromeos/components/onc",
+    "//chromeos/dbus/common",
     "//chromeos/dbus/hermes",
     "//chromeos/dbus/permission_broker",
     "//chromeos/dbus/shill",
@@ -88,6 +89,27 @@
     "managed_network_configuration_handler_impl.h",
     "managed_state.cc",
     "managed_state.h",
+    "network_activation_handler.h",
+    "network_activation_handler_impl.cc",
+    "network_activation_handler_impl.h",
+    "network_cert_loader.cc",
+    "network_cert_loader.h",
+    "network_cert_migrator.cc",
+    "network_cert_migrator.h",
+    "network_certificate_handler.cc",
+    "network_certificate_handler.h",
+    "network_configuration_handler.cc",
+    "network_configuration_handler.h",
+    "network_configuration_observer.cc",
+    "network_configuration_observer.h",
+    "network_connect.cc",
+    "network_connect.h",
+    "network_connection_handler.cc",
+    "network_connection_handler.h",
+    "network_connection_handler_impl.cc",
+    "network_connection_handler_impl.h",
+    "network_connection_observer.cc",
+    "network_connection_observer.h",
   ]
 }
 
@@ -187,5 +209,10 @@
     "geolocation_handler_unittest.cc",
     "managed_cellular_pref_handler_unittest.cc",
     "managed_network_configuration_handler_unittest.cc",
+    "network_cert_loader_unittest.cc",
+    "network_cert_migrator_unittest.cc",
+    "network_configuration_handler_unittest.cc",
+    "network_connect_unittest.cc",
+    "network_connection_handler_impl_unittest.cc",
   ]
 }
diff --git a/chromeos/ash/components/network/auto_connect_handler.cc b/chromeos/ash/components/network/auto_connect_handler.cc
index e39ad67b..55a708a0 100644
--- a/chromeos/ash/components/network/auto_connect_handler.cc
+++ b/chromeos/ash/components/network/auto_connect_handler.cc
@@ -15,9 +15,9 @@
 #include "base/values.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_type_pattern.h"
diff --git a/chromeos/ash/components/network/auto_connect_handler.h b/chromeos/ash/components/network/auto_connect_handler.h
index 13d48181..51a9d93a 100644
--- a/chromeos/ash/components/network/auto_connect_handler.h
+++ b/chromeos/ash/components/network/auto_connect_handler.h
@@ -12,8 +12,8 @@
 #include "base/observer_list.h"
 #include "base/scoped_observation.h"
 #include "chromeos/ash/components/network/client_cert_resolver.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_observer.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_policy_observer.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/ash/components/network/auto_connect_handler_unittest.cc b/chromeos/ash/components/network/auto_connect_handler_unittest.cc
index 502794a..6dcc32b 100644
--- a/chromeos/ash/components/network/auto_connect_handler_unittest.cc
+++ b/chromeos/ash/components/network/auto_connect_handler_unittest.cc
@@ -18,10 +18,10 @@
 #include "base/test/task_environment.h"
 #include "chromeos/ash/components/network/client_cert_resolver.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
diff --git a/chromeos/ash/components/network/cellular_connection_handler.cc b/chromeos/ash/components/network/cellular_connection_handler.cc
index 225a9d8..03dc8436 100644
--- a/chromeos/ash/components/network/cellular_connection_handler.cc
+++ b/chromeos/ash/components/network/cellular_connection_handler.cc
@@ -11,10 +11,10 @@
 #include "chromeos/ash/components/network/cellular_esim_profile_handler.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/hermes_metrics_util.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
 #include "chromeos/dbus/hermes/hermes_manager_client.h"
 #include "chromeos/dbus/hermes/hermes_profile_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_type_pattern.h"
diff --git a/chromeos/ash/components/network/cellular_connection_handler_unittest.cc b/chromeos/ash/components/network/cellular_connection_handler_unittest.cc
index d9bab65..280a70bf 100644
--- a/chromeos/ash/components/network/cellular_connection_handler_unittest.cc
+++ b/chromeos/ash/components/network/cellular_connection_handler_unittest.cc
@@ -16,9 +16,9 @@
 #include "base/time/time.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/fake_stub_cellular_networks_provider.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/testing_pref_service.h"
 #include "testing/gtest/include/gtest/gtest.h"
diff --git a/chromeos/ash/components/network/cellular_esim_installer.cc b/chromeos/ash/components/network/cellular_esim_installer.cc
index 157c45aa..db50ac0 100644
--- a/chromeos/ash/components/network/cellular_esim_installer.cc
+++ b/chromeos/ash/components/network/cellular_esim_installer.cc
@@ -10,10 +10,10 @@
 #include "chromeos/ash/components/network/cellular_connection_handler.h"
 #include "chromeos/ash/components/network/cellular_utils.h"
 #include "chromeos/ash/components/network/hermes_metrics_util.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
 #include "chromeos/dbus/hermes/hermes_profile_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/ash/components/network/cellular_esim_installer_unittest.cc b/chromeos/ash/components/network/cellular_esim_installer_unittest.cc
index 9111923..4e1636f 100644
--- a/chromeos/ash/components/network/cellular_esim_installer_unittest.cc
+++ b/chromeos/ash/components/network/cellular_esim_installer_unittest.cc
@@ -14,6 +14,7 @@
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/fake_network_connection_handler.h"
 #include "chromeos/ash/components/network/fake_stub_cellular_networks_provider.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
@@ -24,7 +25,6 @@
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/ash/components/network/cellular_esim_uninstall_handler.cc b/chromeos/ash/components/network/cellular_esim_uninstall_handler.cc
index 9004c9c..7afd1f43 100644
--- a/chromeos/ash/components/network/cellular_esim_uninstall_handler.cc
+++ b/chromeos/ash/components/network/cellular_esim_uninstall_handler.cc
@@ -12,10 +12,10 @@
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/hermes_metrics_util.h"
 #include "chromeos/ash/components/network/managed_cellular_pref_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
 #include "chromeos/dbus/hermes/hermes_profile_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "components/device_event_log/device_event_log.h"
diff --git a/chromeos/ash/components/network/cellular_esim_uninstall_handler_unittest.cc b/chromeos/ash/components/network/cellular_esim_uninstall_handler_unittest.cc
index 8e7deb28..7d1c91d 100644
--- a/chromeos/ash/components/network/cellular_esim_uninstall_handler_unittest.cc
+++ b/chromeos/ash/components/network/cellular_esim_uninstall_handler_unittest.cc
@@ -14,6 +14,8 @@
 #include "chromeos/ash/components/network/fake_network_connection_handler.h"
 #include "chromeos/ash/components/network/fake_stub_cellular_networks_provider.h"
 #include "chromeos/ash/components/network/managed_cellular_pref_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/hermes/hermes_euicc_client.h"
@@ -22,8 +24,6 @@
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/testing_pref_service.h"
diff --git a/chromeos/ash/components/network/cellular_metrics_logger.cc b/chromeos/ash/components/network/cellular_metrics_logger.cc
index ac5bce9..e419661 100644
--- a/chromeos/ash/components/network/cellular_metrics_logger.cc
+++ b/chromeos/ash/components/network/cellular_metrics_logger.cc
@@ -12,9 +12,9 @@
 #include "chromeos/ash/components/network/cellular_esim_profile.h"
 #include "chromeos/ash/components/network/cellular_esim_profile_handler.h"
 #include "chromeos/ash/components/network/cellular_utils.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/components/feature_usage/feature_usage_metrics.h"
 #include "chromeos/dbus/hermes/hermes_manager_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/pref_registry_simple.h"
diff --git a/chromeos/ash/components/network/cellular_metrics_logger.h b/chromeos/ash/components/network/cellular_metrics_logger.h
index c165a05..89a6cc09 100644
--- a/chromeos/ash/components/network/cellular_metrics_logger.h
+++ b/chromeos/ash/components/network/cellular_metrics_logger.h
@@ -12,8 +12,8 @@
 #include "base/time/time.h"
 #include "base/timer/elapsed_timer.h"
 #include "base/timer/timer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
diff --git a/chromeos/ash/components/network/cellular_metrics_logger_unittest.cc b/chromeos/ash/components/network/cellular_metrics_logger_unittest.cc
index b7abb16..584ffca 100644
--- a/chromeos/ash/components/network/cellular_metrics_logger_unittest.cc
+++ b/chromeos/ash/components/network/cellular_metrics_logger_unittest.cc
@@ -13,11 +13,11 @@
 #include "base/time/time.h"
 #include "chromeos/ash/components/network/cellular_esim_profile.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/components/feature_usage/feature_usage_metrics.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_ui_data.h"
 #include "dbus/object_path.h"
diff --git a/chromeos/ash/components/network/cellular_policy_handler_unittest.cc b/chromeos/ash/components/network/cellular_policy_handler_unittest.cc
index 2468c0cc..ad73836 100644
--- a/chromeos/ash/components/network/cellular_policy_handler_unittest.cc
+++ b/chromeos/ash/components/network/cellular_policy_handler_unittest.cc
@@ -18,14 +18,14 @@
 #include "chromeos/ash/components/network/fake_network_connection_handler.h"
 #include "chromeos/ash/components/network/managed_cellular_pref_handler.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/components/onc/onc_utils.h"
 #include "chromeos/dbus/hermes/hermes_clients.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/ash/components/network/client_cert_resolver.h b/chromeos/ash/components/network/client_cert_resolver.h
index 729bf26..4c7045af 100644
--- a/chromeos/ash/components/network/client_cert_resolver.h
+++ b/chromeos/ash/components/network/client_cert_resolver.h
@@ -18,7 +18,7 @@
 #include "base/sequence_checker.h"
 #include "base/time/time.h"
 #include "chromeos/ash/components/network/client_cert_util.h"
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/network/network_policy_observer.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
diff --git a/chromeos/ash/components/network/client_cert_resolver_unittest.cc b/chromeos/ash/components/network/client_cert_resolver_unittest.cc
index 1cdc8a1f..7778ac4fe 100644
--- a/chromeos/ash/components/network/client_cert_resolver_unittest.cc
+++ b/chromeos/ash/components/network/client_cert_resolver_unittest.cc
@@ -20,14 +20,14 @@
 #include "base/test/task_environment.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/onc/onc_certificate_importer_impl.h"
 #include "chromeos/components/onc/onc_test_utils.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
diff --git a/chromeos/ash/components/network/fake_network_activation_handler.h b/chromeos/ash/components/network/fake_network_activation_handler.h
index 49e109e..ce469618 100644
--- a/chromeos/ash/components/network/fake_network_activation_handler.h
+++ b/chromeos/ash/components/network/fake_network_activation_handler.h
@@ -8,7 +8,7 @@
 #include <string>
 
 #include "base/component_export.h"
-#include "chromeos/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 
 namespace chromeos {
diff --git a/chromeos/ash/components/network/fake_network_connection_handler.h b/chromeos/ash/components/network/fake_network_connection_handler.h
index 0757cf40..6bd9d63 100644
--- a/chromeos/ash/components/network/fake_network_connection_handler.h
+++ b/chromeos/ash/components/network/fake_network_connection_handler.h
@@ -10,7 +10,7 @@
 
 #include "base/callback_forward.h"
 #include "base/component_export.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 
 namespace chromeos {
diff --git a/chromeos/ash/components/network/managed_network_configuration_handler_impl.cc b/chromeos/ash/components/network/managed_network_configuration_handler_impl.cc
index d6deca8..89bb14e 100644
--- a/chromeos/ash/components/network/managed_network_configuration_handler_impl.cc
+++ b/chromeos/ash/components/network/managed_network_configuration_handler_impl.cc
@@ -24,6 +24,7 @@
 #include "chromeos/ash/components/network/client_cert_util.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/onc/onc_merger.h"
 #include "chromeos/ash/components/network/onc/onc_translator.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
@@ -33,7 +34,6 @@
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_policy_observer.h"
diff --git a/chromeos/ash/components/network/managed_network_configuration_handler_unittest.cc b/chromeos/ash/components/network/managed_network_configuration_handler_unittest.cc
index 707ccc1..785862d 100644
--- a/chromeos/ash/components/network/managed_network_configuration_handler_unittest.cc
+++ b/chromeos/ash/components/network/managed_network_configuration_handler_unittest.cc
@@ -23,6 +23,8 @@
 #include "chromeos/ash/components/network/managed_cellular_pref_handler.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
 #include "chromeos/ash/components/network/mock_network_state_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
 #include "chromeos/components/onc/onc_signature.h"
@@ -34,8 +36,6 @@
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_policy_observer.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/chromeos/ash/components/network/metrics/connection_info_metrics_logger.cc b/chromeos/ash/components/network/metrics/connection_info_metrics_logger.cc
index de4fb0d..e753120 100644
--- a/chromeos/ash/components/network/metrics/connection_info_metrics_logger.cc
+++ b/chromeos/ash/components/network/metrics/connection_info_metrics_logger.cc
@@ -7,7 +7,7 @@
 #include "base/containers/contains.h"
 #include "base/containers/flat_set.h"
 #include "chromeos/ash/components/network/metrics/network_metrics_helper.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
 #include "third_party/cros_system_api/dbus/shill/dbus-constants.h"
diff --git a/chromeos/ash/components/network/metrics/connection_info_metrics_logger.h b/chromeos/ash/components/network/metrics/connection_info_metrics_logger.h
index 094afb5..2d850e6 100644
--- a/chromeos/ash/components/network/metrics/connection_info_metrics_logger.h
+++ b/chromeos/ash/components/network/metrics/connection_info_metrics_logger.h
@@ -7,7 +7,7 @@
 
 #include "base/component_export.h"
 #include "base/containers/flat_map.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 
diff --git a/chromeos/ash/components/network/metrics/connection_info_metrics_logger_unittest.cc b/chromeos/ash/components/network/metrics/connection_info_metrics_logger_unittest.cc
index 47cfaf8..9e7111e 100644
--- a/chromeos/ash/components/network/metrics/connection_info_metrics_logger_unittest.cc
+++ b/chromeos/ash/components/network/metrics/connection_info_metrics_logger_unittest.cc
@@ -11,9 +11,9 @@
 #include "base/test/task_environment.h"
 #include "chromeos/ash/components/network/metrics/connection_results.h"
 #include "chromeos/ash/components/network/metrics/network_metrics_helper.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "components/prefs/testing_pref_service.h"
 #include "testing/gtest/include/gtest/gtest.h"
@@ -257,4 +257,4 @@
                                        ShillConnectResult::kSuccess, 1);
 }
 
-}  // namespace chromeos
\ No newline at end of file
+}  // namespace chromeos
diff --git a/chromeos/ash/components/network/metrics/connection_results.cc b/chromeos/ash/components/network/metrics/connection_results.cc
index b6341bec..0439173 100644
--- a/chromeos/ash/components/network/metrics/connection_results.cc
+++ b/chromeos/ash/components/network/metrics/connection_results.cc
@@ -4,7 +4,7 @@
 
 #include "chromeos/ash/components/network/metrics/connection_results.h"
 
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "third_party/cros_system_api/dbus/service_constants.h"
 
 namespace chromeos {
diff --git a/chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger_unittest.cc b/chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger_unittest.cc
index f187109..9c8bef46 100644
--- a/chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger_unittest.cc
+++ b/chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger_unittest.cc
@@ -10,9 +10,9 @@
 #include "base/test/task_environment.h"
 #include "base/time/time.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_ui_data.h"
diff --git a/chromeos/ash/components/network/metrics/vpn_network_metrics_helper.h b/chromeos/ash/components/network/metrics/vpn_network_metrics_helper.h
index ef99aba7..0fd377e 100644
--- a/chromeos/ash/components/network/metrics/vpn_network_metrics_helper.h
+++ b/chromeos/ash/components/network/metrics/vpn_network_metrics_helper.h
@@ -9,8 +9,8 @@
 
 #include "base/component_export.h"
 #include "base/scoped_observation.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_configuration_observer.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 
 namespace chromeos {
 
diff --git a/chromeos/ash/components/network/metrics/vpn_network_metrics_helper_unittest.cc b/chromeos/ash/components/network/metrics/vpn_network_metrics_helper_unittest.cc
index 7b7db10..dfe97ba 100644
--- a/chromeos/ash/components/network/metrics/vpn_network_metrics_helper_unittest.cc
+++ b/chromeos/ash/components/network/metrics/vpn_network_metrics_helper_unittest.cc
@@ -12,9 +12,9 @@
 #include "base/test/metrics/histogram_tester.h"
 #include "base/test/task_environment.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_ui_data.h"
 #include "chromeos/network/shill_property_util.h"
diff --git a/chromeos/network/network_activation_handler.h b/chromeos/ash/components/network/network_activation_handler.h
similarity index 86%
rename from chromeos/network/network_activation_handler.h
rename to chromeos/ash/components/network/network_activation_handler.h
index 88a5d2c..790f1fbd 100644
--- a/chromeos/network/network_activation_handler.h
+++ b/chromeos/ash/components/network/network_activation_handler.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
-#define CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
 
 #include <string>
 
@@ -43,4 +43,4 @@
 using ::chromeos::NetworkActivationHandler;
 }
 
-#endif  // CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_H_
diff --git a/chromeos/network/network_activation_handler_impl.cc b/chromeos/ash/components/network/network_activation_handler_impl.cc
similarity index 94%
rename from chromeos/network/network_activation_handler_impl.cc
rename to chromeos/ash/components/network/network_activation_handler_impl.cc
index 24953130..29a9492 100644
--- a/chromeos/network/network_activation_handler_impl.cc
+++ b/chromeos/ash/components/network/network_activation_handler_impl.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_activation_handler_impl.h"
+#include "chromeos/ash/components/network/network_activation_handler_impl.h"
 
 #include "base/bind.h"
 #include "base/callback_helpers.h"
diff --git a/chromeos/network/network_activation_handler_impl.h b/chromeos/ash/components/network/network_activation_handler_impl.h
similarity index 80%
rename from chromeos/network/network_activation_handler_impl.h
rename to chromeos/ash/components/network/network_activation_handler_impl.h
index e58a154..f241a94 100644
--- a/chromeos/network/network_activation_handler_impl.h
+++ b/chromeos/ash/components/network/network_activation_handler_impl.h
@@ -2,14 +2,14 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
-#define CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
 
 #include <string>
 
 #include "base/component_export.h"
 #include "base/memory/weak_ptr.h"
-#include "chromeos/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 
 namespace chromeos {
@@ -43,4 +43,4 @@
 
 }  // namespace chromeos
 
-#endif  // CHROMEOS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_ACTIVATION_HANDLER_IMPL_H_
diff --git a/chromeos/network/network_cert_loader.cc b/chromeos/ash/components/network/network_cert_loader.cc
similarity index 99%
rename from chromeos/network/network_cert_loader.cc
rename to chromeos/ash/components/network/network_cert_loader.cc
index d682296..19139d0 100644
--- a/chromeos/network/network_cert_loader.cc
+++ b/chromeos/ash/components/network/network_cert_loader.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 
 #include <algorithm>
 #include <initializer_list>
diff --git a/chromeos/network/network_cert_loader.h b/chromeos/ash/components/network/network_cert_loader.h
similarity index 98%
rename from chromeos/network/network_cert_loader.h
rename to chromeos/ash/components/network/network_cert_loader.h
index 9ab81af..f7be40b 100644
--- a/chromeos/network/network_cert_loader.h
+++ b/chromeos/ash/components/network/network_cert_loader.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CERT_LOADER_H_
-#define CHROMEOS_NETWORK_NETWORK_CERT_LOADER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_LOADER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_LOADER_H_
 
 #include <string>
 #include <vector>
@@ -284,4 +284,4 @@
 using ::chromeos::NetworkCertLoader;
 }
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CERT_LOADER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_LOADER_H_
diff --git a/chromeos/network/network_cert_loader_unittest.cc b/chromeos/ash/components/network/network_cert_loader_unittest.cc
similarity index 99%
rename from chromeos/network/network_cert_loader_unittest.cc
rename to chromeos/ash/components/network/network_cert_loader_unittest.cc
index 61656ab84..6b33453 100644
--- a/chromeos/network/network_cert_loader_unittest.cc
+++ b/chromeos/ash/components/network/network_cert_loader_unittest.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 
 #include <stddef.h>
 
diff --git a/chromeos/network/network_cert_migrator.cc b/chromeos/ash/components/network/network_cert_migrator.cc
similarity index 98%
rename from chromeos/network/network_cert_migrator.cc
rename to chromeos/ash/components/network/network_cert_migrator.cc
index 45e550d..cac2849 100644
--- a/chromeos/network/network_cert_migrator.cc
+++ b/chromeos/ash/components/network/network_cert_migrator.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_cert_migrator.h"
+#include "chromeos/ash/components/network/network_cert_migrator.h"
 
 #include <cert.h>
 #include <string>
diff --git a/chromeos/network/network_cert_migrator.h b/chromeos/ash/components/network/network_cert_migrator.h
similarity index 85%
rename from chromeos/network/network_cert_migrator.h
rename to chromeos/ash/components/network/network_cert_migrator.h
index 1b4da782..ed43b3b 100644
--- a/chromeos/network/network_cert_migrator.h
+++ b/chromeos/ash/components/network/network_cert_migrator.h
@@ -2,13 +2,13 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CERT_MIGRATOR_H_
-#define CHROMEOS_NETWORK_NETWORK_CERT_MIGRATOR_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_MIGRATOR_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_MIGRATOR_H_
 
 #include "base/component_export.h"
 #include "base/memory/weak_ptr.h"
 #include "base/scoped_observation.h"
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 
@@ -52,4 +52,4 @@
 
 }  // namespace chromeos
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CERT_MIGRATOR_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERT_MIGRATOR_H_
diff --git a/chromeos/network/network_cert_migrator_unittest.cc b/chromeos/ash/components/network/network_cert_migrator_unittest.cc
similarity index 98%
rename from chromeos/network/network_cert_migrator_unittest.cc
rename to chromeos/ash/components/network/network_cert_migrator_unittest.cc
index 1235747b..415d3af 100644
--- a/chromeos/network/network_cert_migrator_unittest.cc
+++ b/chromeos/ash/components/network/network_cert_migrator_unittest.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_cert_migrator.h"
+#include "chromeos/ash/components/network/network_cert_migrator.h"
 
 #include <cert.h>
 #include <pk11pub.h>
@@ -11,10 +11,10 @@
 #include "base/files/file_path.h"
 #include "base/strings/string_number_conversions.h"
 #include "base/test/task_environment.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_cert_loader.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/system_token_cert_db_storage.h"
 #include "crypto/scoped_nss_types.h"
diff --git a/chromeos/network/network_certificate_handler.cc b/chromeos/ash/components/network/network_certificate_handler.cc
similarity index 97%
rename from chromeos/network/network_certificate_handler.cc
rename to chromeos/ash/components/network/network_certificate_handler.cc
index f069e8a..73609d2 100644
--- a/chromeos/network/network_certificate_handler.cc
+++ b/chromeos/ash/components/network/network_certificate_handler.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
 
 #include "base/logging.h"
 #include "base/strings/stringprintf.h"
diff --git a/chromeos/network/network_certificate_handler.h b/chromeos/ash/components/network/network_certificate_handler.h
similarity index 91%
rename from chromeos/network/network_certificate_handler.h
rename to chromeos/ash/components/network/network_certificate_handler.h
index d4137ef0..481025a 100644
--- a/chromeos/network/network_certificate_handler.h
+++ b/chromeos/ash/components/network/network_certificate_handler.h
@@ -2,14 +2,14 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
-#define CHROMEOS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
 
 #include <string>
 #include <vector>
 
 #include "base/component_export.h"
-#include "chromeos/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
 
 namespace chromeos {
 
@@ -107,4 +107,4 @@
 
 }  // namespace chromeos
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CERTIFICATE_HANDLER_H_
diff --git a/chromeos/network/network_configuration_handler.cc b/chromeos/ash/components/network/network_configuration_handler.cc
similarity index 99%
rename from chromeos/network/network_configuration_handler.cc
rename to chromeos/ash/components/network/network_configuration_handler.cc
index a6279fa..ba144ed 100644
--- a/chromeos/network/network_configuration_handler.cc
+++ b/chromeos/ash/components/network/network_configuration_handler.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 
 #include <stddef.h>
 
diff --git a/chromeos/network/network_configuration_handler.h b/chromeos/ash/components/network/network_configuration_handler.h
similarity index 97%
rename from chromeos/network/network_configuration_handler.h
rename to chromeos/ash/components/network/network_configuration_handler.h
index d079253..099447e8 100644
--- a/chromeos/network/network_configuration_handler.h
+++ b/chromeos/ash/components/network/network_configuration_handler.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
-#define CHROMEOS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
 
 #include <map>
 #include <memory>
@@ -17,8 +17,8 @@
 #include "base/observer_list.h"
 #include "base/scoped_observation.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 #include "chromeos/dbus/common/dbus_method_call_status.h"
-#include "chromeos/network/network_configuration_observer.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "chromeos/network/network_state_handler.h"
@@ -255,4 +255,4 @@
 using ::chromeos::NetworkConfigurationHandler;
 }  // namespace ash
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_HANDLER_H_
diff --git a/chromeos/network/network_configuration_handler_unittest.cc b/chromeos/ash/components/network/network_configuration_handler_unittest.cc
similarity index 99%
rename from chromeos/network/network_configuration_handler_unittest.cc
rename to chromeos/ash/components/network/network_configuration_handler_unittest.cc
index de2b644..5b19e98d 100644
--- a/chromeos/network/network_configuration_handler_unittest.cc
+++ b/chromeos/ash/components/network/network_configuration_handler_unittest.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 
 #include <stddef.h>
 
@@ -17,11 +17,11 @@
 #include "base/task/single_thread_task_runner.h"
 #include "base/test/task_environment.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_observer.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/network/network_configuration_observer.cc b/chromeos/ash/components/network/network_configuration_observer.cc
similarity index 92%
rename from chromeos/network/network_configuration_observer.cc
rename to chromeos/ash/components/network/network_configuration_observer.cc
index b9cb306..8b40539 100644
--- a/chromeos/network/network_configuration_observer.cc
+++ b/chromeos/ash/components/network/network_configuration_observer.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_configuration_observer.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 
 namespace chromeos {
 
diff --git a/chromeos/network/network_configuration_observer.h b/chromeos/ash/components/network/network_configuration_observer.h
similarity index 88%
rename from chromeos/network/network_configuration_observer.h
rename to chromeos/ash/components/network/network_configuration_observer.h
index 2df8f5a..461b5c58 100644
--- a/chromeos/network/network_configuration_observer.h
+++ b/chromeos/ash/components/network/network_configuration_observer.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
-#define CHROMEOS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
 
 #include <string>
 
@@ -51,4 +51,4 @@
 
 }  // namespace chromeos
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONFIGURATION_OBSERVER_H_
diff --git a/chromeos/network/network_connect.cc b/chromeos/ash/components/network/network_connect.cc
similarity index 98%
rename from chromeos/network/network_connect.cc
rename to chromeos/ash/components/network/network_connect.cc
index 6561249e..1af348f9 100644
--- a/chromeos/network/network_connect.cc
+++ b/chromeos/ash/components/network/network_connect.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 
 #include <memory>
 #include <utility>
@@ -12,10 +12,10 @@
 #include "base/strings/stringprintf.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/device_state.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_activation_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "chromeos/network/network_profile.h"
diff --git a/chromeos/network/network_connect.h b/chromeos/ash/components/network/network_connect.h
similarity index 96%
rename from chromeos/network/network_connect.h
rename to chromeos/ash/components/network/network_connect.h
index 211cc6b..b654162 100644
--- a/chromeos/network/network_connect.h
+++ b/chromeos/ash/components/network/network_connect.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONNECT_H_
-#define CHROMEOS_NETWORK_NETWORK_CONNECT_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECT_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECT_H_
 
 #include <string>
 
@@ -122,4 +122,4 @@
 using ::chromeos::NetworkConnect;
 }
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONNECT_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECT_H_
diff --git a/chromeos/network/network_connect_unittest.cc b/chromeos/ash/components/network/network_connect_unittest.cc
similarity index 98%
rename from chromeos/network/network_connect_unittest.cc
rename to chromeos/ash/components/network/network_connect_unittest.cc
index da520578..c92f123e 100644
--- a/chromeos/network/network_connect_unittest.cc
+++ b/chromeos/ash/components/network/network_connect_unittest.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connect.h"
 
 #include <memory>
 
@@ -10,12 +10,12 @@
 #include "base/run_loop.h"
 #include "base/test/task_environment.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_connect.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connect.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/network/network_connection_handler.cc b/chromeos/ash/components/network/network_connection_handler.cc
similarity index 96%
rename from chromeos/network/network_connection_handler.cc
rename to chromeos/ash/components/network/network_connection_handler.cc
index 0e0348e..39147c9b 100644
--- a/chromeos/network/network_connection_handler.cc
+++ b/chromeos/ash/components/network/network_connection_handler.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 
 #include "base/bind.h"
 #include "base/callback_helpers.h"
@@ -16,10 +16,10 @@
 #include "chromeos/ash/components/network/client_cert_resolver.h"
 #include "chromeos/ash/components/network/client_cert_util.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler_impl.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler_impl.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state.h"
diff --git a/chromeos/network/network_connection_handler.h b/chromeos/ash/components/network/network_connection_handler.h
similarity index 96%
rename from chromeos/network/network_connection_handler.h
rename to chromeos/ash/components/network/network_connection_handler.h
index aa3c791..c598f09 100644
--- a/chromeos/network/network_connection_handler.h
+++ b/chromeos/ash/components/network/network_connection_handler.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
-#define CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
 
 #include <map>
 #include <set>
@@ -18,8 +18,8 @@
 // TODO(https://crbug.com/1164001): move to forward declaration
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
 // TODO(https://crbug.com/1164001): move to forward declaration
@@ -263,4 +263,4 @@
 using ::chromeos::NetworkConnectionHandler;
 }
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_H_
diff --git a/chromeos/network/network_connection_handler_impl.cc b/chromeos/ash/components/network/network_connection_handler_impl.cc
similarity index 99%
rename from chromeos/network/network_connection_handler_impl.cc
rename to chromeos/ash/components/network/network_connection_handler_impl.cc
index 733b2ad7..006f75f7 100644
--- a/chromeos/network/network_connection_handler_impl.cc
+++ b/chromeos/ash/components/network/network_connection_handler_impl.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connection_handler_impl.h"
+#include "chromeos/ash/components/network/network_connection_handler_impl.h"
 
 #include <memory>
 #include <ostream>
@@ -24,10 +24,10 @@
 #include "chromeos/ash/components/network/client_cert_util.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/chromeos/network/network_connection_handler_impl.h b/chromeos/ash/components/network/network_connection_handler_impl.h
similarity index 95%
rename from chromeos/network/network_connection_handler_impl.h
rename to chromeos/ash/components/network/network_connection_handler_impl.h
index bda32f3..3ecebc78 100644
--- a/chromeos/network/network_connection_handler_impl.h
+++ b/chromeos/ash/components/network/network_connection_handler_impl.h
@@ -2,15 +2,15 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
-#define CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
 
 #include "base/component_export.h"
 #include "base/scoped_observation.h"
 #include "base/timer/timer.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/dbus/common/dbus_method_call_status.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
 
@@ -197,4 +197,4 @@
 
 }  // namespace chromeos
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_HANDLER_IMPL_H_
diff --git a/chromeos/network/network_connection_handler_impl_unittest.cc b/chromeos/ash/components/network/network_connection_handler_impl_unittest.cc
similarity index 98%
rename from chromeos/network/network_connection_handler_impl_unittest.cc
rename to chromeos/ash/components/network/network_connection_handler_impl_unittest.cc
index f97e4a7..96a3921c 100644
--- a/chromeos/network/network_connection_handler_impl_unittest.cc
+++ b/chromeos/ash/components/network/network_connection_handler_impl_unittest.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connection_handler_impl.h"
+#include "chromeos/ash/components/network/network_connection_handler_impl.h"
 
 #include <map>
 #include <memory>
@@ -18,13 +18,13 @@
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
 #include "chromeos/ash/components/network/cellular_utils.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/ash/components/network/test_cellular_esim_profile_handler.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
-#include "chromeos/network/network_connection_observer.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/network/network_connection_observer.cc b/chromeos/ash/components/network/network_connection_observer.cc
similarity index 91%
rename from chromeos/network/network_connection_observer.cc
rename to chromeos/ash/components/network/network_connection_observer.cc
index 0884986..0246dd5 100644
--- a/chromeos/network/network_connection_observer.cc
+++ b/chromeos/ash/components/network/network_connection_observer.cc
@@ -2,7 +2,7 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#include "chromeos/network/network_connection_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 
 namespace chromeos {
 
diff --git a/chromeos/network/network_connection_observer.h b/chromeos/ash/components/network/network_connection_observer.h
similarity index 88%
rename from chromeos/network/network_connection_observer.h
rename to chromeos/ash/components/network/network_connection_observer.h
index 2dee940a3..d14537d9 100644
--- a/chromeos/network/network_connection_observer.h
+++ b/chromeos/ash/components/network/network_connection_observer.h
@@ -2,8 +2,8 @@
 // Use of this source code is governed by a BSD-style license that can be
 // found in the LICENSE file.
 
-#ifndef CHROMEOS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
-#define CHROMEOS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
+#ifndef CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
+#define CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
 
 #include <string>
 
@@ -50,4 +50,4 @@
 using ::chromeos::NetworkConnectionObserver;
 }
 
-#endif  // CHROMEOS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
+#endif  // CHROMEOS_ASH_COMPONENTS_NETWORK_NETWORK_CONNECTION_OBSERVER_H_
diff --git a/chromeos/ash/components/network/onc/network_onc_utils.cc b/chromeos/ash/components/network/onc/network_onc_utils.cc
index f2aaf59..72a0e7d 100644
--- a/chromeos/ash/components/network/onc/network_onc_utils.cc
+++ b/chromeos/ash/components/network/onc/network_onc_utils.cc
@@ -21,6 +21,7 @@
 #include "base/strings/string_util.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/ash/components/network/onc/onc_normalizer.h"
 #include "chromeos/ash/components/network/onc/onc_translator.h"
@@ -28,7 +29,6 @@
 #include "chromeos/components/onc/onc_signature.h"
 #include "chromeos/components/onc/onc_utils.h"
 #include "chromeos/components/onc/onc_validator.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_profile.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/chromeos/components/sync_wifi/network_test_helper.h b/chromeos/components/sync_wifi/network_test_helper.h
index 307130e..af11612 100644
--- a/chromeos/components/sync_wifi/network_test_helper.h
+++ b/chromeos/components/sync_wifi/network_test_helper.h
@@ -6,10 +6,10 @@
 #define CHROMEOS_COMPONENTS_SYNC_WIFI_NETWORK_TEST_HELPER_H_
 
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/components/sync_wifi/synced_network_metrics_logger.cc b/chromeos/components/sync_wifi/synced_network_metrics_logger.cc
index e8058ae..bf7d03d 100644
--- a/chromeos/components/sync_wifi/synced_network_metrics_logger.cc
+++ b/chromeos/components/sync_wifi/synced_network_metrics_logger.cc
@@ -6,9 +6,9 @@
 
 #include "base/bind.h"
 #include "base/metrics/histogram_functions.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/components/sync_wifi/network_eligibility_checker.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/components/sync_wifi/synced_network_metrics_logger.h b/chromeos/components/sync_wifi/synced_network_metrics_logger.h
index c7afc9e..13b63df6 100644
--- a/chromeos/components/sync_wifi/synced_network_metrics_logger.h
+++ b/chromeos/components/sync_wifi/synced_network_metrics_logger.h
@@ -9,8 +9,8 @@
 #include "base/memory/weak_ptr.h"
 #include "base/time/time.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/components/sync_wifi/network_eligibility_checker.h"
-#include "chromeos/network/network_connection_observer.h"
 #include "chromeos/network/network_state_handler_observer.h"
 #include "third_party/abseil-cpp/absl/types/optional.h"
 
diff --git a/chromeos/components/sync_wifi/synced_network_updater_impl.cc b/chromeos/components/sync_wifi/synced_network_updater_impl.cc
index 9c7fce9..d8ce8e9d 100644
--- a/chromeos/components/sync_wifi/synced_network_updater_impl.cc
+++ b/chromeos/components/sync_wifi/synced_network_updater_impl.cc
@@ -7,9 +7,9 @@
 #include "base/bind.h"
 #include "base/guid.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/components/sync_wifi/network_type_conversions.h"
 #include "chromeos/components/sync_wifi/timer_factory.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_metadata_store.h"
diff --git a/chromeos/components/sync_wifi/wifi_configuration_bridge.cc b/chromeos/components/sync_wifi/wifi_configuration_bridge.cc
index 3fa1a69..44a1840 100644
--- a/chromeos/components/sync_wifi/wifi_configuration_bridge.cc
+++ b/chromeos/components/sync_wifi/wifi_configuration_bridge.cc
@@ -15,13 +15,13 @@
 #include "base/strings/stringprintf.h"
 #include "base/time/clock.h"
 #include "base/time/time.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/components/sync_wifi/local_network_collector.h"
 #include "chromeos/components/sync_wifi/network_identifier.h"
 #include "chromeos/components/sync_wifi/network_type_conversions.h"
 #include "chromeos/components/sync_wifi/synced_network_metrics_logger.h"
 #include "chromeos/components/sync_wifi/synced_network_updater.h"
 #include "chromeos/components/sync_wifi/timer_factory.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "components/device_event_log/device_event_log.h"
diff --git a/chromeos/components/sync_wifi/wifi_configuration_bridge.h b/chromeos/components/sync_wifi/wifi_configuration_bridge.h
index 18b300e..6a946c0 100644
--- a/chromeos/components/sync_wifi/wifi_configuration_bridge.h
+++ b/chromeos/components/sync_wifi/wifi_configuration_bridge.h
@@ -13,8 +13,8 @@
 
 #include "base/memory/weak_ptr.h"
 #include "base/timer/timer.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
 #include "chromeos/components/sync_wifi/network_identifier.h"
-#include "chromeos/network/network_configuration_observer.h"
 #include "chromeos/network/network_metadata_observer.h"
 #include "components/sync/base/model_type.h"
 #include "components/sync/model/model_type_store.h"
diff --git a/chromeos/dbus/BUILD.gn b/chromeos/dbus/BUILD.gn
index 47ade84d..7d37ef6 100644
--- a/chromeos/dbus/BUILD.gn
+++ b/chromeos/dbus/BUILD.gn
@@ -29,8 +29,6 @@
     ":vm_sk_forwarding_proto",
     "//base",
     "//chromeos/dbus/cec_service",
-    "//chromeos/dbus/chunneld",
-    "//chromeos/dbus/chunneld:proto",
     "//chromeos/dbus/cros_disks",
     "//chromeos/dbus/easy_unlock",
     "//chromeos/dbus/fwupd",
@@ -43,8 +41,6 @@
     "//chromeos/dbus/runtime_probe:proto",
     "//chromeos/dbus/smbprovider",
     "//chromeos/dbus/smbprovider:proto",
-    "//chromeos/dbus/update_engine",
-    "//chromeos/dbus/update_engine:proto",
     "//chromeos/dbus/util",
     "//components/account_id",
     "//components/device_event_log",
@@ -101,7 +97,6 @@
     "//chromeos/dbus/tpm_manager:tpm_manager_proto",
     "//chromeos/dbus/u2f",
     "//chromeos/dbus/u2f:u2f_proto",
-    "//chromeos/dbus/update_engine:unit_tests",
     "//chromeos/dbus/util:unit_tests",
     "//dbus",
     "//dbus:test_support",
diff --git a/chromeos/network/BUILD.gn b/chromeos/network/BUILD.gn
index cc699fb3..684458b 100644
--- a/chromeos/network/BUILD.gn
+++ b/chromeos/network/BUILD.gn
@@ -53,27 +53,6 @@
     "//chromeos/ash/components/network/proxy",
   ]
   sources = [
-    "network_activation_handler.h",
-    "network_activation_handler_impl.cc",
-    "network_activation_handler_impl.h",
-    "network_cert_loader.cc",
-    "network_cert_loader.h",
-    "network_cert_migrator.cc",
-    "network_cert_migrator.h",
-    "network_certificate_handler.cc",
-    "network_certificate_handler.h",
-    "network_configuration_handler.cc",
-    "network_configuration_handler.h",
-    "network_configuration_observer.cc",
-    "network_configuration_observer.h",
-    "network_connect.cc",
-    "network_connect.h",
-    "network_connection_handler.cc",
-    "network_connection_handler.h",
-    "network_connection_handler_impl.cc",
-    "network_connection_handler_impl.h",
-    "network_connection_observer.cc",
-    "network_connection_observer.h",
     "network_device_handler.cc",
     "network_device_handler.h",
     "network_device_handler_impl.cc",
@@ -167,11 +146,6 @@
     "//testing/gtest",
   ]
   sources = [
-    "network_cert_loader_unittest.cc",
-    "network_cert_migrator_unittest.cc",
-    "network_configuration_handler_unittest.cc",
-    "network_connect_unittest.cc",
-    "network_connection_handler_impl_unittest.cc",
     "network_device_handler_unittest.cc",
     "network_event_log_unittest.cc",
     "network_metadata_store_unittest.cc",
diff --git a/chromeos/network/network_handler.cc b/chromeos/network/network_handler.cc
index 0ad2750..1a91460 100644
--- a/chromeos/network/network_handler.cc
+++ b/chromeos/network/network_handler.cc
@@ -21,13 +21,13 @@
 #include "chromeos/ash/components/network/metrics/connection_info_metrics_logger.h"
 #include "chromeos/ash/components/network/metrics/esim_policy_login_metrics_logger.h"
 #include "chromeos/ash/components/network/metrics/vpn_network_metrics_helper.h"
+#include "chromeos/ash/components/network/network_activation_handler_impl.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_cert_migrator.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler_impl.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
-#include "chromeos/network/network_activation_handler_impl.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_cert_migrator.h"
-#include "chromeos/network/network_certificate_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler_impl.h"
 #include "chromeos/network/network_device_handler_impl.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/chromeos/network/network_metadata_store.cc b/chromeos/network/network_metadata_store.cc
index faaefcc..44df9ff 100644
--- a/chromeos/network/network_metadata_store.cc
+++ b/chromeos/network/network_metadata_store.cc
@@ -10,8 +10,8 @@
 #include "base/metrics/histogram_functions.h"
 #include "base/strings/stringprintf.h"
 #include "base/time/time.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
diff --git a/chromeos/network/network_metadata_store.h b/chromeos/network/network_metadata_store.h
index 1c361d0..54bd894 100644
--- a/chromeos/network/network_metadata_store.h
+++ b/chromeos/network/network_metadata_store.h
@@ -11,9 +11,9 @@
 #include "base/observer_list.h"
 #include "base/scoped_observation.h"
 #include "base/values.h"
+#include "chromeos/ash/components/network/network_configuration_observer.h"
+#include "chromeos/ash/components/network/network_connection_observer.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_observer.h"
-#include "chromeos/network/network_connection_observer.h"
 #include "chromeos/network/network_metadata_observer.h"
 #include "chromeos/network/network_state_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
diff --git a/chromeos/network/network_metadata_store_unittest.cc b/chromeos/network/network_metadata_store_unittest.cc
index 5f5b301..0e679a5 100644
--- a/chromeos/network/network_metadata_store_unittest.cc
+++ b/chromeos/network/network_metadata_store_unittest.cc
@@ -7,12 +7,12 @@
 #include "base/callback_helpers.h"
 #include "base/test/metrics/histogram_tester.h"
 #include "base/test/task_environment.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler_impl.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/dbus/shill/shill_clients.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
-#include "chromeos/network/network_connection_handler_impl.h"
 #include "chromeos/network/network_metadata_observer.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/chromeos/network/network_state_handler.cc b/chromeos/network/network_state_handler.cc
index 3d3d624..11a12d28 100644
--- a/chromeos/network/network_state_handler.cc
+++ b/chromeos/network/network_state_handler.cc
@@ -24,7 +24,7 @@
 #include "base/strings/stringprintf.h"
 #include "base/values.h"
 #include "chromeos/ash/components/network/device_state.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler_callbacks.h"
 #include "chromeos/network/network_state_handler_observer.h"
diff --git a/chromeos/network/prohibited_technologies_handler_unittest.cc b/chromeos/network/prohibited_technologies_handler_unittest.cc
index d65f8ff..1915f71 100644
--- a/chromeos/network/prohibited_technologies_handler_unittest.cc
+++ b/chromeos/network/prohibited_technologies_handler_unittest.cc
@@ -15,9 +15,9 @@
 #include "base/run_loop.h"
 #include "base/test/task_environment.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler_impl.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_state_test_helper.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #include "testing/gtest/include/gtest/gtest.h"
diff --git a/chromeos/services/network_config/cros_network_config.cc b/chromeos/services/network_config/cros_network_config.cc
index fb7f26ca..796585d 100644
--- a/chromeos/services/network_config/cros_network_config.cc
+++ b/chromeos/services/network_config/cros_network_config.cc
@@ -20,6 +20,7 @@
 #include "chromeos/ash/components/network/cellular_utils.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/onc/onc_translation_tables.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
 #include "chromeos/components/sync_wifi/network_eligibility_checker.h"
@@ -27,7 +28,6 @@
 #include "chromeos/dbus/hermes/hermes_manager_client.h"
 #include "chromeos/dbus/shill/shill_manager_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_handler.h"
diff --git a/chromeos/services/network_config/cros_network_config.h b/chromeos/services/network_config/cros_network_config.h
index 77435ca..6687ba4 100644
--- a/chromeos/services/network_config/cros_network_config.h
+++ b/chromeos/services/network_config/cros_network_config.h
@@ -8,7 +8,7 @@
 #include "base/containers/flat_map.h"
 #include "base/memory/weak_ptr.h"
 #include "chromeos/ash/components/network/cellular_inhibitor.h"
-#include "chromeos/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
 #include "chromeos/network/network_policy_observer.h"
 #include "chromeos/network/network_profile_handler.h"
 #include "chromeos/network/network_state_handler_observer.h"
diff --git a/chromeos/services/network_config/cros_network_config_unittest.cc b/chromeos/services/network_config/cros_network_config_unittest.cc
index 907463dd..b33296d2 100644
--- a/chromeos/services/network_config/cros_network_config_unittest.cc
+++ b/chromeos/services/network_config/cros_network_config_unittest.cc
@@ -19,15 +19,15 @@
 #include "chromeos/ash/components/network/cellular_metrics_logger.h"
 #include "chromeos/ash/components/network/fake_stub_cellular_networks_provider.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_cert_loader.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/ash/components/network/proxy/ui_proxy_config_service.h"
 #include "chromeos/components/onc/onc_utils.h"
 #include "chromeos/dbus/shill/fake_shill_device_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_cert_loader.h"
-#include "chromeos/network/network_certificate_handler.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_metadata_store.h"
 #include "chromeos/network/network_profile_handler.h"
diff --git a/chromeos/strings/chromeos_strings_km.xtb b/chromeos/strings/chromeos_strings_km.xtb
index c7ec51f..d97a457 100644
--- a/chromeos/strings/chromeos_strings_km.xtb
+++ b/chromeos/strings/chromeos_strings_km.xtb
@@ -123,6 +123,7 @@
 <translation id="188114911237521550">បិទ​មុខងារ​ងងឹត</translation>
 <translation id="1881188606372070653">ចូលទៅកាន់​<ph name="BEGIN_LINK1" />ទំព័រ​ជំនួយ​ផ្នែក​ច្បាប់<ph name="END_LINK1" /> ដើម្បីស្នើ​សុំ​ធ្វើការផ្លាស់ប្ដូរ​ខ្លឹមសារ​ដោយសារ​ហេតុផល​ផ្លូវច្បាប់។ ព័ត៌មាន​មួយចំនួន​អំពី​គណនី និងប្រព័ន្ធ​អាច​ត្រូវបាន​ផ្ញើទៅ Google។ យើង​នឹង​ប្រើ​ប្រាស់​ព័ត៌មាន​ដែល​អ្នក​ផ្ដល់​​ឱ្យយើង​ ដើម្បី​ជួយ​ដោះ​ស្រាយ​បញ្ហា​បច្ចេកទេស និង​ដើម្បី​កែ​លម្អ​សេវាកម្ម​របស់​យើង ដោយអនុលោមតាម​<ph name="BEGIN_LINK2" />គោលការណ៍​ឯកជនភាព<ph name="END_LINK2" /> និង​<ph name="BEGIN_LINK3" />លក្ខខណ្ឌ​ប្រើប្រាស់<ph name="END_LINK3" />​របស់យើង។</translation>
 <translation id="1887850431809612466">ការផ្លាស់ប្តូរផ្នែករឹង</translation>
+<translation id="1904932688895783618">ទាំង​នេះ​គឺជា​ធនធាន​ដែល​មាន​ប្រយោជន៍​ផ្សេងៗ​មួយចំនួន​ទៀត៖</translation>
 <translation id="1905710495812624430">បាន​លើស​ការ​ព្យាយាម​ចូូល​អតិបរមា​ដែល​បាន​អនុញ្ញាត​ហើយ​។​</translation>
 <translation id="1908234395526491708">សំណើ UDP មិនបានសម្រេច</translation>
 <translation id="1932611479324127242">ផ្ដាច់ថ្ម</translation>
@@ -137,6 +138,7 @@
 <translation id="2016697457005847575">សាកល្បងអនុវត្តតាមជំហានដោះស្រាយបញ្ហា</translation>
 <translation id="2016848882344942759">--មិនមានស្លាកពណ៌ស--</translation>
 <translation id="202500043506723828">EID</translation>
+<translation id="2047316797244836561">សូម​ភ្ជាប់​ទៅ​បណ្ដាញ​ រួច​ផ្ទុក​ទំព័រ​ឡើងវិញ ដើម្បី​មើល​ធាតុ​រក្សាអេក្រង់។</translation>
 <translation id="2080070583977670716">ការកំណត់ច្រើនទៀត</translation>
 <translation id="2085089206770112532">គ្រាប់ចុចព្រួញចុះក្រោមសម្រាប់បន្ថយពន្លឺផ្ទាំងអេក្រង់</translation>
 <translation id="2105810540595158374">ឧបករណ៍គឺជាឧបករណ៍បញ្ជាហ្គេម។</translation>
@@ -772,6 +774,7 @@
 <translation id="7763470514545477072">ភាពត្រូវគ្នានៃ​កន្ទុយដែន</translation>
 <translation id="7769672763586021400">លេខសម្គាល់ម៉ូដែល</translation>
 <translation id="7784116172884276937">មិនបានរៀបចំម៉ាស៊ីនមេ DNS ទេ</translation>
+<translation id="779591286616261875">ផ្ញើ​របាយការណ៍​ថ្មី</translation>
 <translation id="7799817062559422778">មុខងារភ្លឺ</translation>
 <translation id="780301667611848630">ទេ អរគុណ</translation>
 <translation id="7805768142964895445">ស្ថានភាព</translation>
@@ -924,6 +927,7 @@
 <translation id="9082718469794970195">ប្រើវីដេអូនេះ</translation>
 <translation id="9087578468327036362">រាយការណ៍​អំពី​សំណួរ​នេះ</translation>
 <translation id="9088306295921699330">ការប្រើប្រាស់​បច្ចុប្បន្ន</translation>
+<translation id="9092255287806472980">មតិ​កែលម្អ​របស់អ្នក​ជួយ​ធ្វើឱ្យ Chrome OS ប្រសើរឡើង ហើ​យ​នឹង​ត្រូវ​បាន​ពិនិត្យ​មើល​ដោយ​ក្រុម​ការងារ​របស់យើង។ ដោយសារតែ​មាន​ចំនួន​នៃ​របាយការណ៍​ច្រើន យើង​នឹង​មិន​អាច​ផ្ញើ​ការឆ្លើយតប​បានទេ។</translation>
 <translation id="9095775724867566971">Pluginvm</translation>
 <translation id="90977145661420967">អ្នកនឹងត្រូវដោះបំបែក​ឧបករណ៍</translation>
 <translation id="9098156406873149060">រក្សាទិន្នន័យរបស់អ្នកប្រើប្រាស់</translation>
diff --git a/chromeos/strings/chromeos_strings_uz.xtb b/chromeos/strings/chromeos_strings_uz.xtb
index e096e3d..199402d 100644
--- a/chromeos/strings/chromeos_strings_uz.xtb
+++ b/chromeos/strings/chromeos_strings_uz.xtb
@@ -123,6 +123,7 @@
 <translation id="188114911237521550">Tungi rejimdan chiqish</translation>
 <translation id="1881188606372070653">Agar bu kontent biror qonunni buzsa, shikoyat yuborish uchun <ph name="BEGIN_LINK1" />Huquqiy yordam sahifasiga<ph name="END_LINK1" /> kiring. Hisob va tizimga oid ayrim axborotlar Google kompaniyasiga yuborilishi mumkin. Bizga taqdim etilgan maʼlumotlardan texnik muammolarni hal qilish va xizmatlarimizni yaxshilashda foydalanamiz. Bunda <ph name="BEGIN_LINK2" />Maxfiylik siyosati<ph name="END_LINK2" /> va <ph name="BEGIN_LINK3" />Xizmat shartlariga<ph name="END_LINK3" /> rioya qilinadi.</translation>
 <translation id="1887850431809612466">Qurilma versiyasi</translation>
+<translation id="1904932688895783618">Quyidagi manbalar foydali boʻlishi mumkin:</translation>
 <translation id="1905710495812624430">Urinishlar soni cheklovdan oshib ketdi.</translation>
 <translation id="1908234395526491708">Bajarilmagan UDP soʻrovlari</translation>
 <translation id="1932611479324127242">Batareyani uzish</translation>
@@ -137,6 +138,7 @@
 <translation id="2016697457005847575">Muammoni hal qilishga urining</translation>
 <translation id="2016848882344942759">--oq yorliqsiz--</translation>
 <translation id="202500043506723828">EID</translation>
+<translation id="2047316797244836561">Ekran lavhasini koʻrish uchun tarmoqqa ulaning va sahifani yangilang.</translation>
 <translation id="2080070583977670716">Kengaytirilgan sozlamalar</translation>
 <translation id="2085089206770112532">Displey yorlinligini pasaytirish</translation>
 <translation id="2105810540595158374">Qurilma — geympad</translation>
@@ -773,6 +775,7 @@
 <translation id="7763470514545477072">Domen kengaytmasi topildi</translation>
 <translation id="7769672763586021400">Model identifikatori</translation>
 <translation id="7784116172884276937">DNS serverlar sozlanmagan</translation>
+<translation id="779591286616261875">Yangi hisobot yuborish</translation>
 <translation id="7799817062559422778">Kunduzgi rejim</translation>
 <translation id="780301667611848630">Kerak emas</translation>
 <translation id="7805768142964895445">Holat</translation>
@@ -925,6 +928,7 @@
 <translation id="9082718469794970195">Bu videodan foydalanish</translation>
 <translation id="9087578468327036362">Bu soʻrov haqida xabar berish</translation>
 <translation id="9088306295921699330">Joriy faollik</translation>
+<translation id="9092255287806472980">Fikr-mulohazangiz Chrome OS tizimini yaxshilashimizga yordam beradi va jamoamiz tomonidan koʻrib chiqiladi. Murojaatlar soni juda koʻpligi uchun har biriga javob qaytara olmaymiz.</translation>
 <translation id="9095775724867566971">Pluginvm</translation>
 <translation id="90977145661420967">Qurilma ichini ochish talab etiladi</translation>
 <translation id="9098156406873149060">Foydalanuvchi maʼlumotlari qolsin</translation>
diff --git a/chromeos/strings/chromeos_strings_zh-HK.xtb b/chromeos/strings/chromeos_strings_zh-HK.xtb
index 2600d669..7724fb0 100644
--- a/chromeos/strings/chromeos_strings_zh-HK.xtb
+++ b/chromeos/strings/chromeos_strings_zh-HK.xtb
@@ -647,7 +647,7 @@
 <translation id="6516990319416533844">如要測試充電速率,請讓電池耗電一小段時間</translation>
 <translation id="6517239166834772319">探索</translation>
 <translation id="6527081081771465939">未知的 Wi-Fi 安全通訊協定</translation>
-<translation id="6535178685492749208">你已經離線,系統稍後才會傳送意見回饋。</translation>
+<translation id="6535178685492749208">您已離線。意見將會在稍後傳送。</translation>
 <translation id="65587193855025101">平台式</translation>
 <translation id="6564646048574748301">失敗 - 無法連接打印機</translation>
 <translation id="6566314079205407217">多頁掃瞄</translation>
diff --git a/chromeos/tast_control.gni b/chromeos/tast_control.gni
index 3a8dc386..5974dae 100644
--- a/chromeos/tast_control.gni
+++ b/chromeos/tast_control.gni
@@ -259,11 +259,6 @@
   # b/235279574
   "wmp.DragAndDropWindow",
 
-  # http://crbug.com/1336853
-  "arc.StandardizedKeyboardTyping",
-  "arc.StandardizedKeyboardTyping.tablet_mode",
-  "arc.StandardizedKeyboardKeys.tablet_mode",
-
   # http://b/236312054
   "crostini.AppGeditFilesharing",
   "crostini.AppGeditFilesharing.stable",
@@ -282,9 +277,6 @@
   "crostini.RestartApp",
   "crostini.RestartApp.stable",
 
-  # http://crbug.com/1338038
-  "arc.IMEBlockingVK",
-
   # http://crbug.com/1335213
   "arc.WindowState.clamshell",
 
@@ -300,6 +292,12 @@
   # https://crbug.com/1341288
   "launcher.Smoke",
   "launcher.BubbleSmoke",
+
+  # https://crbug.com/1341074
+  "launcher.BubbleLaunchApp.enable_launcher_app_sort",
+
+  # https://crbug.com/1341076
+  "launcher.BubbleLaunchApp.disable_launcher_app_sort",
 ]
 
 # To create filters to be used on specific builders add them like this:
diff --git a/components/autofill/ios/browser/autofill_util.h b/components/autofill/ios/browser/autofill_util.h
index d4aa8f7..c65ac04 100644
--- a/components/autofill/ios/browser/autofill_util.h
+++ b/components/autofill/ios/browser/autofill_util.h
@@ -7,13 +7,12 @@
 
 #include <vector>
 
+#include "base/values.h"
+
 #import "ios/web/public/js_messaging/web_frame.h"
 
 class GURL;
 
-namespace base {
-class DictionaryValue;
-}
 namespace web {
 class WebState;
 }
@@ -59,7 +58,7 @@
 // Extracts a single form field from the JSON dictionary into a FormFieldData
 // object.
 // Returns false if the field could not be extracted.
-bool ExtractFormFieldData(const base::DictionaryValue& field,
+bool ExtractFormFieldData(const base::Value::Dict& field,
                           FormFieldData* field_data);
 
 typedef base::OnceCallback<void(const base::Value*)> JavaScriptResultCallback;
diff --git a/components/autofill/ios/browser/autofill_util.mm b/components/autofill/ios/browser/autofill_util.mm
index 9cde0ac..a4d0e58 100644
--- a/components/autofill/ios/browser/autofill_util.mm
+++ b/components/autofill/ios/browser/autofill_util.mm
@@ -118,20 +118,24 @@
                      autofill::FormData* form_data) {
   DCHECK(form_data);
   // Each form should be a JSON dictionary.
-  const base::DictionaryValue* form_dictionary = nullptr;
-  if (!form_value.GetAsDictionary(&form_dictionary))
+  if (!form_value.is_dict())
     return false;
 
+  const base::Value::Dict& form_dictionary = form_value.GetDict();
+
   // Form data is copied into a FormData object field-by-field.
-  if (!form_dictionary->GetString("name", &form_data->name))
+  const std::string* name = form_dictionary.FindString("name");
+  if (!name)
     return false;
+  form_data->name = base::UTF8ToUTF16(*name);
   if (filtered && form_name != form_data->name)
     return false;
 
   // Origin is mandatory.
-  std::u16string origin;
-  if (!form_dictionary->GetString("origin", &origin))
+  const std::string* origin_ptr = form_dictionary.FindString("origin");
+  if (!origin_ptr)
     return false;
+  std::u16string origin = base::UTF8ToUTF16(*origin_ptr);
 
   // Use GURL object to verify origin of host frame URL.
   form_data->url = GURL(origin);
@@ -141,35 +145,44 @@
   // main_frame_origin is used for logging UKM.
   form_data->main_frame_origin = url::Origin::Create(main_frame_url);
 
-  std::string unique_renderer_id;
-  form_dictionary->GetString("unique_renderer_id", &unique_renderer_id);
-  if (!unique_renderer_id.empty()) {
-    StringToUint(unique_renderer_id, &form_data->unique_renderer_id.value());
+  const std::string* unique_renderer_id =
+      form_dictionary.FindString("unique_renderer_id");
+  if (unique_renderer_id && !unique_renderer_id->empty()) {
+    StringToUint(*unique_renderer_id, &form_data->unique_renderer_id.value());
   } else {
     form_data->unique_renderer_id = FormRendererId();
   }
 
   // Action is optional.
   std::u16string action;
-  form_dictionary->GetString("action", &action);
+  if (const std::string* action_ptr = form_dictionary.FindString("action")) {
+    action = base::UTF8ToUTF16(*action_ptr);
+  }
   form_data->action = GURL(action);
 
   // Optional fields.
-  form_dictionary->GetString("name_attribute", &form_data->name_attribute);
-  form_dictionary->GetString("id_attribute", &form_data->id_attribute);
-  form_data->is_form_tag = form_dictionary->FindBoolKey("is_form_tag")
-                               .value_or(form_data->is_form_tag);
-  form_dictionary->GetString("frame_id", &form_data->frame_id);
+  if (const std::string* name_attribute =
+          form_dictionary.FindString("name_attribute")) {
+    form_data->name_attribute = base::UTF8ToUTF16(*name_attribute);
+  }
+  if (const std::string* id_attribute =
+          form_dictionary.FindString("id_attribute")) {
+    form_data->id_attribute = base::UTF8ToUTF16(*id_attribute);
+  }
+  form_data->is_form_tag =
+      form_dictionary.FindBool("is_form_tag").value_or(form_data->is_form_tag);
+  if (const std::string* frame_id = form_dictionary.FindString("frame_id")) {
+    form_data->frame_id = *frame_id;
+  }
 
   // Field list (mandatory) is extracted.
-  const base::ListValue* fields_list = nullptr;
-  if (!form_dictionary->GetList("fields", &fields_list))
+  const base::Value::List* fields_list = form_dictionary.FindList("fields");
+  if (!fields_list)
     return false;
-  for (const auto& field_dict : fields_list->GetListDeprecated()) {
-    const base::DictionaryValue* field;
+  for (const auto& field_dict : *fields_list) {
     autofill::FormFieldData field_data;
-    if (field_dict.GetAsDictionary(&field) &&
-        ExtractFormFieldData(*field, &field_data)) {
+    if (field_dict.is_dict() &&
+        ExtractFormFieldData(field_dict.GetDict(), &field_data)) {
       form_data->fields.push_back(std::move(field_data));
     } else {
       return false;
@@ -178,68 +191,81 @@
   return true;
 }
 
-bool ExtractFormFieldData(const base::DictionaryValue& field,
+bool ExtractFormFieldData(const base::Value::Dict& field,
                           autofill::FormFieldData* field_data) {
-  if (!field.GetString("name", &field_data->name) ||
-      !field.GetString("identifier", &field_data->unique_id) ||
-      !field.GetString("form_control_type", &field_data->form_control_type)) {
+  const std::string *name, *identifier, *form_control_type;
+  if (!(name = field.FindString("name")) ||
+      !(identifier = field.FindString("identifier")) ||
+      !(form_control_type = field.FindString("form_control_type"))) {
     return false;
   }
 
-  std::string unique_renderer_id;
-  field.GetString("unique_renderer_id", &unique_renderer_id);
-  if (!unique_renderer_id.empty()) {
-    StringToUint(unique_renderer_id, &field_data->unique_renderer_id.value());
+  field_data->name = base::UTF8ToUTF16(*name);
+  field_data->unique_id = base::UTF8ToUTF16(*identifier);
+  field_data->form_control_type = *form_control_type;
+
+  const std::string* unique_renderer_id =
+      field.FindString("unique_renderer_id");
+  if (unique_renderer_id && !unique_renderer_id->empty()) {
+    StringToUint(*unique_renderer_id, &field_data->unique_renderer_id.value());
   } else {
     field_data->unique_renderer_id = FieldRendererId();
   }
 
   // Optional fields.
-  field.GetString("name_attribute", &field_data->name_attribute);
-  field.GetString("id_attribute", &field_data->id_attribute);
-  field.GetString("label", &field_data->label);
-  field.GetString("value", &field_data->value);
-  field.GetString("autocomplete_attribute",
-                  &field_data->autocomplete_attribute);
+  if (const std::string* name_attribute = field.FindString("name_attribute")) {
+    field_data->name_attribute = base::UTF8ToUTF16(*name_attribute);
+  }
+  if (const std::string* id_attribute = field.FindString("id_attribute")) {
+    field_data->id_attribute = base::UTF8ToUTF16(*id_attribute);
+  }
+  if (const std::string* label = field.FindString("label")) {
+    field_data->label = base::UTF8ToUTF16(*label);
+  }
+  if (const std::string* value = field.FindString("value")) {
+    field_data->value = base::UTF8ToUTF16(*value);
+  }
+  if (const std::string* autocomplete_attribute =
+          field.FindString("autocomplete_attribute")) {
+    field_data->autocomplete_attribute = *autocomplete_attribute;
+  }
   field_data->is_autofilled =
-      field.FindBoolKey("is_autofilled").value_or(field_data->is_autofilled);
+      field.FindBool("is_autofilled").value_or(field_data->is_autofilled);
 
-  int max_length = 0;
-  if (field.GetInteger("max_length", &max_length))
-    field_data->max_length = max_length;
+  if (absl::optional<int> max_length = field.FindInt("max_length")) {
+    field_data->max_length = *max_length;
+  }
 
   // TODO(crbug.com/427614): Extract |is_checked|.
-  bool is_checkable = field.FindBoolKey("is_checkable").value_or(false);
+  bool is_checkable = field.FindBool("is_checkable").value_or(false);
   autofill::SetCheckStatus(field_data, is_checkable, false);
 
   field_data->is_focusable =
-      field.FindBoolKey("is_focusable").value_or(field_data->is_focusable);
+      field.FindBool("is_focusable").value_or(field_data->is_focusable);
   field_data->should_autocomplete =
-      field.FindBoolKey("should_autocomplete")
+      field.FindBool("should_autocomplete")
           .value_or(field_data->should_autocomplete);
 
   // RoleAttribute::kOther is the default value. The only other value as of this
   // writing is RoleAttribute::kPresentation.
-  int role = 0;
-  if (field.GetInteger("role", &role) &&
-      role == static_cast<int>(FormFieldData::RoleAttribute::kPresentation)) {
+  absl::optional<int> role = field.FindInt("role");
+  if (role &&
+      *role == static_cast<int>(FormFieldData::RoleAttribute::kPresentation)) {
     field_data->role = FormFieldData::RoleAttribute::kPresentation;
   }
 
   // TODO(crbug.com/427614): Extract |text_direction|.
 
   // Load option values where present.
-  const base::ListValue* option_values;
-  const base::ListValue* option_contents;
-  if (field.GetList("option_values", &option_values) &&
-      field.GetList("option_contents", &option_contents)) {
-    auto value_list = option_values->GetListDeprecated();
-    auto content_list = option_contents->GetListDeprecated();
-    if (value_list.size() != content_list.size())
+  const base::Value::List* option_values = field.FindList("option_values");
+  const base::Value::List* option_contents = field.FindList("option_contents");
+  if (option_values && option_contents) {
+    if (option_values->size() != option_contents->size())
       return false;
-    auto value_it = value_list.begin();
-    auto content_it = content_list.begin();
-    while (value_it != value_list.end() && content_it != content_list.end()) {
+    auto value_it = option_values->begin();
+    auto content_it = option_contents->begin();
+    while (value_it != option_values->end() &&
+           content_it != option_contents->end()) {
       if (value_it->is_string() && content_it->is_string()) {
         field_data->options.push_back(
             {.value = base::UTF8ToUTF16(value_it->GetString()),
diff --git a/components/captive_portal/core/DEPS b/components/captive_portal/core/DEPS
index 7b5f1e0..d6896f0 100644
--- a/components/captive_portal/core/DEPS
+++ b/components/captive_portal/core/DEPS
@@ -1,4 +1,5 @@
 include_rules = [
+  "+chromeos/ash/components/network",
   "+chromeos/network",
   "+services/network/public/cpp",
   "+services/network/public/mojom",
diff --git a/components/captive_portal/core/captive_portal_detector.cc b/components/captive_portal/core/captive_portal_detector.cc
index fde9c78..40d1201 100644
--- a/components/captive_portal/core/captive_portal_detector.cc
+++ b/components/captive_portal/core/captive_portal_detector.cc
@@ -19,7 +19,7 @@
 #include "url/gurl.h"
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
-#include "chromeos/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state_handler.h"
 #endif
diff --git a/components/services/app_service/public/cpp/BUILD.gn b/components/services/app_service/public/cpp/BUILD.gn
index b510282..745556c 100644
--- a/components/services/app_service/public/cpp/BUILD.gn
+++ b/components/services/app_service/public/cpp/BUILD.gn
@@ -319,7 +319,6 @@
   sources = [
     "app_capability_access_cache_unittest.cc",
     "app_capability_access_cache_wrapper_unittest.cc",
-    "app_registry_cache_mojom_unittest.cc",
     "app_registry_cache_unittest.cc",
     "app_registry_cache_wrapper_unittest.cc",
     "app_update_mojom_unittest.cc",
diff --git a/components/services/app_service/public/cpp/app_registry_cache.cc b/components/services/app_service/public/cpp/app_registry_cache.cc
index 24f1537..58e42f5c 100644
--- a/components/services/app_service/public/cpp/app_registry_cache.cc
+++ b/components/services/app_service/public/cpp/app_registry_cache.cc
@@ -109,10 +109,7 @@
     DoOnApps(std::move(pending));
   }
 
-  if (base::FeatureList::IsEnabled(
-          kAppServiceOnAppTypeInitializedWithoutMojom)) {
-    OnAppTypeInitialized();
-  }
+  OnAppTypeInitialized();
 }
 
 void AppRegistryCache::DoOnApps(std::vector<apps::mojom::AppPtr> deltas) {
@@ -333,30 +330,7 @@
   return base::Contains(initialized_app_types_, app_type);
 }
 
-void AppRegistryCache::OnMojomAppTypeInitialized() {
-  if (in_progress_initialized_mojom_app_types_.empty()) {
-    return;
-  }
-
-  auto in_progress_initialized_app_types =
-      in_progress_initialized_mojom_app_types_;
-  in_progress_initialized_mojom_app_types_.clear();
-
-  for (auto app_type : in_progress_initialized_app_types) {
-    for (auto& obs : observers_) {
-      obs.OnAppTypeInitialized(ConvertMojomAppTypToAppType(app_type));
-    }
-    initialized_app_types_.insert(ConvertMojomAppTypToAppType(app_type));
-  }
-}
-
 void AppRegistryCache::OnAppTypeInitialized() {
-  if (!base::FeatureList::IsEnabled(
-          kAppServiceOnAppTypeInitializedWithoutMojom)) {
-    OnMojomAppTypeInitialized();
-    return;
-  }
-
   // Check both the non mojom and mojom initialized status. Only when they are
   // not initialized, call OnAppTypeInitialized to notify observers, because
   // observers might use the non mojom or mojom App struct.
diff --git a/components/services/app_service/public/cpp/app_registry_cache.h b/components/services/app_service/public/cpp/app_registry_cache.h
index 3010da4..f0e84427 100644
--- a/components/services/app_service/public/cpp/app_registry_cache.h
+++ b/components/services/app_service/public/cpp/app_registry_cache.h
@@ -258,8 +258,6 @@
   void DoOnApps(std::vector<apps::mojom::AppPtr> deltas);
   void DoOnApps(std::vector<AppPtr> deltas);
 
-  void OnMojomAppTypeInitialized();
-
   void OnAppTypeInitialized();
 
   base::ObserverList<Observer> observers_;
diff --git a/components/services/app_service/public/cpp/app_registry_cache_mojom_unittest.cc b/components/services/app_service/public/cpp/app_registry_cache_mojom_unittest.cc
deleted file mode 100644
index efbbdcd2..0000000
--- a/components/services/app_service/public/cpp/app_registry_cache_mojom_unittest.cc
+++ /dev/null
@@ -1,567 +0,0 @@
-// Copyright 2018 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include <map>
-
-#include "base/memory/raw_ptr.h"
-#include "base/test/scoped_feature_list.h"
-#include "components/services/app_service/public/cpp/app_registry_cache.h"
-#include "components/services/app_service/public/cpp/app_types.h"
-#include "components/services/app_service/public/cpp/features.h"
-#include "testing/gmock/include/gmock/gmock.h"
-#include "testing/gtest/include/gtest/gtest.h"
-
-namespace {
-
-class MockRegistryObserver : public apps::AppRegistryCache::Observer {
- public:
-  MOCK_METHOD(void, OnAppUpdate, (const apps::AppUpdate& update), ());
-
-  MOCK_METHOD(void,
-              OnAppRegistryCacheWillBeDestroyed,
-              (apps::AppRegistryCache * cache),
-              ());
-};
-
-MATCHER_P(HasAppId, app_id, "Has the correct app id") {
-  return arg.AppId() == app_id;
-}
-
-}  // namespace
-
-class AppRegistryCacheMojomTest : public testing::Test,
-                                  public apps::AppRegistryCache::Observer {
- protected:
-  AppRegistryCacheMojomTest() {
-    scoped_feature_list_.InitWithFeatures(
-        /*enabled_features=*/{},
-        /*disabled_features=*/{
-            apps::kAppServiceOnAppTypeInitializedWithoutMojom,
-            apps::kAppServiceOnAppUpdateWithoutMojom});
-  }
-
-  static apps::mojom::AppPtr MakeApp(
-      const char* app_id,
-      const char* name,
-      apps::mojom::Readiness readiness = apps::mojom::Readiness::kUnknown) {
-    apps::mojom::AppPtr app = apps::mojom::App::New();
-    app->app_type = apps::mojom::AppType::kArc;
-    app->app_id = app_id;
-    app->readiness = readiness;
-    app->name = name;
-    return app;
-  }
-
-  void CallForEachApp(apps::AppRegistryCache& cache) {
-    cache.ForEachApp(
-        [this](const apps::AppUpdate& update) { OnAppUpdate(update); });
-  }
-
-  std::string GetName(apps::AppRegistryCache& cache,
-                      const std::string& app_id) {
-    std::string name;
-    cache.ForOneApp(app_id, [&name](const apps::AppUpdate& update) {
-      name = update.Name();
-    });
-    return name;
-  }
-
-  // apps::AppRegistryCache::Observer overrides.
-  void OnAppUpdate(const apps::AppUpdate& update) override {
-    EXPECT_EQ(account_id_, update.AccountId());
-    EXPECT_NE("", update.Name());
-    if (update.ReadinessChanged() &&
-        (update.Readiness() == apps::Readiness::kReady)) {
-      num_freshly_installed_++;
-    }
-    updated_ids_.insert(update.AppId());
-    updated_names_.insert(update.Name());
-  }
-
-  void OnAppTypeInitialized(apps::AppType app_type) override {
-    app_type_ = app_type;
-  }
-
-  void OnAppRegistryCacheWillBeDestroyed(
-      apps::AppRegistryCache* cache) override {
-    // The test code explicitly calls both AddObserver and RemoveObserver.
-    NOTREACHED();
-  }
-
-  void SetAppType(apps::AppType app_type) { app_type_ = app_type; }
-
-  const AccountId& account_id() const { return account_id_; }
-
-  apps::AppType app_type() const { return app_type_; }
-
-  int num_freshly_installed_ = 0;
-  std::set<std::string> updated_ids_;
-  std::set<std::string> updated_names_;
-  AccountId account_id_ = AccountId::FromUserEmail("test@gmail.com");
-  apps::AppType app_type_ = apps::AppType::kUnknown;
-  base::test::ScopedFeatureList scoped_feature_list_;
-};
-
-// Responds to a cache's OnAppUpdate to call back into the cache, checking that
-// the cache presents a self-consistent snapshot. For example, the app names
-// should match for the outer and inner AppUpdate.
-//
-// In the tests below, just "recursive" means that cache.OnApps calls
-// observer.OnAppsUpdate which calls cache.ForEachApp and cache.ForOneApp.
-// "Super-recursive" means that cache.OnApps calls observer.OnAppsUpdate calls
-// cache.OnApps which calls observer.OnAppsUpdate.
-class RecursiveObserver : public apps::AppRegistryCache::Observer {
- public:
-  explicit RecursiveObserver(apps::AppRegistryCache* cache) : cache_(cache) {
-    Observe(cache);
-  }
-
-  ~RecursiveObserver() override = default;
-
-  void PrepareForOnApps(
-      int expected_num_apps,
-      const std::string& expected_name_for_p,
-      std::vector<apps::mojom::AppPtr>* super_recursive_apps = nullptr) {
-    expected_name_for_p_ = expected_name_for_p;
-    expected_num_apps_ = expected_num_apps;
-    num_apps_seen_on_app_update_ = 0;
-    old_names_.clear();
-
-    names_snapshot_.clear();
-    check_names_snapshot_ = true;
-    if (super_recursive_apps) {
-      check_names_snapshot_ = false;
-      super_recursive_apps_.swap(*super_recursive_apps);
-    }
-  }
-
-  int NumAppsSeenOnAppUpdate() { return num_apps_seen_on_app_update_; }
-
-  apps::AppType app_type() const { return app_type_; }
-
- protected:
-  // apps::AppRegistryCache::Observer overrides.
-  void OnAppUpdate(const apps::AppUpdate& outer) override {
-    EXPECT_EQ(account_id_, outer.AccountId());
-    int num_apps = 0;
-    cache_->ForEachApp([this, &outer, &num_apps](const apps::AppUpdate& inner) {
-      if (check_names_snapshot_) {
-        if (num_apps_seen_on_app_update_ == 0) {
-          // If this is the first time that OnAppUpdate is called, after a
-          // PrepareForOnApps call, then just populate the names_snapshot_ map.
-          names_snapshot_[inner.AppId()] = inner.Name();
-        } else {
-          // Otherwise, check that the names found during this OnAppUpdate call
-          // match those during the first OnAppUpdate call.
-          auto iter = names_snapshot_.find(inner.AppId());
-          EXPECT_EQ(inner.Name(),
-                    (iter != names_snapshot_.end()) ? iter->second : "");
-        }
-      }
-
-      if (outer.AppId() == inner.AppId()) {
-        ExpectEq(outer, inner);
-      }
-
-      if (inner.AppId() == "p") {
-        EXPECT_EQ(expected_name_for_p_, inner.Name());
-      }
-
-      num_apps++;
-    });
-    EXPECT_EQ(expected_num_apps_, num_apps);
-
-    EXPECT_FALSE(cache_->ForOneApp(
-        "no_such_app_id",
-        [&outer](const apps::AppUpdate& inner) { ExpectEq(outer, inner); }));
-
-    EXPECT_TRUE(cache_->ForOneApp(
-        outer.AppId(),
-        [&outer](const apps::AppUpdate& inner) { ExpectEq(outer, inner); }));
-
-    if (outer.NameChanged()) {
-      std::string old_name;
-      auto iter = old_names_.find(outer.AppId());
-      if (iter != old_names_.end()) {
-        old_name = iter->second;
-      }
-      // The way the tests are configured, if an app's name changes, it should
-      // increase (in string comparison order): e.g. from "" to "mango" or from
-      // "mango" to "mulberry" and never from "mulberry" to "melon".
-      EXPECT_LT(old_name, outer.Name());
-    }
-    old_names_[outer.AppId()] = outer.Name();
-
-    std::vector<apps::mojom::AppPtr> super_recursive;
-    while (!super_recursive_apps_.empty()) {
-      apps::mojom::AppPtr app = std::move(super_recursive_apps_.back());
-      super_recursive_apps_.pop_back();
-      if (app.get() == nullptr) {
-        // This is the placeholder 'punctuation'.
-        break;
-      }
-      super_recursive.push_back(std::move(app));
-    }
-    if (!super_recursive.empty()) {
-      cache_->OnApps(std::move(super_recursive), apps::mojom::AppType::kArc,
-                     false /* should_notify_initialized */);
-    }
-
-    num_apps_seen_on_app_update_++;
-  }
-
-  void OnAppTypeInitialized(apps::AppType app_type) override {
-    app_type_ = app_type;
-  }
-
-  void OnAppRegistryCacheWillBeDestroyed(
-      apps::AppRegistryCache* cache) override {
-    Observe(nullptr);
-  }
-
-  static void ExpectEq(const apps::AppUpdate& outer,
-                       const apps::AppUpdate& inner) {
-    EXPECT_EQ(outer.AppType(), inner.AppType());
-    EXPECT_EQ(outer.AppId(), inner.AppId());
-    EXPECT_EQ(outer.StateIsNull(), inner.StateIsNull());
-    EXPECT_EQ(outer.Readiness(), inner.Readiness());
-    EXPECT_EQ(outer.Name(), inner.Name());
-  }
-
-  raw_ptr<apps::AppRegistryCache> cache_;
-  std::string expected_name_for_p_;
-  int expected_num_apps_;
-  int num_apps_seen_on_app_update_;
-  AccountId account_id_ = AccountId::FromUserEmail("test@gmail.com");
-  apps::AppType app_type_ = apps::AppType::kUnknown;
-
-  // Records previously seen app names, keyed by app_id's, so we can check
-  // that, for these tests, a given app's name is always increasing (in string
-  // comparison order).
-  std::map<std::string, std::string> old_names_;
-
-  // Non-empty when this.OnAppsUpdate should trigger more cache_.OnApps calls.
-  //
-  // During OnAppsUpdate, this vector (a stack) is popped from the back until a
-  // nullptr 'punctuation' element (a group terminator) is seen. If that group
-  // of popped elements (in LIFO order) is non-empty, that group forms the
-  // vector of App's passed to cache_.OnApps.
-  std::vector<apps::mojom::AppPtr> super_recursive_apps_;
-
-  // For non-super-recursive tests (i.e. for check_names_snapshot_ == true), we
-  // check that the "app_id to name" mapping is consistent across every
-  // OnAppsUpdate call to this observer. For super-recursive tests, that
-  // mapping can change as updates are processed, so the names_snapshot_ check
-  // is skipped.
-  bool check_names_snapshot_ = false;
-  std::map<std::string, std::string> names_snapshot_;
-};
-
-// InitializedObserver is used to test the OnAppTypeInitialized interface for
-// AppRegistryCache::Observer.
-class InitializedObserver : public apps::AppRegistryCache::Observer {
- public:
-  explicit InitializedObserver(apps::AppRegistryCache* cache) {
-    Observe(cache);
-  }
-
-  ~InitializedObserver() override = default;
-
-  // apps::AppRegistryCache::Observer overrides.
-  void OnAppUpdate(const apps::AppUpdate& update) override {
-    updated_ids_.insert(update.AppId());
-  }
-
-  void OnAppTypeInitialized(apps::AppType app_type) override {
-    app_type_ = app_type;
-    ++count_;
-    app_count_ = updated_ids_.size();
-  }
-
-  void OnAppRegistryCacheWillBeDestroyed(
-      apps::AppRegistryCache* cache) override {
-    Observe(nullptr);
-  }
-
-  void SetAppType(apps::AppType app_type) { app_type_ = app_type; }
-
-  apps::AppType app_type() const { return app_type_; }
-
-  int count() const { return count_; }
-
-  int app_count() const { return app_count_; }
-
- private:
-  std::set<std::string> updated_ids_;
-  apps::AppType app_type_ = apps::AppType::kUnknown;
-  int count_ = 0;
-  int app_count_ = 0;
-};
-
-TEST_F(AppRegistryCacheMojomTest, ForEachApp) {
-  std::vector<apps::mojom::AppPtr> deltas;
-  apps::AppRegistryCache cache;
-  cache.SetAccountId(account_id());
-
-  updated_names_.clear();
-  CallForEachApp(cache);
-
-  EXPECT_EQ(0u, updated_names_.size());
-
-  deltas.clear();
-  deltas.push_back(MakeApp("a", "apple"));
-  deltas.push_back(MakeApp("b", "banana"));
-  deltas.push_back(MakeApp("c", "cherry"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-
-  updated_names_.clear();
-  CallForEachApp(cache);
-
-  EXPECT_EQ(3u, updated_names_.size());
-  EXPECT_NE(updated_names_.end(), updated_names_.find("apple"));
-  EXPECT_NE(updated_names_.end(), updated_names_.find("banana"));
-  EXPECT_NE(updated_names_.end(), updated_names_.find("cherry"));
-
-  deltas.clear();
-  deltas.push_back(MakeApp("a", "apricot"));
-  deltas.push_back(MakeApp("d", "durian"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-
-  updated_names_.clear();
-  CallForEachApp(cache);
-
-  EXPECT_EQ(4u, updated_names_.size());
-  EXPECT_NE(updated_names_.end(), updated_names_.find("apricot"));
-  EXPECT_NE(updated_names_.end(), updated_names_.find("banana"));
-  EXPECT_NE(updated_names_.end(), updated_names_.find("cherry"));
-  EXPECT_NE(updated_names_.end(), updated_names_.find("durian"));
-
-  // Test that ForOneApp succeeds for "c" and fails for "e".
-
-  bool found_c = false;
-  EXPECT_TRUE(cache.ForOneApp("c", [&found_c](const apps::AppUpdate& update) {
-    found_c = true;
-    EXPECT_EQ("c", update.AppId());
-  }));
-  EXPECT_TRUE(found_c);
-
-  bool found_e = false;
-  EXPECT_FALSE(cache.ForOneApp("e", [&found_e](const apps::AppUpdate& update) {
-    found_e = true;
-    EXPECT_EQ("e", update.AppId());
-  }));
-  EXPECT_FALSE(found_e);
-}
-
-TEST_F(AppRegistryCacheMojomTest, Removed) {
-  apps::AppRegistryCache cache;
-  testing::StrictMock<MockRegistryObserver> observer;
-  cache.SetAccountId(account_id());
-  cache.AddObserver(&observer);
-
-  // Starting with an empty cache.
-  cache.ForEachApp([&observer](const apps::AppUpdate& update) {
-    observer.OnAppUpdate(update);
-  });
-
-  // We add the app, and expect to be notified.
-  EXPECT_CALL(observer, OnAppUpdate(HasAppId("app")));
-  std::vector<apps::mojom::AppPtr> apps;
-  apps.push_back(MakeApp("app", "app", apps::mojom::Readiness::kReady));
-  cache.OnApps(std::move(apps), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-
-  // We first say the app is uninstalled, then remove it.
-  apps.clear();
-  apps.push_back(
-      MakeApp("app", "app", apps::mojom::Readiness::kUninstalledByUser));
-  apps.push_back(MakeApp("app", "app", apps::mojom::Readiness::kRemoved));
-
-  // We should see one call informing us that the app was uninstalled.
-  EXPECT_CALL(observer, OnAppUpdate(HasAppId("app")))
-      .WillOnce(
-          testing::Invoke([&observer, &cache](const apps::AppUpdate& update) {
-            EXPECT_EQ(apps::Readiness::kUninstalledByUser, update.Readiness());
-            // Even though we have queued the removal, checking the cache now
-            // shows the app is still present.
-            EXPECT_CALL(observer, OnAppUpdate(HasAppId("app")));
-            cache.ForEachApp([&observer](const apps::AppUpdate& update) {
-              observer.OnAppUpdate(update);
-            });
-          }));
-  cache.OnApps(std::move(apps), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-
-  // The cache is now empty.
-  cache.ForEachApp([](const apps::AppUpdate& update) { NOTREACHED(); });
-  cache.RemoveObserver(&observer);
-}
-
-TEST_F(AppRegistryCacheMojomTest, Observer) {
-  std::vector<apps::mojom::AppPtr> deltas;
-  apps::AppRegistryCache cache;
-  cache.SetAccountId(account_id());
-
-  cache.AddObserver(this);
-
-  num_freshly_installed_ = 0;
-  updated_ids_.clear();
-  deltas.clear();
-  deltas.push_back(MakeApp("a", "avocado"));
-  deltas.push_back(MakeApp("c", "cucumber"));
-  deltas.push_back(MakeApp("e", "eggfruit"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  EXPECT_EQ(0, num_freshly_installed_);
-  EXPECT_EQ(3u, updated_ids_.size());
-  EXPECT_NE(updated_ids_.end(), updated_ids_.find("a"));
-  EXPECT_NE(updated_ids_.end(), updated_ids_.find("c"));
-  EXPECT_NE(updated_ids_.end(), updated_ids_.find("e"));
-  EXPECT_EQ(apps::AppType::kArc, app_type());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-
-  SetAppType(apps::AppType::kUnknown);
-  num_freshly_installed_ = 0;
-  updated_ids_.clear();
-  deltas.clear();
-  deltas.push_back(MakeApp("b", "blueberry"));
-  deltas.push_back(MakeApp("c", "cucumber", apps::mojom::Readiness::kReady));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               false /* should_notify_initialized */);
-
-  EXPECT_EQ(1, num_freshly_installed_);
-  EXPECT_EQ(2u, updated_ids_.size());
-  EXPECT_NE(updated_ids_.end(), updated_ids_.find("b"));
-  EXPECT_NE(updated_ids_.end(), updated_ids_.find("c"));
-  EXPECT_EQ(apps::AppType::kUnknown, app_type());
-
-  cache.RemoveObserver(this);
-
-  num_freshly_installed_ = 0;
-  updated_ids_.clear();
-  deltas.clear();
-  deltas.push_back(MakeApp("f", "fig"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-
-  EXPECT_EQ(0, num_freshly_installed_);
-  EXPECT_EQ(0u, updated_ids_.size());
-  EXPECT_EQ(apps::AppType::kUnknown, app_type());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-}
-
-TEST_F(AppRegistryCacheMojomTest, Recursive) {
-  std::vector<apps::mojom::AppPtr> deltas;
-  apps::AppRegistryCache cache;
-  cache.SetAccountId(account_id());
-  RecursiveObserver observer(&cache);
-
-  observer.PrepareForOnApps(2, "peach");
-  deltas.clear();
-  deltas.push_back(MakeApp("o", "orange"));
-  deltas.push_back(MakeApp("p", "peach"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-  EXPECT_EQ(2, observer.NumAppsSeenOnAppUpdate());
-
-  observer.PrepareForOnApps(3, "pear");
-  deltas.clear();
-  deltas.push_back(MakeApp("p", "pear", apps::mojom::Readiness::kReady));
-  deltas.push_back(MakeApp("q", "quince"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-  EXPECT_EQ(2, observer.NumAppsSeenOnAppUpdate());
-
-  observer.PrepareForOnApps(3, "plum");
-  deltas.clear();
-  deltas.push_back(MakeApp("p", "pear"));
-  deltas.push_back(MakeApp("p", "pear"));
-  deltas.push_back(MakeApp("p", "plum"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kUnknown,
-               false /* should_notify_initialized */);
-  EXPECT_EQ(1, observer.NumAppsSeenOnAppUpdate());
-  EXPECT_EQ(apps::AppType::kArc, observer.app_type());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-}
-
-TEST_F(AppRegistryCacheMojomTest, SuperRecursive) {
-  std::vector<apps::mojom::AppPtr> deltas;
-  apps::AppRegistryCache cache;
-  cache.SetAccountId(account_id());
-  RecursiveObserver observer(&cache);
-
-  // Set up a series of OnApps to be called during observer.OnAppUpdate:
-  //  - the 1st update is {"blackberry, "coconut"}.
-  //  - the 2nd update is {}.
-  //  - the 3rd update is {"blackcurrant", "apricot", "blueberry"}.
-  //  - the 4th update is {"avocado"}.
-  //  - the 5th update is {}.
-  //  - the 6th update is {"boysenberry"}.
-  //
-  // The vector is processed in LIFO order with nullptr punctuation to
-  // terminate each group. See the comment on the
-  // RecursiveObserver::super_recursive_apps_ field.
-  std::vector<apps::mojom::AppPtr> super_recursive_apps;
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(MakeApp("b", "boysenberry"));
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(MakeApp("a", "avocado"));
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(MakeApp("b", "blueberry"));
-  super_recursive_apps.push_back(MakeApp("a", "apricot"));
-  super_recursive_apps.push_back(MakeApp("b", "blackcurrant"));
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(nullptr);
-  super_recursive_apps.push_back(MakeApp("c", "coconut"));
-  super_recursive_apps.push_back(MakeApp("b", "blackberry"));
-
-  observer.PrepareForOnApps(3, "", &super_recursive_apps);
-  deltas.clear();
-  deltas.push_back(MakeApp("a", "apple"));
-  deltas.push_back(MakeApp("b", "banana"));
-  deltas.push_back(MakeApp("c", "cherry"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // After all of that, check that for each app_id, the last delta won.
-  EXPECT_EQ("avocado", GetName(cache, "a"));
-  EXPECT_EQ("boysenberry", GetName(cache, "b"));
-  EXPECT_EQ("coconut", GetName(cache, "c"));
-  EXPECT_EQ(apps::AppType::kArc, observer.app_type());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-}
-
-TEST_F(AppRegistryCacheMojomTest, OnAppTypeInitialized) {
-  std::vector<apps::mojom::AppPtr> deltas;
-  apps::AppRegistryCache cache;
-  InitializedObserver observer1(&cache);
-
-  deltas.push_back(MakeApp("a", "avocado"));
-  deltas.push_back(MakeApp("c", "cucumber"));
-  deltas.push_back(MakeApp("e", "eggfruit"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  deltas.clear();
-  deltas.push_back(MakeApp("d", "durian"));
-  cache.OnApps(std::move(deltas), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  EXPECT_EQ(apps::AppType::kArc, observer1.app_type());
-  EXPECT_EQ(1, observer1.count());
-  EXPECT_EQ(3, observer1.app_count());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-
-  // New observers should not have OnAppTypeInitialized called.
-  InitializedObserver observer2(&cache);
-  EXPECT_EQ(apps::AppType::kUnknown, observer2.app_type());
-  EXPECT_EQ(0, observer2.count());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(apps::AppType::kArc));
-}
diff --git a/components/services/app_service/public/cpp/app_registry_cache_unittest.cc b/components/services/app_service/public/cpp/app_registry_cache_unittest.cc
index 4798bfc1..81047f7 100644
--- a/components/services/app_service/public/cpp/app_registry_cache_unittest.cc
+++ b/components/services/app_service/public/cpp/app_registry_cache_unittest.cc
@@ -391,30 +391,15 @@
     updated_names_.clear();
   }
 
-  void DisableOnAppTypeInitializedFlag() {
-    scoped_feature_list_.Reset();
-    if (IsOnAppUpdateWithoutMojomEnabled()) {
-      scoped_feature_list_.InitWithFeatures(
-          /*enabled_features=*/{kAppServiceOnAppUpdateWithoutMojom},
-          /*disabled_features=*/{kAppServiceOnAppTypeInitializedWithoutMojom});
-    } else {
-      scoped_feature_list_.InitWithFeatures(
-          /*enabled_features=*/{},
-          /*disabled_features=*/{kAppServiceOnAppTypeInitializedWithoutMojom,
-                                 kAppServiceOnAppUpdateWithoutMojom});
-    }
-  }
-
   void EnableOnAppTypeInitializedFlag() {
     scoped_feature_list_.Reset();
     if (IsOnAppUpdateWithoutMojomEnabled())
       scoped_feature_list_.InitWithFeatures(
-          /*enabled_features=*/{kAppServiceOnAppUpdateWithoutMojom,
-                                kAppServiceOnAppTypeInitializedWithoutMojom},
+          /*enabled_features=*/{kAppServiceOnAppUpdateWithoutMojom},
           /*disabled_features=*/{});
     else {
       scoped_feature_list_.InitWithFeatures(
-          /*enabled_features=*/{kAppServiceOnAppTypeInitializedWithoutMojom},
+          /*enabled_features=*/{},
           /*disabled_features=*/{kAppServiceOnAppUpdateWithoutMojom});
     }
   }
@@ -1034,286 +1019,6 @@
 }
 
 // Verify the OnAppTypeInitialized callback when OnApps is called for the non
-// mojom App type first, with the disabled flag.
-TEST_P(AppRegistryCacheTest,
-       OnAppTypeInitializedWithDisableFlagNonMojomUpdateFirst) {
-  DisableOnAppTypeInitializedFlag();
-
-  AppRegistryCache cache;
-  InitializedObserver observer1(&cache);
-
-  std::vector<AppPtr> deltas1;
-  deltas1.push_back(MakeApp("a", "avocado"));
-  deltas1.push_back(MakeApp("c", "cucumber"));
-  cache.OnApps(std::move(deltas1), AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // added.
-  EXPECT_TRUE(observer1.app_types().empty());
-  EXPECT_EQ(0, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_TRUE(cache.InitializedAppTypes().empty());
-  EXPECT_FALSE(cache.IsAppTypeInitialized(AppType::kArc));
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas1;
-  mojom_deltas1.push_back(MakeMojomApp("a", "avocado"));
-  mojom_deltas1.push_back(MakeMojomApp("c", "cucumber"));
-  cache.OnApps(std::move(mojom_deltas1), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are added.
-  EXPECT_TRUE(base::Contains(observer1.app_types(), apps::AppType::kArc));
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(2, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kArc));
-
-  std::vector<AppPtr> deltas2;
-  deltas2.push_back(MakeApp("d", "durian"));
-  cache.OnApps(std::move(deltas2), AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // added.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(2, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas2;
-  mojom_deltas2.push_back(MakeMojomApp("d", "durian"));
-  cache.OnApps(std::move(mojom_deltas2), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the mojom Apps are
-  // initialized again.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(2, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-
-  // Verify the new observers should not have OnAppTypeInitialized called.
-  InitializedObserver observer2(&cache);
-  EXPECT_TRUE(observer2.app_types().empty());
-  EXPECT_EQ(0, observer2.initialized_app_type_count());
-  EXPECT_EQ(0, observer2.app_count_at_initialization());
-}
-
-// Verify the OnAppTypeInitialized callback when OnApps is called for the mojom
-// App type first, with the disabled flag.
-TEST_P(AppRegistryCacheTest,
-       OnAppTypeInitializedWithDisableFlagMojomUpdateFirst) {
-  DisableOnAppTypeInitializedFlag();
-
-  AppRegistryCache cache;
-  InitializedObserver observer1(&cache);
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas1;
-  mojom_deltas1.push_back(MakeMojomApp("a", "avocado"));
-  mojom_deltas1.push_back(MakeMojomApp("c", "cucumber"));
-  cache.OnApps(std::move(mojom_deltas1), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // When OnAppUpdate is called for mojom App, "a" and "c" are updated.
-  // When OnAppUpdate is called for non mojom App, no app is updated.
-  int app_count = IsOnAppUpdateWithoutMojomEnabled() ? 0 : 2;
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are added.
-  EXPECT_TRUE(base::Contains(observer1.app_types(), apps::AppType::kArc));
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(app_count, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kArc));
-
-  std::vector<AppPtr> deltas1;
-  deltas1.push_back(MakeApp("a", "avocado"));
-  deltas1.push_back(MakeApp("c", "cucumber"));
-  cache.OnApps(std::move(deltas1), AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // added.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(app_count, observer1.app_count_at_initialization());
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas2;
-  mojom_deltas2.push_back(MakeMojomApp("d", "durian"));
-  cache.OnApps(std::move(mojom_deltas2), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  std::vector<AppPtr> deltas2;
-  deltas2.push_back(MakeApp("d", "durian"));
-  cache.OnApps(std::move(deltas2), AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the Apps are added.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(app_count, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-
-  // Verify the new observers should not have OnAppTypeInitialized called.
-  InitializedObserver observer2(&cache);
-  EXPECT_TRUE(observer2.app_types().empty());
-  EXPECT_EQ(0, observer2.initialized_app_type_count());
-  EXPECT_EQ(0, observer2.app_count_at_initialization());
-}
-
-// Verify the OnAppTypeInitialized callback when OnApps is called for multiple
-// App types, with the disabled flag.
-TEST_P(AppRegistryCacheTest,
-       OnAppTypeInitializedWithDisableFlagMultipleAppTypes) {
-  DisableOnAppTypeInitializedFlag();
-
-  AppRegistryCache cache;
-  InitializedObserver observer1(&cache);
-
-  std::vector<AppPtr> deltas1;
-  deltas1.push_back(MakeApp("a", "avocado"));
-  deltas1.push_back(MakeApp("c", "cucumber"));
-  cache.OnApps(std::move(deltas1), AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // added.
-  EXPECT_TRUE(observer1.app_types().empty());
-  EXPECT_EQ(0, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_TRUE(cache.InitializedAppTypes().empty());
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas1;
-  mojom_deltas1.push_back(MakeMojomApp("a", "avocado"));
-  mojom_deltas1.push_back(MakeMojomApp("c", "cucumber"));
-  cache.OnApps(std::move(mojom_deltas1), apps::mojom::AppType::kArc,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are added.
-  EXPECT_TRUE(base::Contains(observer1.app_types(), apps::AppType::kArc));
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(2, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kArc));
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas2;
-  mojom_deltas2.push_back(
-      MakeMojomApp("d", "durian", apps::mojom::AppType::kChromeApp));
-  cache.OnApps(std::move(mojom_deltas2), apps::mojom::AppType::kChromeApp,
-               true /* should_notify_initialized */);
-
-  // When OnAppUpdate is called for mojom App, "a", "c", "d", "n", "s" are
-  // updated. When OnAppUpdate is called for non mojom App, "a", "c", "n", "s"
-  // is updated.
-  int app_count = IsOnAppUpdateWithoutMojomEnabled() ? 4 : 5;
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are added.
-  EXPECT_EQ(2u, observer1.app_types().size());
-  EXPECT_TRUE(base::Contains(observer1.app_types(), apps::AppType::kChromeApp));
-  EXPECT_EQ(2, observer1.initialized_app_type_count());
-  EXPECT_EQ(app_count, observer1.app_count_at_initialization());
-  EXPECT_EQ(2u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kChromeApp));
-
-  std::vector<AppPtr> deltas2;
-  deltas2.push_back(MakeApp("d", "durian", AppType::kChromeApp));
-  cache.OnApps(std::move(deltas2), AppType::kChromeApp,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // added.
-  EXPECT_EQ(2, observer1.initialized_app_type_count());
-  EXPECT_EQ(app_count, observer1.app_count_at_initialization());
-  EXPECT_EQ(2u, cache.InitializedAppTypes().size());
-
-  // Verify the new observers should not have OnAppTypeInitialized called.
-  InitializedObserver observer2(&cache);
-  EXPECT_TRUE(observer2.app_types().empty());
-  EXPECT_EQ(0, observer2.initialized_app_type_count());
-  EXPECT_EQ(0, observer2.app_count_at_initialization());
-}
-
-// Verify the OnAppTypeInitialized callback when OnApps is called for empty apps
-// vector, with the disabled flag.
-TEST_P(AppRegistryCacheTest, OnAppTypeInitializedWithDisableFlagEmptyUpdate) {
-  DisableOnAppTypeInitializedFlag();
-
-  AppRegistryCache cache;
-  InitializedObserver observer1(&cache);
-
-  std::vector<AppPtr> deltas1;
-  cache.OnApps(std::move(deltas1), AppType::kStandaloneBrowserChromeApp,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // initialized.
-  EXPECT_TRUE(observer1.app_types().empty());
-  EXPECT_EQ(0, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_TRUE(cache.InitializedAppTypes().empty());
-  EXPECT_FALSE(
-      cache.IsAppTypeInitialized(AppType::kStandaloneBrowserChromeApp));
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas1;
-  cache.OnApps(std::move(mojom_deltas1),
-               apps::mojom::AppType::kStandaloneBrowserChromeApp,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are initialized.
-  EXPECT_TRUE(base::Contains(observer1.app_types(),
-                             apps::AppType::kStandaloneBrowserChromeApp));
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kStandaloneBrowserChromeApp));
-
-  std::vector<AppPtr> deltas2;
-  deltas2.push_back(MakeApp("d", "durian"));
-  cache.OnApps(std::move(deltas2), AppType::kStandaloneBrowserChromeApp,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // initialized again.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas2;
-  mojom_deltas2.push_back(MakeMojomApp("d", "durian"));
-  cache.OnApps(std::move(mojom_deltas2),
-               apps::mojom::AppType::kStandaloneBrowserChromeApp,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the mojom Apps are
-  // initialized again.
-  EXPECT_EQ(1, observer1.initialized_app_type_count());
-  EXPECT_EQ(0, observer1.app_count_at_initialization());
-  EXPECT_EQ(1u, cache.InitializedAppTypes().size());
-
-  std::vector<apps::mojom::AppPtr> mojom_deltas3;
-  cache.OnApps(std::move(mojom_deltas3), apps::mojom::AppType::kRemote,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is called when the mojom Apps are initialized.
-  EXPECT_EQ(2u, observer1.app_types().size());
-  EXPECT_TRUE(base::Contains(observer1.app_types(), apps::AppType::kRemote));
-  EXPECT_EQ(2, observer1.initialized_app_type_count());
-  EXPECT_EQ(2u, cache.InitializedAppTypes().size());
-  EXPECT_TRUE(cache.IsAppTypeInitialized(AppType::kRemote));
-
-  std::vector<AppPtr> deltas3;
-  cache.OnApps(std::move(deltas3), AppType::kRemote,
-               true /* should_notify_initialized */);
-
-  // Verify OnAppTypeInitialized is not called when the non mojom Apps are
-  // initialized.
-  EXPECT_EQ(2, observer1.initialized_app_type_count());
-  EXPECT_EQ(2u, cache.InitializedAppTypes().size());
-
-  // Verify the new observers should not have OnAppTypeInitialized called.
-  InitializedObserver observer2(&cache);
-  EXPECT_TRUE(observer2.app_types().empty());
-  EXPECT_EQ(0, observer2.initialized_app_type_count());
-  EXPECT_EQ(0, observer2.app_count_at_initialization());
-}
-
-// Verify the OnAppTypeInitialized callback when OnApps is called for the non
 // mojom App type first, with the enabled flag.
 TEST_P(AppRegistryCacheTest,
        OnAppTypeInitializedWithEnableFlagNonMojomUpdateFirst) {
diff --git a/components/services/app_service/public/cpp/features.cc b/components/services/app_service/public/cpp/features.cc
index b003aa0..78cec8e4 100644
--- a/components/services/app_service/public/cpp/features.cc
+++ b/components/services/app_service/public/cpp/features.cc
@@ -6,10 +6,6 @@
 
 namespace apps {
 
-const base::Feature kAppServiceOnAppTypeInitializedWithoutMojom{
-    "AppServiceOnAppTypeInitializedWithoutMojom",
-    base::FEATURE_ENABLED_BY_DEFAULT};
-
 const base::Feature kAppServiceOnAppUpdateWithoutMojom{
     "AppServiceOnAppUpdateWithoutMojom", base::FEATURE_ENABLED_BY_DEFAULT};
 
diff --git a/components/services/app_service/public/cpp/features.h b/components/services/app_service/public/cpp/features.h
index 9bd5d29..5f65e4c 100644
--- a/components/services/app_service/public/cpp/features.h
+++ b/components/services/app_service/public/cpp/features.h
@@ -11,8 +11,6 @@
 namespace apps {
 
 COMPONENT_EXPORT(APP_TYPES)
-extern const base::Feature kAppServiceOnAppTypeInitializedWithoutMojom;
-COMPONENT_EXPORT(APP_TYPES)
 extern const base::Feature kAppServiceOnAppUpdateWithoutMojom;
 COMPONENT_EXPORT(APP_TYPES)
 extern const base::Feature kAppServiceCrosApiOnAppsWithoutMojom;
diff --git a/components/services/screen_ai/proto/proto_convertor.cc b/components/services/screen_ai/proto/proto_convertor.cc
index 740d6b1b..f1c31a2 100644
--- a/components/services/screen_ai/proto/proto_convertor.cc
+++ b/components/services/screen_ai/proto/proto_convertor.cc
@@ -16,6 +16,7 @@
 #include <vector>
 
 #include "base/check_op.h"
+#include "base/containers/flat_map.h"
 #include "base/notreached.h"
 #include "base/numerics/checked_math.h"
 #include "base/numerics/clamped_math.h"
@@ -395,6 +396,31 @@
     AddSubTree(nodes, id_to_position, nodes_order, id_to_position[child_id]);
 }
 
+// Converts a Chrome role to a Screen2x role as text.
+// TODO(https://crbug.com/1278249): Remove after Screen2x proto generation
+// for training is done directly by Chrome.
+std::string GetScreen2xRoleFromChromeRole(ax::mojom::Role role) {
+  // Some roles have different texts in Screen2x.
+  static base::flat_map<ax::mojom::Role, std::string> exceptions_map = {
+      {ax::mojom::Role::kComboBoxGrouping, "combobox"},
+      {ax::mojom::Role::kContentInfo, "contentinfo"},
+      {ax::mojom::Role::kDescriptionList, "DescriptionList"},
+      {ax::mojom::Role::kDescriptionListDetail, "DescriptionListDetail"},
+      {ax::mojom::Role::kDescriptionListTerm, "DescriptionListTerm"},
+      {ax::mojom::Role::kGenericContainer, "generic"},
+      {ax::mojom::Role::kHeaderAsNonLandmark, "HeaderAsNonLandmark"},
+      {ax::mojom::Role::kImage, "img"},
+      {ax::mojom::Role::kLineBreak, "LineBreak"},
+      {ax::mojom::Role::kListItem, "listitem"},
+      {ax::mojom::Role::kListMarker, "ListMarker"},
+      {ax::mojom::Role::kRootWebArea, "RootWebArea"},
+      {ax::mojom::Role::kSection, "Section"},
+      {ax::mojom::Role::kStaticText, "StaticText"}};
+
+  const auto& item = exceptions_map.find(role);
+  return item == exceptions_map.end() ? ui::ToString(role) : item->second;
+}
+
 }  // namespace
 
 namespace screen_ai {
@@ -579,7 +605,7 @@
     // Role.
     attrib = uie->add_attributes();
     attrib->set_name("chrome_role");
-    attrib->set_string_value(ui::ToString(node.role));
+    attrib->set_string_value(GetScreen2xRoleFromChromeRole(node.role));
 
     // AXNode ID.
     attrib = uie->add_attributes();
@@ -587,10 +613,10 @@
     attrib->set_int_value(ax_node_id);
 
     // Child IDs.
+    attrib = uie->add_attributes();
+    attrib->set_name("/axnode/child_ids");
     for (const ui::AXNodeID& id : node.child_ids) {
-      attrib = uie->add_attributes();
-      attrib->set_name("/axnode/child_ids");
-      attrib->set_int_value(id);
+      attrib->mutable_int_list_value()->add_value(id);
       uie->add_child_ids(new_id[id]);
     }
 
diff --git a/components/services/screen_ai/proto/proto_convertor_unittest.cc b/components/services/screen_ai/proto/proto_convertor_unittest.cc
index 7472923a..593db060 100644
--- a/components/services/screen_ai/proto/proto_convertor_unittest.cc
+++ b/components/services/screen_ai/proto/proto_convertor_unittest.cc
@@ -4,6 +4,7 @@
 
 #include "components/services/screen_ai/proto/proto_convertor.h"
 
+#include <algorithm>
 #include <string>
 
 #include "base/files/file_path.h"
@@ -19,6 +20,7 @@
 #include "ui/accessibility/ax_node_data.h"
 #include "ui/accessibility/ax_tree_update.h"
 #include "ui/accessibility/test_ax_tree_update_json_reader.h"
+#include "ui/gfx/geometry/point_f.h"
 
 namespace {
 
@@ -93,25 +95,132 @@
   return std::string();
 }
 
-void CompareViewHierarchyProtos(screenai::ViewHierarchy& generated,
-                                screenai::ViewHierarchy& expected) {
+template <class T>
+void ExpectBoundingBoxes(const T& box1,
+                         const T& box2,
+                         const gfx::PointF& max_diff) {
+  EXPECT_NEAR(box1.top(), box2.top(), max_diff.y());
+  EXPECT_NEAR(box1.left(), box2.left(), max_diff.x());
+  EXPECT_NEAR(box1.bottom(), box2.bottom(), max_diff.y());
+  EXPECT_NEAR(box1.right(), box2.right(), max_diff.x());
+}
+
+// TODO(https://crbug.com/1278249): Consider making the comparison not sensitive
+// to order.
+template <class T>
+void ExpectLists(const T& list1, const T& list2) {
+  EXPECT_EQ(list1.value_size(), list2.value_size());
+  int min_length = std::min(list1.value_size(), list2.value_size());
+  for (int i = 0; i < min_length; i++)
+    EXPECT_EQ(list1.value(i), list2.value(i));
+}
+
+void ExpectAttributes(const ::screenai::UiElementAttribute& attrib1,
+                      const ::screenai::UiElementAttribute& attrib2) {
+  SCOPED_TRACE(
+      base::StringPrintf("Comparing attribute: %s", attrib1.name().c_str()));
+  EXPECT_EQ(attrib1.value_case(), attrib2.value_case());
+
+  switch (attrib1.value_case()) {
+    case screenai::UiElementAttribute::ValueCase::kBoolValue:
+      EXPECT_EQ(attrib1.bool_value(), attrib2.bool_value());
+      break;
+    case screenai::UiElementAttribute::kIntValue:
+      EXPECT_EQ(attrib1.int_value(), attrib2.int_value());
+      break;
+    case screenai::UiElementAttribute::kStringValue:
+      EXPECT_EQ(attrib1.string_value(), attrib2.string_value());
+      break;
+    case screenai::UiElementAttribute::kFloatValue:
+      EXPECT_EQ(attrib1.float_value(), attrib2.float_value());
+      break;
+    case screenai::UiElementAttribute::kIntListValue: {
+      ExpectLists(attrib1.int_list_value(), attrib2.int_list_value());
+      break;
+    }
+    case screenai::UiElementAttribute::kStringListValue: {
+      ExpectLists(attrib1.int_list_value(), attrib2.int_list_value());
+      break;
+    }
+    case screenai::UiElementAttribute::kFloatListValue: {
+      NOTREACHED() << "Chrome has no float list.";
+      break;
+    }
+    case screenai::UiElementAttribute::VALUE_NOT_SET:
+      break;
+  }
+}
+
+void ExpectViewHierarchyProtos(screenai::ViewHierarchy& generated,
+                               screenai::ViewHierarchy& expected) {
   EXPECT_EQ(generated.ui_elements_size(), expected.ui_elements_size());
 
+  // Bounding boxes can have a one pixel difference threshold as there might be
+  // different approaches in rounding floats to integers.
+  // To compare |bounding_box_pixels| values which represent bounding boxes in
+  // pixels, we use |kPixelDifferenceThreshold|.
+  const gfx::PointF kPixelDifferenceThreshold(1, 1);
+
+  // |bounding_box| values represent the relative position of a bounding box to
+  // the tree, and as each of them (the element and the tree) can have a one
+  // pixel error, the total error can be up to two pixels. To get the tree size
+  // to compute |kRelativeDifferenceThreshold|, we use the 0th element which
+  // should be the root and cover the entire tree.
+  const auto& root = expected.ui_elements(0);
+  const gfx::PointF kRelativeDifferenceThreshold(
+      2.0 / root.bounding_box_pixels().right(),
+      2.0 / root.bounding_box_pixels().bottom());
+  EXPECT_EQ(root.bounding_box_pixels().top(), 0);
+  EXPECT_EQ(root.bounding_box_pixels().left(), 0);
+
   for (int i = 0; i < generated.ui_elements_size(); i++) {
     SCOPED_TRACE(base::StringPrintf("Comparing ui_elements at index: %i", i));
-    const screenai::UiElement& gen_uie = generated.ui_elements(i);
-    const screenai::UiElement& exp_uie = expected.ui_elements(i);
+    const screenai::UiElement& generated_uie = generated.ui_elements(i);
+    const screenai::UiElement& expected_uie = expected.ui_elements(i);
 
-    // TODO(https://crbug.com/1278249): Consider adding a comparison approach
-    // that iterates all values for lite protos.
-    EXPECT_EQ(gen_uie.id(), exp_uie.id());
-    EXPECT_EQ(gen_uie.type(), exp_uie.type());
-    EXPECT_EQ(gen_uie.parent_id(), exp_uie.parent_id());
-    EXPECT_EQ(GetStringAttribute(gen_uie, "text"),
-              GetStringAttribute(exp_uie, "text"));
+    EXPECT_EQ(generated_uie.id(), expected_uie.id());
+    EXPECT_EQ(generated_uie.type(), expected_uie.type());
+    EXPECT_EQ(generated_uie.parent_id(), expected_uie.parent_id());
+    EXPECT_EQ(GetStringAttribute(generated_uie, "text"),
+              GetStringAttribute(expected_uie, "text"));
 
-    // TODO(https://crbug.com/1278249): Compare child_ids, attributes,
-    // bounding_box, and bounding_box_pixels.
+    EXPECT_EQ(generated_uie.child_ids_size(), expected_uie.child_ids_size());
+    int min_length =
+        std::min(generated_uie.child_ids_size(), expected_uie.child_ids_size());
+    for (int child_index = 0; child_index < min_length; child_index++)
+      EXPECT_EQ(generated_uie.child_ids(child_index),
+                expected_uie.child_ids(child_index));
+
+    ExpectBoundingBoxes(generated_uie.bounding_box(),
+                        expected_uie.bounding_box(),
+                        kRelativeDifferenceThreshold);
+    ExpectBoundingBoxes(generated_uie.bounding_box_pixels(),
+                        expected_uie.bounding_box_pixels(),
+                        kPixelDifferenceThreshold);
+
+    // Attributes may have different orders in the two protos.
+    std::map<std::string, int> attribute_index;
+    for (int j = 0; j < expected_uie.attributes_size(); j++)
+      attribute_index[expected_uie.attributes(j).name()] = j;
+
+    for (int j = 0; j < generated_uie.attributes_size(); j++) {
+      const ::screenai::UiElementAttribute& generated_attrib =
+          generated_uie.attributes(j);
+
+      const auto& expected_attrib_index =
+          attribute_index.find(generated_attrib.name());
+      EXPECT_NE(expected_attrib_index, attribute_index.end())
+          << "Could not find attribute: " << generated_attrib.name();
+      if (expected_attrib_index != attribute_index.end()) {
+        ExpectAttributes(generated_attrib, expected_uie.attributes(
+                                               expected_attrib_index->second));
+      }
+    }
+
+    // TODO(https://crbug.com/1278249): Ensure all expected attributes are
+    // generated.
+    // EXPECT_EQ(generated_uie.attributes().size(),
+    //           expected_uie.attributes().size());
   }
 }
 
@@ -218,7 +327,8 @@
 
     const std::string expected_update(
         "id=4 dialog (0, 0)-(800, 900) child_ids=5,6\n"
-        "  id=5 button offset_container_id=4 (0, 1)-(2, 3) transform=[ +0.0000 "
+        "  id=5 button offset_container_id=4 (0, 1)-(2, 3) transform=[ "
+        "+0.0000 "
         "-1.0000 +0.0000 +0.0000  \n"
         "  +1.0000 +0.0000 +0.0000 +0.0000  \n"
         "  +0.0000 +0.0000 +1.0000 +0.0000  \n"
@@ -284,15 +394,15 @@
 
 TEST_F(ProtoConvertorTest, ViewHierarchyProtoGenerationTest) {
   // TODO(https://crbug.com/1278249): Add more tests.
-  const base::FilePath input_json_path =
+  const base::FilePath kInputJsonPath =
       GetTestFilePath("sample_01_ax_tree.json");
-  const base::FilePath expected_proto_path =
+  const base::FilePath kExpectedProtoPath =
       GetTestFilePath("sample_01_expected_proto.pbtxt");
 
   // Load JSON file.
   std::string file_content;
-  ASSERT_TRUE(base::ReadFileToString(input_json_path, &file_content))
-      << "Failed to load input AX tree: " << input_json_path;
+  ASSERT_TRUE(base::ReadFileToString(kInputJsonPath, &file_content))
+      << "Failed to load input AX tree: " << kInputJsonPath;
   absl::optional<base::Value> json = base::JSONReader::Read(file_content);
   ASSERT_TRUE(json.has_value());
 
@@ -310,15 +420,15 @@
   WriteDebugProto(serialized_proto, "proto_convertor_output.pbtxt");
 
   // Load expected Proto.
-  ASSERT_TRUE(base::ReadFileToString(expected_proto_path, &file_content))
-      << "Failed to read expected proto from " << expected_proto_path;
+  ASSERT_TRUE(base::ReadFileToString(kExpectedProtoPath, &file_content))
+      << "Failed to read expected proto from " << kExpectedProtoPath;
   screenai::ViewHierarchy expected_view_hierarchy;
   ASSERT_TRUE(expected_view_hierarchy.ParseFromString(file_content))
       << "Failed to parse expected proto.";
 
   // Compare protos.
-  ASSERT_NO_FATAL_FAILURE(CompareViewHierarchyProtos(generated_view_hierarchy,
-                                                     expected_view_hierarchy));
+  ASSERT_NO_FATAL_FAILURE(ExpectViewHierarchyProtos(generated_view_hierarchy,
+                                                    expected_view_hierarchy));
 }
 
 }  // namespace screen_ai
diff --git a/components/signin/core/browser/account_reconcilor_unittest.cc b/components/signin/core/browser/account_reconcilor_unittest.cc
index 7be43cb..b18054ff 100644
--- a/components/signin/core/browser/account_reconcilor_unittest.cc
+++ b/components/signin/core/browser/account_reconcilor_unittest.cc
@@ -37,6 +37,7 @@
 #include "components/signin/public/identity_manager/primary_account_mutator.h"
 #include "components/signin/public/identity_manager/set_accounts_in_cookie_result.h"
 #include "components/sync_preferences/testing_pref_service_syncable.h"
+#include "google_apis/gaia/core_account_id.h"
 #include "google_apis/gaia/gaia_constants.h"
 #include "google_apis/gaia/gaia_urls.h"
 #include "google_apis/gaia/google_service_auth_error.h"
@@ -413,8 +414,6 @@
   const char* gaia_api_calls;
   const char* tokens_after_reconcile;
   const char* cookies_after_reconcile;
-  // Int represents AccountReconcilorDelegate::InconsistencyReason.
-  const int inconsistency_reason;
 };
 
 std::vector<AccountReconcilorTestTableParam> GenerateTestCasesFromParams(
@@ -466,6 +465,8 @@
     bool has_error;
   };
 
+  virtual void CreateReconclior() { GetMockReconcilor(); }
+
   // Build Tokens from string.
   std::vector<Token> ParseTokenString(const char* token_string) {
     std::vector<Token> parsed_tokens;
@@ -580,8 +581,134 @@
     identity_test_env()->SetFreshnessOfAccountsInGaiaCookie(false);
   }
 
-  std::string GaiaIdForAccountKey(char account_key) {
-    return accounts_[account_key].gaia_id;
+  Account GetAccount(const CoreAccountId& account_id) {
+    for (const auto& pair : accounts_) {
+      const Account& account = pair.second;
+      if (PickAccountIdForAccount(account.gaia_id, account.email) == account_id)
+        return account;
+    }
+    NOTREACHED();
+    return Account();
+  }
+
+  // Simulates the effect of a Multilogin call on the cookies.
+  std::vector<Cookie> FakeSetAccountsInCookie(
+      const signin::MultiloginParameters& parameters,
+      const std::vector<Cookie>& cookies_before_reconcile) {
+    std::vector<Cookie> cookies_after_reconcile;
+    if (parameters.mode ==
+        gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER) {
+      for (const CoreAccountId& account_id : parameters.accounts_to_send) {
+        cookies_after_reconcile.push_back(
+            {GetAccount(account_id).gaia_id, true});
+      }
+    } else {
+      std::vector<std::string> gaia_ids;
+      for (const auto& account_id : parameters.accounts_to_send)
+        gaia_ids.push_back(GetAccount(account_id).gaia_id);
+      cookies_after_reconcile = cookies_before_reconcile;
+      for (Cookie& cookie : cookies_after_reconcile) {
+        if (base::Contains(gaia_ids, cookie.gaia_id)) {
+          cookie.is_valid = true;
+          gaia_ids.erase(
+              std::find(gaia_ids.begin(), gaia_ids.end(), cookie.gaia_id));
+        } else {
+          DCHECK(!cookie.is_valid);
+        }
+      }
+      for (const std::string& gaia_id : gaia_ids)
+        cookies_after_reconcile.push_back({gaia_id, true});
+    }
+    return cookies_after_reconcile;
+  }
+
+  // Runs the test corresponding to one row of the table.
+  void RunRowTest(const AccountReconcilorTestTableParam& param) {
+    // Setup cookies.
+    std::vector<Cookie> cookies = ParseCookieString(param.cookies);
+    ConfigureCookieManagerService(cookies);
+    std::vector<Cookie> cookies_after_reconcile = cookies;
+
+    // Call list accounts now so that the next call completes synchronously.
+    identity_test_env()->identity_manager()->GetAccountsInCookieJar();
+    base::RunLoop().RunUntilIdle();
+
+    // Setup tokens. This triggers listing cookies so we need to setup cookies
+    // before that.
+    SetupTokens(param.tokens);
+
+    CreateReconclior();
+
+    // Setup expectations.
+    testing::InSequence mock_sequence;
+    bool should_logout = false;
+    if (param.gaia_api_calls[0] != '\0') {
+      if (param.gaia_api_calls[0] == 'X') {
+        should_logout = true;
+        EXPECT_CALL(*GetMockReconcilor(), PerformLogoutAllAccountsAction())
+            .Times(1);
+        cookies_after_reconcile.clear();
+      } else {
+        gaia::MultiloginMode mode =
+            param.gaia_api_calls[0] == 'U'
+                ? gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER
+                : gaia::MultiloginMode::
+                      MULTILOGIN_PRESERVE_COOKIE_ACCOUNTS_ORDER;
+        // Generate expected array of accounts in cookies and set fake gaia
+        // response.
+        std::vector<CoreAccountId> accounts_to_send;
+        for (int i = 1; param.gaia_api_calls[i] != '\0'; ++i) {
+          const Account& account = accounts_[param.gaia_api_calls[i]];
+          accounts_to_send.push_back(
+              PickAccountIdForAccount(account.gaia_id, account.email));
+        }
+        DCHECK(!accounts_to_send.empty());
+        const signin::MultiloginParameters params(mode, accounts_to_send);
+        cookies_after_reconcile = FakeSetAccountsInCookie(params, cookies);
+        EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(params))
+            .Times(1);
+      }
+    }
+    // Reconcile.
+    AccountReconcilor* reconcilor = GetMockReconcilor();
+    ASSERT_TRUE(reconcilor);
+    ASSERT_TRUE(reconcilor->first_execution_);
+    reconcilor->first_execution_ =
+        param.is_first_reconcile == IsFirstReconcile::kFirst ? true : false;
+    reconcilor->StartReconcile(AccountReconcilor::Trigger::kCookieChange);
+    if (param.gaia_api_calls[0] != '\0') {
+      if (should_logout) {
+        SimulateLogOutFromCookieCompleted(
+            reconcilor, GoogleServiceAuthError::AuthErrorNone());
+      } else {
+        SimulateSetAccountsInCookieCompleted(
+            reconcilor, signin::SetAccountsInCookieResult::kSuccess);
+      }
+    }
+
+    ASSERT_FALSE(reconcilor->is_reconcile_started_);
+    if (param.tokens == param.tokens_after_reconcile) {
+      EXPECT_EQ(signin_metrics::ACCOUNT_RECONCILOR_OK, reconcilor->GetState());
+    } else {
+      // If the tokens were changed by the reconcile, a new reconcile should be
+      // scheduled.
+      EXPECT_EQ(signin_metrics::ACCOUNT_RECONCILOR_SCHEDULED,
+                reconcilor->GetState());
+    }
+    VerifyCurrentTokens(ParseTokenString(param.tokens_after_reconcile));
+
+    std::vector<Cookie> cookies_after =
+        ParseCookieString(param.cookies_after_reconcile);
+    EXPECT_EQ(cookies_after, cookies_after_reconcile);
+
+    testing::Mock::VerifyAndClearExpectations(GetMockReconcilor());
+
+    // Another reconcile is sometimes triggered if Chrome accounts have
+    // changed. Allow it to finish.
+    EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(testing::_))
+        .WillRepeatedly(testing::Return());
+    ConfigureCookieManagerService({});
+    base::RunLoop().RunUntilIdle();
   }
 
   std::map<char, Account> accounts_;
@@ -665,37 +792,6 @@
 
 #if BUILDFLAG(ENABLE_DICE_SUPPORT)
 
-namespace {
-std::vector<Cookie> FakeSetAccountsInCookie(
-    const signin::MultiloginParameters& parameters,
-    const std::vector<Cookie>& cookies_before_reconcile) {
-  std::vector<Cookie> cookies_after_reconcile;
-  if (parameters.mode ==
-      gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER) {
-    for (const CoreAccountId& account : parameters.accounts_to_send) {
-      cookies_after_reconcile.push_back({account.ToString(), true});
-    }
-  } else {
-    std::vector<CoreAccountId> accounts(parameters.accounts_to_send.begin(),
-                                        parameters.accounts_to_send.end());
-    cookies_after_reconcile = cookies_before_reconcile;
-    for (Cookie& param : cookies_after_reconcile) {
-      CoreAccountId account = CoreAccountId(param.gaia_id);
-      if (base::Contains(accounts, account)) {
-        param.is_valid = true;
-        accounts.erase(std::find(accounts.begin(), accounts.end(), account));
-      } else {
-        DCHECK(!param.is_valid);
-      }
-    }
-    for (const CoreAccountId& account : accounts) {
-      cookies_after_reconcile.push_back({account.ToString(), true});
-    }
-  }
-  return cookies_after_reconcile;
-}
-}  // namespace
-
 // clang-format off
 const std::vector<AccountReconcilorTestTableParam> kDiceParams = {
     // This table encodes the initial state and expectations of a reconcile.
@@ -716,162 +812,163 @@
     //   x: The next cookie is marked "invalid".
     // - First Run: true if this is the first reconcile (i.e. Chrome startup).
     // -------------------------------------------------------------------------
-    // Tokens|Cookies|First Run|Gaia calls|Tokens aft.|Cookies aft.|AccountReconcilorDelegate::InconsistencyReason |
+    // Tokens|Cookies| First Run            |Gaia calls|Tokens aft.|Cookies aft.
     // -------------------------------------------------------------------------
 
     // First reconcile (Chrome restart): Rebuild the Gaia cookie to match the
     // tokens. Make the Sync account the default account in the Gaia cookie.
     // Sync enabled.
-    {  "",      "A",   IsFirstReconcile::kBoth,    "U",    "",     "",      3},
-    {  "*AB",   "AB",  IsFirstReconcile::kBoth,    "",     "*AB",  "AB",    0},
-    {  "*A",    "A",   IsFirstReconcile::kBoth,    "",     "*A" ,  "A",     0},
-    {  "*A",    "",    IsFirstReconcile::kBoth,    "PA",   "*A" ,  "A",     1},
-    {  "*A",    "B",   IsFirstReconcile::kBoth,    "UA",   "*A" ,  "A",     1},
-    {  "*A",    "AB",  IsFirstReconcile::kBoth,    "UA",   "*A" ,  "A",     5},
-    {  "*AB",   "BA",  IsFirstReconcile::kFirst,   "UAB",  "*AB",  "AB",    7},
-    {  "*AB",   "BA",  IsFirstReconcile::kNotFirst,"",     "*AB",  "BA",    0},
+    {  "",      "A",   IsFirstReconcile::kBoth,     "X",    "",     ""        },
+    {  "*AB",   "AB",  IsFirstReconcile::kBoth,     "",     "*AB",  "AB"      },
+    {  "*A",    "A",   IsFirstReconcile::kBoth,     "",     "*A" ,  "A"       },
+    {  "*A",    "",    IsFirstReconcile::kBoth,     "PA",   "*A" ,  "A"       },
+    {  "*A",    "B",   IsFirstReconcile::kBoth,     "UA",   "*A" ,  "A"       },
+    {  "*A",    "AB",  IsFirstReconcile::kBoth,     "UA",   "*A" ,  "A"       },
+    {  "*AB",   "BA",  IsFirstReconcile::kFirst,    "UAB",  "*AB",  "AB"      },
+    {  "*AB",   "BA",  IsFirstReconcile::kNotFirst, "",     "*AB",  "BA"      },
 
-    {  "*AB",   "A",   IsFirstReconcile::kBoth,    "PAB",  "*AB",  "AB",    4},
+    {  "*AB",   "A",   IsFirstReconcile::kBoth,     "PAB",  "*AB",  "AB"      },
 
-    {  "*AB",   "B",   IsFirstReconcile::kFirst,   "UAB",  "*AB",  "AB",    1},
-    {  "*AB",   "B",   IsFirstReconcile::kNotFirst,"PBA",  "*AB",  "BA",    1},
+    {  "*AB",   "B",   IsFirstReconcile::kFirst,    "UAB",  "*AB",  "AB"      },
+    {  "*AB",   "B",   IsFirstReconcile::kNotFirst, "PBA",  "*AB",  "BA"      },
 
-    {  "*AB",   "",    IsFirstReconcile::kBoth,    "PAB",  "*AB",  "AB",    1},
+    {  "*AB",   "",    IsFirstReconcile::kBoth,     "PAB",  "*AB",  "AB"      },
     // Sync enabled, token error on primary.
 
-    {  "*xAB",  "AB",  IsFirstReconcile::kBoth,    "U",    "*xA",  "",      2},
-    {  "*xAB",  "BA",  IsFirstReconcile::kBoth,    "UB",   "*xAB", "B",     2},
-    {  "*xAB",  "A",   IsFirstReconcile::kBoth,    "U",    "*xA",  "",      2},
-    {  "*xAB",  "B",   IsFirstReconcile::kBoth,    "",     "*xAB", "B",     0},
-    {  "*xAB",  "",    IsFirstReconcile::kBoth,    "PB",   "*xAB", "B",     0},
+    {  "*xAB",  "AB",  IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAB",  "BA",  IsFirstReconcile::kBoth,     "UB",   "*xAB", "B"       },
+    {  "*xAB",  "A",   IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAB",  "B",   IsFirstReconcile::kBoth,     "",     "*xAB", "B"       },
+    {  "*xAB",  "",    IsFirstReconcile::kBoth,     "PB",   "*xAB", "B"       },
     // Sync enabled, token error on secondary.
-    {  "*AxB",  "AB",  IsFirstReconcile::kBoth,    "UA",   "*A",   "A",     5},
-    {  "*AxB",  "A",   IsFirstReconcile::kBoth,    "",     "*A",   "A",     0},
-    {  "*AxB",  "",    IsFirstReconcile::kBoth,    "PA",   "*A",   "A",     1},
+    {  "*AxB",  "AB",  IsFirstReconcile::kBoth,     "UA",   "*A",   "A"       },
+    {  "*AxB",  "A",   IsFirstReconcile::kBoth,     "",     "*A",   "A"       },
+    {  "*AxB",  "",    IsFirstReconcile::kBoth,     "PA",   "*A",   "A"       },
     // The first account in cookies is swapped even when Chrome is running.
-    // The swap would happen at next startup anyway and doing it earlier avoids signing the user out.
-    {  "*AxB",  "BA",  IsFirstReconcile::kBoth,     "UA",   "*A",   "A",     5},
-    {  "*AxB",  "B",   IsFirstReconcile::kBoth,     "UA",   "*A",   "A",     1},
+    // The swap would happen at next startup anyway and doing it earlier avoids
+    // signing the user out.
+    {  "*AxB",  "BA",  IsFirstReconcile::kBoth,     "UA",   "*A",   "A"       },
+    {  "*AxB",  "B",   IsFirstReconcile::kBoth,     "UA",   "*A",   "A"       },
     // Sync enabled, token error on both accounts.
-    {  "*xAxB", "AB",  IsFirstReconcile::kBoth,     "U",    "*xA",  "",      2},
-    {  "*xAxB", "BA",  IsFirstReconcile::kBoth,     "U",    "*xA",  "",      2},
-    {  "*xAxB", "A",   IsFirstReconcile::kBoth,     "U",    "*xA",  "",      2},
-    {  "*xAxB", "B",   IsFirstReconcile::kBoth,     "U",    "*xA",  "",      5},
-    {  "*xAxB", "",    IsFirstReconcile::kBoth,     "",     "*xA",  "",      0},
+    {  "*xAxB", "AB",  IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAxB", "BA",  IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAxB", "A",   IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAxB", "B",   IsFirstReconcile::kBoth,     "X",    "*xA",  ""        },
+    {  "*xAxB", "",    IsFirstReconcile::kBoth,     "",     "*xA",  ""        },
     // Sync disabled.
-    {  "AB",    "AB",  IsFirstReconcile::kBoth,     "",     "AB",   "AB",    0},
-    {  "AB",    "BA",  IsFirstReconcile::kBoth,     "",     "AB",   "BA",    0},
-    {  "AB",    "A",   IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB",    4},
-    {  "AB",    "B",   IsFirstReconcile::kBoth,     "PBA",  "AB",   "BA",    4},
-    {  "AB",    "",    IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB",    0},
+    {  "AB",    "AB",  IsFirstReconcile::kBoth,     "",     "AB",   "AB"      },
+    {  "AB",    "BA",  IsFirstReconcile::kBoth,     "",     "AB",   "BA"      },
+    {  "AB",    "A",   IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB"      },
+    {  "AB",    "B",   IsFirstReconcile::kBoth,     "PBA",  "AB",   "BA"      },
+    {  "AB",    "",    IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB"      },
     // Sync disabled, token error on first account.
-    {  "xAB",   "AB",  IsFirstReconcile::kFirst,    "UB",   "B",    "B",     3},
-    {  "xAB",   "AB",  IsFirstReconcile::kNotFirst, "U",    "",     "",      3},
+    {  "xAB",   "AB",  IsFirstReconcile::kFirst,    "UB",   "B",    "B"       },
+    {  "xAB",   "AB",  IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "xAB",   "BA",  IsFirstReconcile::kBoth,     "UB",   "B",    "B",     5},
+    {  "xAB",   "BA",  IsFirstReconcile::kBoth,     "UB",   "B",    "B"       },
 
-    {  "xAB",   "A",   IsFirstReconcile::kFirst,    "UB",   "B",    "B",     3},
-    {  "xAB",   "A",   IsFirstReconcile::kNotFirst, "U",    "",     "",      3},
+    {  "xAB",   "A",   IsFirstReconcile::kFirst,    "UB",   "B",    "B"       },
+    {  "xAB",   "A",   IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "xAB",   "B",   IsFirstReconcile::kBoth,     "",     "B",    "B",     0},
+    {  "xAB",   "B",   IsFirstReconcile::kBoth,     "",     "B",    "B"       },
 
-    {  "xAB",   "",    IsFirstReconcile::kBoth,     "PB",   "B",    "B",     0},
+    {  "xAB",   "",    IsFirstReconcile::kBoth,     "PB",   "B",    "B"       },
     // Sync disabled, token error on second account
-    {  "AxB",   "AB",  IsFirstReconcile::kBoth,     "UA",   "A",    "A",     5},
+    {  "AxB",   "AB",  IsFirstReconcile::kBoth,     "UA",   "A",    "A"       },
 
-    {  "AxB",   "BA",  IsFirstReconcile::kFirst,    "UA",   "A",    "A",     3},
-    {  "AxB",   "BA",  IsFirstReconcile::kNotFirst, "U",    "",     "",      3},
+    {  "AxB",   "BA",  IsFirstReconcile::kFirst,    "UA",   "A",    "A"       },
+    {  "AxB",   "BA",  IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "AxB",   "A",   IsFirstReconcile::kBoth,     "",     "A",    "A",     0},
+    {  "AxB",   "A",   IsFirstReconcile::kBoth,     "",     "A",    "A"       },
 
-    {  "AxB",   "B",   IsFirstReconcile::kFirst,    "UA",   "A",    "A",     3},
-    {  "AxB",   "B",   IsFirstReconcile::kNotFirst, "U",    "",     "",      3},
+    {  "AxB",   "B",   IsFirstReconcile::kFirst,    "UA",   "A",    "A"       },
+    {  "AxB",   "B",   IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "AxB",   "",    IsFirstReconcile::kBoth,     "PA",   "A",    "A",     0},
+    {  "AxB",   "",    IsFirstReconcile::kBoth,     "PA",   "A",    "A"       },
     // Sync disabled, token error on both accounts.
-    {  "xAxB",  "AB",  IsFirstReconcile::kBoth,     "U",    "",     "",      3},
-    {  "xAxB",  "BA",  IsFirstReconcile::kBoth,     "U",    "",     "",      3},
-    {  "xAxB",  "A",   IsFirstReconcile::kBoth,     "U",    "",     "",      3},
-    {  "xAxB",  "B",   IsFirstReconcile::kBoth,     "U",    "",     "",      3},
-    {  "xAxB",  "",    IsFirstReconcile::kBoth,     "",     "",     "",      0},
+    {  "xAxB",  "AB",  IsFirstReconcile::kBoth,     "X",    "",     ""        },
+    {  "xAxB",  "BA",  IsFirstReconcile::kBoth,     "X",    "",     ""        },
+    {  "xAxB",  "A",   IsFirstReconcile::kBoth,     "X",    "",     ""        },
+    {  "xAxB",  "B",   IsFirstReconcile::kBoth,     "X",    "",     ""        },
+    {  "xAxB",  "",    IsFirstReconcile::kBoth,     "",     "",     ""        },
     // Account marked as invalid in cookies.
     // No difference between cookies and tokens, do not do do anything.
     // Do not logout. Regression tests for http://crbug.com/854799
-    {  "",     "xA",   IsFirstReconcile::kBoth,     "",     "",     "xA",    0},
-    {  "",     "xAxB", IsFirstReconcile::kBoth,     "",     "",     "xAxB",  0},
-    {  "xA",   "xA",   IsFirstReconcile::kBoth,     "",     "",     "xA",    0},
-    {  "xAB",  "xAB",  IsFirstReconcile::kBoth,     "",     "B",    "xAB",   0},
-    {  "AxB",  "AxC",  IsFirstReconcile::kBoth,     "",     "A",    "AxC",   0},
-    {  "B",    "xAB",  IsFirstReconcile::kBoth,     "",     "B",    "xAB",   0},
-    {  "*xA",  "xA",   IsFirstReconcile::kBoth,     "",     "*xA",  "xA",    0},
-    {  "*xA",  "xB",   IsFirstReconcile::kBoth,     "",     "*xA",  "xB",    0},
-    {  "*xAB", "xAB",  IsFirstReconcile::kBoth,     "",     "*xAB", "xAB",   0},
-    {  "*AxB", "xBA",  IsFirstReconcile::kNotFirst, "",     "*A",   "xBA",   0},
+    {  "",     "xA",   IsFirstReconcile::kBoth,     "",     "",     "xA"      },
+    {  "",     "xAxB", IsFirstReconcile::kBoth,     "",     "",     "xAxB"    },
+    {  "xA",   "xA",   IsFirstReconcile::kBoth,     "",     "",     "xA"      },
+    {  "xAB",  "xAB",  IsFirstReconcile::kBoth,     "",     "B",    "xAB"     },
+    {  "AxB",  "AxC",  IsFirstReconcile::kBoth,     "",     "A",    "AxC"     },
+    {  "B",    "xAB",  IsFirstReconcile::kBoth,     "",     "B",    "xAB"     },
+    {  "*xA",  "xA",   IsFirstReconcile::kBoth,     "",     "*xA",  "xA"      },
+    {  "*xA",  "xB",   IsFirstReconcile::kBoth,     "",     "*xA",  "xB"      },
+    {  "*xAB", "xAB",  IsFirstReconcile::kBoth,     "",     "*xAB", "xAB"     },
+    {  "*AxB", "xBA",  IsFirstReconcile::kNotFirst, "",     "*A",   "xBA"     },
     // Appending a new cookie after the invalid one.
-    {  "B",    "xA",   IsFirstReconcile::kBoth,     "PB",   "B",    "xAB",   4},
-    {  "xAB",  "xA",   IsFirstReconcile::kBoth,     "PB",   "B",    "xAB",   4},
+    {  "B",    "xA",   IsFirstReconcile::kBoth,     "PB",   "B",    "xAB"     },
+    {  "xAB",  "xA",   IsFirstReconcile::kBoth,     "PB",   "B",    "xAB"     },
     // Refresh existing cookies.
-    {  "AB",   "xAB",  IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB",    4},
-    {  "*AB",  "xBxA", IsFirstReconcile::kNotFirst, "PBA",  "*AB",  "BA",    1},
+    {  "AB",   "xAB",  IsFirstReconcile::kBoth,     "PAB",  "AB",   "AB"      },
+    {  "*AB",  "xBxA", IsFirstReconcile::kNotFirst, "PBA",  "*AB",  "BA"      },
     // Appending and invalidating cookies at the same time.
-    {  "xAB",  "xAC",  IsFirstReconcile::kFirst,    "UB",   "B",    "B",     6},
-    {  "xAB",  "xAC",  IsFirstReconcile::kNotFirst, "U",    "",     "",      6},
+    {  "xAB",  "xAC",  IsFirstReconcile::kFirst,    "UB",   "B",    "B"       },
+    {  "xAB",  "xAC",  IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "xAB",  "AxC",  IsFirstReconcile::kFirst,    "UB",   "B",    "B",     3},
-    {  "xAB",  "AxC",  IsFirstReconcile::kNotFirst, "U",    "",     "",      3},
+    {  "xAB",  "AxC",  IsFirstReconcile::kFirst,    "UB",   "B",    "B"       },
+    {  "xAB",  "AxC",  IsFirstReconcile::kNotFirst, "X",    "",     ""        },
 
-    {  "*xAB", "xABC", IsFirstReconcile::kFirst,    "UB",   "*xAB", "B",     5},
-    {  "*xAB", "xABC", IsFirstReconcile::kNotFirst, "U",    "*xA",  "",      5},
+    {  "*xAB", "xABC", IsFirstReconcile::kFirst,    "UB",   "*xAB", "B"       },
+    {  "*xAB", "xABC", IsFirstReconcile::kNotFirst, "X",    "*xA",  ""        },
 
-    {  "xAB",  "xABC", IsFirstReconcile::kFirst,    "UB",   "B",    "B",     5},
-    {  "xAB",  "xABC", IsFirstReconcile::kNotFirst, "U",    "",     "",      5},
+    {  "xAB",  "xABC", IsFirstReconcile::kFirst,    "UB",   "B",    "B"       },
+    {  "xAB",  "xABC", IsFirstReconcile::kNotFirst, "X",    "",     ""        },
     // Miscellaneous cases.
     // Check that unknown Gaia accounts are signed o.
-    {  "*A",   "AB",   IsFirstReconcile::kBoth,     "UA",   "*A",   "A",     5},
+    {  "*A",   "AB",   IsFirstReconcile::kBoth,     "UA",   "*A",   "A"       },
     // Check that Gaia default account is kept in first position.
-    {  "AB",   "BC",   IsFirstReconcile::kBoth,     "UBA",  "AB",   "BA",    6},
+    {  "AB",   "BC",   IsFirstReconcile::kBoth,     "UBA",  "AB",   "BA"      },
     // Check that Gaia cookie order is preserved for B.
-    {  "*ABC", "CB",   IsFirstReconcile::kFirst,    "UABC", "*ABC", "ABC",   1},
+    {  "*ABC", "CB",   IsFirstReconcile::kFirst,    "UABC", "*ABC", "ABC"     },
     // TODO(https://crbug.com/1129931): Merge session should do XCB instead.
-    {  "xABC", "ABC",  IsFirstReconcile::kFirst,    "UCB",  "BC",   "CB",    1},
+    {  "xABC", "ABC",  IsFirstReconcile::kFirst,    "UCB",  "BC",   "CB"      },
     // Check that order in the chrome_accounts is not important.
-    {  "A*B",  "",     IsFirstReconcile::kBoth,     "PBA",  "A*B",  "BA",    7},
-    {  "*xBA", "BA",   IsFirstReconcile::kFirst,    "U",    "*xB",  "",      2},
+    {  "A*B",  "",     IsFirstReconcile::kBoth,     "PBA",  "A*B",  "BA"      },
+    {  "*xBA", "BA",   IsFirstReconcile::kFirst,    "X",    "*xB",  ""        },
     // Required for idempotency check.
-    {  "",     "",     IsFirstReconcile::kNotFirst, "",     "",     "",      0},
-    {  "",     "xA",   IsFirstReconcile::kNotFirst, "",     "",     "xA",    0},
-    {  "",     "xB",   IsFirstReconcile::kNotFirst, "",     "",     "xB",    0},
-    {  "",     "xAxB", IsFirstReconcile::kNotFirst, "",     "",     "xAxB",  0},
-    {  "",     "xBxA", IsFirstReconcile::kNotFirst, "",     "",     "xBxA",  0},
-    {  "*A",   "A",    IsFirstReconcile::kNotFirst, "",     "*A",   "A",     0},
-    {  "*A",   "xBA",  IsFirstReconcile::kNotFirst, "",     "*A",   "xBA",   0},
-    {  "*A",   "AxB",  IsFirstReconcile::kNotFirst, "",     "*A",   "AxB",   0},
-    {  "A",    "A",    IsFirstReconcile::kNotFirst, "",     "A",    "A",     0},
-    {  "A",    "xBA",  IsFirstReconcile::kNotFirst, "",     "A",    "xBA",   0},
-    {  "A",    "AxB",  IsFirstReconcile::kNotFirst, "",     "A",    "AxB",   0},
-    {  "B",    "B",    IsFirstReconcile::kNotFirst, "",     "B",    "B",     0},
-    {  "B",    "xAB",  IsFirstReconcile::kNotFirst, "",     "B",    "xAB",   0},
-    {  "B",    "BxA",  IsFirstReconcile::kNotFirst, "",     "B",    "BxA",   0},
-    {  "*xA",  "",     IsFirstReconcile::kNotFirst, "",     "*xA",  "",      0},
-    {  "*xA",  "xAxB", IsFirstReconcile::kNotFirst, "",     "*xA",  "xAxB",  0},
-    {  "*xA",  "xBxA", IsFirstReconcile::kNotFirst, "",     "*xA",  "xBxA",  0},
-    {  "*xA",  "xA",   IsFirstReconcile::kNotFirst, "",     "*xA",  "xA",    0},
-    {  "*xA",  "xB",   IsFirstReconcile::kNotFirst, "",     "*xA",  "xB",    0},
-    {  "*xAB", "B",    IsFirstReconcile::kNotFirst, "",     "*xAB", "B",     0},
-    {  "*xAB", "BxA",  IsFirstReconcile::kNotFirst, "",     "*xAB", "BxA",   0},
-    {  "*xAB", "xAB",  IsFirstReconcile::kNotFirst, "",     "*xAB", "xAB",   0},
-    {  "*xAB", "xABxC",IsFirstReconcile::kNotFirst, "",     "*xAB", "xABxC", 0},
-    {  "*xB",  "",     IsFirstReconcile::kNotFirst, "",     "*xB",  "",      0},
-    {  "A*B",  "BA",   IsFirstReconcile::kNotFirst, "",     "A*B",  "BA",    0},
-    {  "A*B",  "AB",   IsFirstReconcile::kNotFirst, "",     "A*B",  "AB",    0},
-    {  "A",    "AxC",  IsFirstReconcile::kNotFirst, "",     "A",    "AxC",   0},
-    {  "AB",   "BxCA", IsFirstReconcile::kNotFirst, "",     "AB",   "BxCA",  0},
-    {  "B",    "xABxC",IsFirstReconcile::kNotFirst, "",     "B",    "xABxC", 0},
-    {  "B",    "xAxCB",IsFirstReconcile::kNotFirst, "",     "B",    "xAxCB", 0},
-    {  "*ABC", "ACB",  IsFirstReconcile::kNotFirst, "",     "*ABC", "ACB",   0},
-    {  "*ABC", "ABC",  IsFirstReconcile::kNotFirst, "",     "*ABC", "ABC",   0},
-    {  "BC",   "BC",   IsFirstReconcile::kNotFirst, "",     "BC",   "BC",    0},
-    {  "BC",   "CB",   IsFirstReconcile::kNotFirst, "",     "BC",   "CB",    0},
+    {  "",     "",     IsFirstReconcile::kNotFirst, "",     "",     ""        },
+    {  "",     "xA",   IsFirstReconcile::kNotFirst, "",     "",     "xA"      },
+    {  "",     "xB",   IsFirstReconcile::kNotFirst, "",     "",     "xB"      },
+    {  "",     "xAxB", IsFirstReconcile::kNotFirst, "",     "",     "xAxB"    },
+    {  "",     "xBxA", IsFirstReconcile::kNotFirst, "",     "",     "xBxA"    },
+    {  "*A",   "A",    IsFirstReconcile::kNotFirst, "",     "*A",   "A"       },
+    {  "*A",   "xBA",  IsFirstReconcile::kNotFirst, "",     "*A",   "xBA"     },
+    {  "*A",   "AxB",  IsFirstReconcile::kNotFirst, "",     "*A",   "AxB"     },
+    {  "A",    "A",    IsFirstReconcile::kNotFirst, "",     "A",    "A"       },
+    {  "A",    "xBA",  IsFirstReconcile::kNotFirst, "",     "A",    "xBA"     },
+    {  "A",    "AxB",  IsFirstReconcile::kNotFirst, "",     "A",    "AxB"     },
+    {  "B",    "B",    IsFirstReconcile::kNotFirst, "",     "B",    "B"       },
+    {  "B",    "xAB",  IsFirstReconcile::kNotFirst, "",     "B",    "xAB"     },
+    {  "B",    "BxA",  IsFirstReconcile::kNotFirst, "",     "B",    "BxA"     },
+    {  "*xA",  "",     IsFirstReconcile::kNotFirst, "",     "*xA",  ""        },
+    {  "*xA",  "xAxB", IsFirstReconcile::kNotFirst, "",     "*xA",  "xAxB"    },
+    {  "*xA",  "xBxA", IsFirstReconcile::kNotFirst, "",     "*xA",  "xBxA"    },
+    {  "*xA",  "xA",   IsFirstReconcile::kNotFirst, "",     "*xA",  "xA"      },
+    {  "*xA",  "xB",   IsFirstReconcile::kNotFirst, "",     "*xA",  "xB"      },
+    {  "*xAB", "B",    IsFirstReconcile::kNotFirst, "",     "*xAB", "B"       },
+    {  "*xAB", "BxA",  IsFirstReconcile::kNotFirst, "",     "*xAB", "BxA"     },
+    {  "*xAB", "xAB",  IsFirstReconcile::kNotFirst, "",     "*xAB", "xAB"     },
+    {  "*xAB", "xABxC",IsFirstReconcile::kNotFirst, "",     "*xAB", "xABxC"   },
+    {  "*xB",  "",     IsFirstReconcile::kNotFirst, "",     "*xB",  ""        },
+    {  "A*B",  "BA",   IsFirstReconcile::kNotFirst, "",     "A*B",  "BA"      },
+    {  "A*B",  "AB",   IsFirstReconcile::kNotFirst, "",     "A*B",  "AB"      },
+    {  "A",    "AxC",  IsFirstReconcile::kNotFirst, "",     "A",    "AxC"     },
+    {  "AB",   "BxCA", IsFirstReconcile::kNotFirst, "",     "AB",   "BxCA"    },
+    {  "B",    "xABxC",IsFirstReconcile::kNotFirst, "",     "B",    "xABxC"   },
+    {  "B",    "xAxCB",IsFirstReconcile::kNotFirst, "",     "B",    "xAxCB"   },
+    {  "*ABC", "ACB",  IsFirstReconcile::kNotFirst, "",     "*ABC", "ACB"     },
+    {  "*ABC", "ABC",  IsFirstReconcile::kNotFirst, "",     "*ABC", "ABC"     },
+    {  "BC",   "BC",   IsFirstReconcile::kNotFirst, "",     "BC",   "BC"      },
+    {  "BC",   "CB",   IsFirstReconcile::kNotFirst, "",     "BC",   "CB"      },
 };
 // clang-format on
 
@@ -890,90 +987,8 @@
 // Checks one row of the kDiceParams table above.
 TEST_P(AccountReconcilorTestDiceMultilogin, TableRowTest) {
   SetAccountConsistency(signin::AccountConsistencyMethod::kDice);
-
   CheckReconcileIdempotent(kDiceParams, GetParam());
-
-  // Setup cookies.
-  std::vector<Cookie> cookies = ParseCookieString(GetParam().cookies);
-  ConfigureCookieManagerService(cookies);
-  std::vector<Cookie> cookies_after_reconcile = cookies;
-
-  // Call list accounts now so that the next call completes synchronously.
-  identity_test_env()->identity_manager()->GetAccountsInCookieJar();
-  base::RunLoop().RunUntilIdle();
-
-  // Setup tokens. This triggers listing cookies so we need to setup cookies
-  // before that.
-  SetupTokens(GetParam().tokens);
-
-  // Setup expectations.
-  testing::InSequence mock_sequence;
-  bool should_logout = false;
-  if (GetParam().gaia_api_calls[0] != '\0') {
-    gaia::MultiloginMode mode =
-        GetParam().gaia_api_calls[0] == 'U'
-            ? gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER
-            : gaia::MultiloginMode::MULTILOGIN_PRESERVE_COOKIE_ACCOUNTS_ORDER;
-    // Generate expected array of accounts in cookies and set fake gaia
-    // response.
-    std::vector<CoreAccountId> accounts_to_send;
-    for (int i = 1; GetParam().gaia_api_calls[i] != '\0'; ++i) {
-      accounts_to_send.push_back(
-          CoreAccountId(accounts_[GetParam().gaia_api_calls[i]].gaia_id));
-    }
-    const signin::MultiloginParameters params(mode, accounts_to_send);
-    cookies_after_reconcile = FakeSetAccountsInCookie(params, cookies);
-    should_logout =
-        accounts_to_send.empty() &&
-        (mode == gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER);
-    if (should_logout) {
-      EXPECT_CALL(*GetMockReconcilor(), PerformLogoutAllAccountsAction())
-          .Times(1);
-    } else {
-      EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(params))
-          .Times(1);
-    }
-  }
-  // Reconcile.
-  AccountReconcilor* reconcilor = GetMockReconcilor();
-  ASSERT_TRUE(reconcilor);
-  ASSERT_TRUE(reconcilor->first_execution_);
-  reconcilor->first_execution_ =
-      GetParam().is_first_reconcile == IsFirstReconcile::kFirst ? true : false;
-  reconcilor->StartReconcile(AccountReconcilor::Trigger::kCookieChange);
-  if (GetParam().gaia_api_calls[0] != '\0') {
-    if (should_logout) {
-      SimulateLogOutFromCookieCompleted(
-          reconcilor, GoogleServiceAuthError::AuthErrorNone());
-    } else {
-      SimulateSetAccountsInCookieCompleted(
-          reconcilor, signin::SetAccountsInCookieResult::kSuccess);
-    }
-  }
-
-  ASSERT_FALSE(reconcilor->is_reconcile_started_);
-  if (GetParam().tokens == GetParam().tokens_after_reconcile) {
-    EXPECT_EQ(signin_metrics::ACCOUNT_RECONCILOR_OK, reconcilor->GetState());
-  } else {
-    // If the tokens were changed by the reconcile, a new reconcile should be
-    // scheduled.
-    EXPECT_EQ(signin_metrics::ACCOUNT_RECONCILOR_SCHEDULED,
-              reconcilor->GetState());
-  }
-  VerifyCurrentTokens(ParseTokenString(GetParam().tokens_after_reconcile));
-
-  std::vector<Cookie> cookies_after =
-      ParseCookieString(GetParam().cookies_after_reconcile);
-  EXPECT_EQ(cookies_after, cookies_after_reconcile);
-
-  testing::Mock::VerifyAndClearExpectations(GetMockReconcilor());
-
-  // Another reconcile is sometimes triggered if Chrome accounts have
-  // changed. Allow it to finish.
-  EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(testing::_))
-      .WillRepeatedly(testing::Return());
-  ConfigureCookieManagerService({});
-  base::RunLoop().RunUntilIdle();
+  RunRowTest(GetParam());
 }
 
 INSTANTIATE_TEST_SUITE_P(
@@ -1291,39 +1306,40 @@
 const std::vector<AccountReconcilorTestTableParam> kMirrorParams = {
 // This table encodes the initial state and expectations of a reconcile.
 // See kDiceParams for documentation of the syntax.
-// -------------------------------------------------------------------------
-// Tokens | Cookies | First Run            | Gaia calls | Tokens after | Cookies after
-// -------------------------------------------------------------------------
+// -----------------------------------------------------------------------------
+// Tokens | Cookies | First Run          |Gaia calls|Tokens after| Cookies after
+// -----------------------------------------------------------------------------
 
 // First reconcile (Chrome restart): Rebuild the Gaia cookie to match the
 // tokens. Make the Sync account the default account in the Gaia cookie.
 // Sync enabled.
 {  "*AB",   "AB",   IsFirstReconcile::kBoth, "",          "*AB",         "AB"},
-{  "*AB",   "BA",   IsFirstReconcile::kBoth, "U",         "*AB",         "AB"},
-{  "*AB",   "A",    IsFirstReconcile::kBoth, "U",         "*AB",         "AB"},
-{  "*AB",   "B",    IsFirstReconcile::kBoth, "U",         "*AB",         "AB"},
-{  "*AB",   "",     IsFirstReconcile::kBoth, "U",         "*AB",         "AB"},
+{  "*AB",   "BA",   IsFirstReconcile::kBoth, "UAB",       "*AB",         "AB"},
+{  "*AB",   "A",    IsFirstReconcile::kBoth, "UAB",       "*AB",         "AB"},
+{  "*AB",   "B",    IsFirstReconcile::kBoth, "UAB",       "*AB",         "AB"},
+{  "*AB",   "",     IsFirstReconcile::kBoth, "UAB",       "*AB",         "AB"},
 // Sync enabled, token error on primary.
 // Sync enabled, token error on secondary.
-{  "*AxB",  "AB",   IsFirstReconcile::kBoth, "U",         "*AxB",        "A"},
-{  "*AxB",  "BA",   IsFirstReconcile::kBoth, "U",         "*AxB",        "A"},
-{  "*AxB",  "A",    IsFirstReconcile::kBoth, "",          "*AxB",        ""},
-{  "*AxB",  "B",    IsFirstReconcile::kBoth, "U",         "*AxB",        "A"},
-{  "*AxB",  "",     IsFirstReconcile::kBoth, "U",         "*AxB",        "A"},
+{  "*AxB",  "AB",   IsFirstReconcile::kBoth, "UA",        "*AxB",        "A"},
+{  "*AxB",  "BA",   IsFirstReconcile::kBoth, "UA",        "*AxB",        "A"},
+{  "*AxB",  "A",    IsFirstReconcile::kBoth, "",          "*AxB",        "A"},
+{  "*AxB",  "B",    IsFirstReconcile::kBoth, "UA",        "*AxB",        "A"},
+{  "*AxB",  "",     IsFirstReconcile::kBoth, "UA",        "*AxB",        "A"},
 
 // Cookies can be refreshed in pace, without logout.
-{  "*AB",   "xBxA", IsFirstReconcile::kBoth, "U",         "*AB",         "AB"},
+{  "*AB",   "xBxA", IsFirstReconcile::kBoth, "UAB",       "*AB",         "AB"},
 
 // Check that unknown Gaia accounts are signed out.
-{  "*A",    "AB",   IsFirstReconcile::kBoth, "U",         "*A",          "A"},
+{  "*A",    "AB",   IsFirstReconcile::kBoth, "UA",        "*A",          "A"},
 // Check that the previous case is idempotent.
-{  "*A",    "A",    IsFirstReconcile::kBoth, "",          "*A",          ""},
+{  "*A",    "A",    IsFirstReconcile::kBoth, "",          "*A",          "A"},
 
 // On Lacros, the reconcilor is enabled even if there is no account, or if the
 // primary account is in error.
 #if BUILDFLAG(IS_CHROMEOS_LACROS)
 {  "",      "",     IsFirstReconcile::kBoth, "",          "",            ""},
 {  "*xA",   "",     IsFirstReconcile::kBoth, "",          "*xA",         ""},
+{  "*xAB",  "",     IsFirstReconcile::kBoth, "",          "*xAB",        ""},
 {  "",      "A",    IsFirstReconcile::kBoth, "X",         "",            ""},
 {  "*xA",   "A",    IsFirstReconcile::kBoth, "X",         "*xA",         ""},
 {  "*xAB",  "AB",   IsFirstReconcile::kBoth, "X",         "*xAB",        ""},
@@ -1344,86 +1360,12 @@
       const AccountReconcilorTestMirrorMultilogin&) = delete;
 };
 
-// Checks one row of the kDiceParams table above.
+// Checks one row of the kMirrorParams table above.
 TEST_P(AccountReconcilorTestMirrorMultilogin, TableRowTest) {
   // Enable Mirror.
   SetAccountConsistency(signin::AccountConsistencyMethod::kMirror);
-
-  // Setup cookies.
-  std::vector<Cookie> cookies = ParseCookieString(GetParam().cookies);
-  ConfigureCookieManagerService(cookies);
-
-  // Call list accounts now so that the next call completes synchronously.
-  identity_test_env()->identity_manager()->GetAccountsInCookieJar();
-  base::RunLoop().RunUntilIdle();
-
-  // Setup tokens.
-  SetupTokens(GetParam().tokens);
-
-  // Setup expectations.
-  testing::InSequence mock_sequence;
-  bool logout_action = false;
-  for (int i = 0; GetParam().gaia_api_calls[i] != '\0'; ++i) {
-    if (GetParam().gaia_api_calls[i] == 'X') {
-      logout_action = true;
-      EXPECT_CALL(*GetMockReconcilor(), PerformLogoutAllAccountsAction())
-          .Times(1);
-      cookies.clear();
-      continue;
-    }
-    if (GetParam().gaia_api_calls[i] == 'U') {
-      std::vector<CoreAccountId> accounts_to_send;
-      for (int j = 0; GetParam().cookies_after_reconcile[j] != '\0'; ++j) {
-        char cookie = GetParam().cookies_after_reconcile[j];
-        std::string account_to_send = GaiaIdForAccountKey(cookie);
-        accounts_to_send.push_back(PickAccountIdForAccount(
-            account_to_send,
-            accounts_[GetParam().cookies_after_reconcile[j]].email));
-      }
-      const signin::MultiloginParameters ml_params(
-          gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER,
-          accounts_to_send);
-      EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(ml_params))
-          .Times(1);
-    }
-  }
-  if (!logout_action) {
-    EXPECT_CALL(*GetMockReconcilor(), PerformLogoutAllAccountsAction())
-        .Times(0);
-  }
-
-  // Reconcile.
-  AccountReconcilor* reconcilor = GetMockReconcilor();
-  ASSERT_TRUE(reconcilor);
-  ASSERT_TRUE(reconcilor->first_execution_);
-  reconcilor->first_execution_ =
-      GetParam().is_first_reconcile == IsFirstReconcile::kFirst ? true : false;
-  reconcilor->StartReconcile(AccountReconcilor::Trigger::kCookieChange);
-
-  if (GetParam().gaia_api_calls[0] != '\0') {
-    if (logout_action) {
-      SimulateLogOutFromCookieCompleted(
-          reconcilor, GoogleServiceAuthError::AuthErrorNone());
-    } else {
-      SimulateSetAccountsInCookieCompleted(
-          reconcilor, signin::SetAccountsInCookieResult::kSuccess);
-    }
-  }
-
-  ASSERT_FALSE(reconcilor->is_reconcile_started_);
-  ASSERT_EQ(signin_metrics::ACCOUNT_RECONCILOR_OK, reconcilor->GetState());
-  VerifyCurrentTokens(ParseTokenString(GetParam().tokens_after_reconcile));
-
-  testing::Mock::VerifyAndClearExpectations(GetMockReconcilor());
-
-  // Another reconcile is sometimes triggered if Chrome accounts have
-  // changed. Allow it to finish.
-  EXPECT_CALL(*GetMockReconcilor(), PerformSetCookiesAction(testing::_))
-      .WillRepeatedly(testing::Return());
-  EXPECT_CALL(*GetMockReconcilor(), PerformLogoutAllAccountsAction())
-      .WillRepeatedly(testing::Return());
-  ConfigureCookieManagerService({});
-  base::RunLoop().RunUntilIdle();
+  CheckReconcileIdempotent(kMirrorParams, GetParam());
+  RunRowTest(GetParam());
 }
 
 INSTANTIATE_TEST_SUITE_P(
@@ -1445,6 +1387,12 @@
     SetAccountConsistency(signin::AccountConsistencyMethod::kMirror);
   }
 
+  void CreateReconclior() override {
+    DeleteReconcilor();
+    CreateMockReconcilor(
+        std::make_unique<signin::ActiveDirectoryAccountReconcilorDelegate>());
+  }
+
  private:
   ash::ScopedStubInstallAttributes install_attributes_{
       ash::StubInstallAttributes::CreateActiveDirectoryManaged("realm.com",
@@ -1455,103 +1403,37 @@
 const std::vector<AccountReconcilorTestTableParam> kActiveDirectoryParams = {
 // This table encodes the initial state and expectations of a reconcile.
 // See kDiceParams for documentation of the syntax.
-// -------------------------------------------------------------------------
-// Tokens  |Cookies |First Run     |Gaia calls|Tokens aft.|Cookies aft |
-// -------------------------------------------------------------------------
-{  "ABC",   "ABC",   IsFirstReconcile::kBoth,   "" ,    "ABC",   "ABC" },
-{  "ABC",   "",      IsFirstReconcile::kBoth,   "U",    "ABC",   "ABC" },
-{  "",      "ABC",   IsFirstReconcile::kBoth,   "X",    "",      "",   },
+// -----------------------------------------------------------------------------
+// Tokens  |Cookies |First Run             |Gaia calls|Tokens aft.|Cookies aft |
+// -----------------------------------------------------------------------------
+{  "ABC",   "ABC",   IsFirstReconcile::kBoth, "" ,     "ABC",      "ABC"      },
+{  "ABC",   "",      IsFirstReconcile::kBoth, "UABC",  "ABC",      "ABC"      },
+{  "",      "ABC",   IsFirstReconcile::kBoth, "X",     "",         ""         },
+{  "",      "",      IsFirstReconcile::kBoth, "",      "",         ""         },
 // Order of Gaia accounts can be different from chrome accounts.
-{  "ABC",   "CBA",   IsFirstReconcile::kBoth,   "" ,    "ABC",   "CBA" },
-{  "ABC",   "CB",    IsFirstReconcile::kBoth,   "U",    "ABC",   "CBA" },
+{  "ABC",   "CBA",   IsFirstReconcile::kBoth, "" ,     "ABC",      "CBA"      },
+{  "ABC",   "CB",    IsFirstReconcile::kBoth, "UCBA",  "ABC",      "CBA"      },
 // Gaia accounts which are not present in chrome accounts should be removed. In
 // this case Gaia accounts are going to be in the same order as chrome accounts.
-// this case Gaia accounts are going to be in thcousame order as chromcnts.
-{  "A",     "AB",    IsFirstReconcile::kBoth,   "U",   "A",     "A"   },
-{  "AB",    "CBA",   IsFirstReconcile::kBoth,   "U",   "AB",    "AB"  },
-{  "AB",    "C",     IsFirstReconcile::kBoth,   "U",   "AB",    "AB"  },
+{  "A",     "AB",    IsFirstReconcile::kBoth, "UA",    "A",        "A"        },
+{  "AB",    "CBA",   IsFirstReconcile::kBoth, "UAB",   "AB",       "AB"       },
+{  "AB",    "C",     IsFirstReconcile::kBoth, "UAB",   "AB",       "AB"       },
 // Cookies can be refreshed in pace, without logout.
-{  "AB",    "xAxB",  IsFirstReconcile::kBoth,   "U",    "AB",    "AB"  },
+{  "AB",    "xAxB",  IsFirstReconcile::kBoth, "UAB",   "AB",       "AB"       },
 // Token error on the account - remove it from cookies
-{  "AxB",   "AB",    IsFirstReconcile::kBoth,   "U",   "AxB",    "A"   },
-{  "xAxB",  "AB",    IsFirstReconcile::kBoth,   "X",   "xAxB",   ""    },
+{  "AxB",   "AB",    IsFirstReconcile::kBoth, "UA",    "AxB",      "A"        },
+{  "xAxB",  "AB",    IsFirstReconcile::kBoth, "X",     "xAxB",     ""         },
+// For idempotency checks.
+{  "A",     "A",     IsFirstReconcile::kBoth, "",      "A",        "A"        },
+{  "AB",    "AB",    IsFirstReconcile::kBoth, "",      "AB",       "AB"       },
+{  "AxB",   "A",     IsFirstReconcile::kBoth, "",      "AxB",      "A"        },
+{  "xAxB",  "",      IsFirstReconcile::kBoth, "",      "xAxB",     ""         },
 };
 // clang-format on
 
 TEST_P(AccountReconcilorTestActiveDirectory, TableRowTestMultilogin) {
-  // Setup cookies.
-  std::vector<Cookie> cookies = ParseCookieString(GetParam().cookies);
-  ConfigureCookieManagerService(cookies);
-
-  // Call list accounts now so that the next call completes synchronously.
-  identity_test_env()->identity_manager()->GetAccountsInCookieJar();
-  base::RunLoop().RunUntilIdle();
-
-  // Setup tokens.
-  std::vector<Token> tokens = ParseTokenString(GetParam().tokens);
-  SetupTokens(GetParam().tokens);
-
-  testing::InSequence mock_sequence;
-  DeleteReconcilor();
-  MockAccountReconcilor* reconcilor = CreateMockReconcilor(
-      std::make_unique<signin::ActiveDirectoryAccountReconcilorDelegate>());
-
-  // Setup expectations.
-  bool should_logout;
-  if (GetParam().gaia_api_calls[0] != '\0') {
-    if (GetParam().gaia_api_calls[0] == 'X') {
-      should_logout = true;
-      EXPECT_CALL(*reconcilor, PerformLogoutAllAccountsAction()).Times(1);
-      EXPECT_CALL(*reconcilor, PerformSetCookiesAction(_)).Times(0);
-      cookies.clear();
-    } else if (GetParam().gaia_api_calls[0] == 'U') {
-      should_logout = false;
-      std::vector<CoreAccountId> accounts_to_send;
-      for (int i = 0; GetParam().cookies_after_reconcile[i] != '\0'; ++i) {
-        char cookie = GetParam().cookies_after_reconcile[i];
-        std::string account_to_send = GaiaIdForAccountKey(cookie);
-        accounts_to_send.push_back(PickAccountIdForAccount(
-            account_to_send,
-            accounts_[GetParam().cookies_after_reconcile[i]].email));
-      }
-      const signin::MultiloginParameters params(
-          gaia::MultiloginMode::MULTILOGIN_UPDATE_COOKIE_ACCOUNTS_ORDER,
-          accounts_to_send);
-      EXPECT_CALL(*reconcilor, PerformSetCookiesAction(params)).Times(1);
-      EXPECT_CALL(*reconcilor, PerformLogoutAllAccountsAction()).Times(0);
-    }
-  }
-
-  // Reconcile.
-  ASSERT_TRUE(reconcilor);
-  ASSERT_TRUE(reconcilor->first_execution_);
-  reconcilor->first_execution_ =
-      GetParam().is_first_reconcile == IsFirstReconcile::kFirst ? true : false;
-  reconcilor->StartReconcile(AccountReconcilor::Trigger::kCookieChange);
-  if (GetParam().gaia_api_calls[0] != '\0') {
-    if (should_logout) {
-      SimulateLogOutFromCookieCompleted(
-          reconcilor, GoogleServiceAuthError::AuthErrorNone());
-    } else {
-      SimulateSetAccountsInCookieCompleted(
-          reconcilor, signin::SetAccountsInCookieResult::kSuccess);
-    }
-  }
-
-  ASSERT_FALSE(reconcilor->is_reconcile_started_);
-  ASSERT_EQ(signin_metrics::ACCOUNT_RECONCILOR_OK, reconcilor->GetState());
-  VerifyCurrentTokens(ParseTokenString(GetParam().tokens_after_reconcile));
-
-  testing::Mock::VerifyAndClearExpectations(reconcilor);
-
-  // Another reconcile is sometimes triggered if Chrome accounts have
-  // changed. Allow it to finish.
-  EXPECT_CALL(*reconcilor, PerformSetCookiesAction(testing::_))
-      .WillRepeatedly(testing::Return());
-  EXPECT_CALL(*reconcilor, PerformLogoutAllAccountsAction())
-      .WillRepeatedly(testing::Return());
-  ConfigureCookieManagerService({});
-  base::RunLoop().RunUntilIdle();
+  CheckReconcileIdempotent(kActiveDirectoryParams, GetParam());
+  RunRowTest(GetParam());
 }
 
 INSTANTIATE_TEST_SUITE_P(
diff --git a/components/strings/components_strings_fa.xtb b/components/strings/components_strings_fa.xtb
index c6194bd..199613a9 100644
--- a/components/strings/components_strings_fa.xtb
+++ b/components/strings/components_strings_fa.xtb
@@ -1482,7 +1482,7 @@
 <translation id="5029568752722684782">پاک کردن نسخه کپی</translation>
 <translation id="5030338702439866405">صدور توسط</translation>
 <translation id="503069730517007720">برای «<ph name="SOFTWARE_NAME" />» گواهینامه ریشه‌ لازم است اما نصب نشده است. برای رفع این مشکل، سرپرست فناوری اطلاعات شما باید دستورالعمل‌های پیکربندی مربوط به «<ph name="SOFTWARE_NAME" />» را بررسی کند. <ph name="FURTHER_EXPLANATION" /></translation>
-<translation id="5031870354684148875">‏درباره ‏‫ترجمه Google‬</translation>
+<translation id="5031870354684148875">‏درباره «ترجمه Google»‬</translation>
 <translation id="503498442187459473"><ph name="HOST" /> می‌خواهد از دوربین و میکروفن شما استفاده کند</translation>
 <translation id="5035135400558156732">باغبانی</translation>
 <translation id="5039762155821394373">اندازه قلم</translation>
diff --git a/components/strings/components_strings_km.xtb b/components/strings/components_strings_km.xtb
index fed2589..6db5586 100644
--- a/components/strings/components_strings_km.xtb
+++ b/components/strings/components_strings_km.xtb
@@ -834,6 +834,7 @@
 <translation id="3226387218769101247">រូបភាព​តូចៗ</translation>
 <translation id="3227137524299004712">ម៉ៃក្រូហ្វូន</translation>
 <translation id="3229041911291329567">ព័ត៌មានកំណែ​អំពីឧបករណ៍ និងកម្មវិធីរុករក​តាមអ៊ីនធឺណិតរបស់អ្នក</translation>
+<translation id="3229277193950731405">ចម្លង​ជួរអក្សរកំណែ</translation>
 <translation id="323107829343500871">បញ្ចូល CVC សម្រាប់ <ph name="CREDIT_CARD" /></translation>
 <translation id="3234666976984236645">តែងតែចាប់យកមាតិកាសំខាន់ជានិច្ចនៅលើគេហទំព័រនេះ</translation>
 <translation id="3240683217920639535"><ph name="MANAGE_CHROME_THEMES_FOCUSED_FRIENDLY_MATCH_TEXT" />, ចុច tab រួចចុច Enter ដើម្បីប្ដូរ​រូបរាងនៃ​កម្មវិធីរុករកតាមអ៊ីនធឺណិត​របស់អ្នក​តាមបំណង</translation>
diff --git a/components/strings/components_strings_uz.xtb b/components/strings/components_strings_uz.xtb
index 6b6e3ea..bb19f92 100644
--- a/components/strings/components_strings_uz.xtb
+++ b/components/strings/components_strings_uz.xtb
@@ -828,6 +828,7 @@
 <translation id="3226387218769101247">Eskizlar</translation>
 <translation id="3227137524299004712">Mikrofon</translation>
 <translation id="3229041911291329567">Qurilma va brauzer versiyalari axboroti</translation>
+<translation id="3229277193950731405">Versiya qatorini nusxalash</translation>
 <translation id="323107829343500871"><ph name="CREDIT_CARD" /> kartasining CVC kodini kiriting</translation>
 <translation id="3234666976984236645">Bu saytda har doim muhim kontent aniqlansin</translation>
 <translation id="3240683217920639535"><ph name="MANAGE_CHROME_THEMES_FOCUSED_FRIENDLY_MATCH_TEXT" />, Brauzeringiz koʻrinishini moslash uchun avval Tab, keyin Enter tugmasini bosing</translation>
diff --git a/components/sync/engine/nigori/nigori_unittest.cc b/components/sync/engine/nigori/nigori_unittest.cc
index 7222a68..ec9caa5 100644
--- a/components/sync/engine/nigori/nigori_unittest.cc
+++ b/components/sync/engine/nigori/nigori_unittest.cc
@@ -51,11 +51,11 @@
   ASSERT_THAT(nigori, NotNull());
 
   std::string permuted;
-  EXPECT_TRUE(nigori->Permute(Nigori::Password, "test name", &permuted));
+  EXPECT_TRUE(nigori->Permute(Nigori::Password, kNigoriKeyName, &permuted));
 
   std::string expected =
-      "evpwwPT726JS/mhxv1UwPVLDz5ha/GrMA8HfA3sQGJr5"
-      "5zFtrFep7DXu9FIyGbBEdlHNWtwVlPVE5FEgyoV++w==";
+      "ibGL7ymU0Si+eYCXGS6SBHPFT+JCYiB6GDOYqj6vIwEi"
+      "WJ7RENSHxmIQ8Q3rXd/UnZUmFHYB+jSIbthQADXvrQ==";
   EXPECT_EQ(expected, permuted);
 }
 
@@ -65,14 +65,14 @@
   ASSERT_THAT(nigori1, NotNull());
 
   std::string permuted1;
-  EXPECT_TRUE(nigori1->Permute(Nigori::Password, "name", &permuted1));
+  EXPECT_TRUE(nigori1->Permute(Nigori::Password, kNigoriKeyName, &permuted1));
 
   std::unique_ptr<Nigori> nigori2 = Nigori::CreateByDerivation(
       KeyDerivationParams::CreateForPbkdf2(), "password");
   ASSERT_THAT(nigori2, NotNull());
 
   std::string permuted2;
-  EXPECT_TRUE(nigori2->Permute(Nigori::Password, "name", &permuted2));
+  EXPECT_TRUE(nigori2->Permute(Nigori::Password, kNigoriKeyName, &permuted2));
 
   EXPECT_LT(0U, permuted1.size());
   EXPECT_EQ(permuted1, permuted2);
@@ -208,8 +208,8 @@
   EXPECT_EQ(original, plaintext);
 
   std::string permuted1, permuted2;
-  EXPECT_TRUE(nigori1->Permute(Nigori::Password, original, &permuted1));
-  EXPECT_TRUE(nigori2->Permute(Nigori::Password, original, &permuted2));
+  EXPECT_TRUE(nigori1->Permute(Nigori::Password, kNigoriKeyName, &permuted1));
+  EXPECT_TRUE(nigori2->Permute(Nigori::Password, kNigoriKeyName, &permuted2));
   EXPECT_EQ(permuted1, permuted2);
 }
 
diff --git a/components/test/data/screen_ai/sample_01_ax_tree.json b/components/test/data/screen_ai/sample_01_ax_tree.json
index 0c86506..7e10126 100644
--- a/components/test/data/screen_ai/sample_01_ax_tree.json
+++ b/components/test/data/screen_ai/sample_01_ax_tree.json
@@ -64,7 +64,14 @@
     },
     "name": "UK government sets out plans to rein in Big Tech - BBC News",
     "interesting": true,
-    "extras": {},
+    "extras": {
+      "bounds": [
+        0,
+        0,
+        1440,
+        10380
+      ]
+    },
     "backendDomId": 2,
     "children": [
       {
diff --git a/content/test/data/gpu/vc/README.md b/content/test/data/gpu/vc/README.md
index 6a0e594..f005a7d 100644
--- a/content/test/data/gpu/vc/README.md
+++ b/content/test/data/gpu/vc/README.md
@@ -67,6 +67,17 @@
 webgpu_videos_mxn.html?fps=none
 ```
 
+To use largest video only. Use `use_large_size_video=1`
+```
+webgpu_videos_mxn.html?use_large_size_video=1
+```
+
+To disable the 30fps cap in the sample. Use `cap_ui_fps=0`
+```
+
+webgpu_videos_mxn.html?cap_ui_fps=0
+```
+
 For webgpu_videos_mxn.html only:
 To disable Import Texture API and force the video texture copy through
 createImageBitmap() and then copyExternalImageToTexture(),
@@ -75,6 +86,13 @@
 webgpu_videos_mxn.html?import_texture_api=0
 ```
 
+To disable using onSubmittedWorkDone to workaround webgpu
+backpressure issue(may hurt performance). Use `back_pressure_workaround=0`
+```
+
+webgpu_videos_mxn.html?back_pressure_workaround=0
+```
+
 
 ## Video Files
 
diff --git a/content/test/data/gpu/vc/video_utils.js b/content/test/data/gpu/vc/video_utils.js
index d526ae1d..af5e9f7a 100644
--- a/content/test/data/gpu/vc/video_utils.js
+++ b/content/test/data/gpu/vc/video_utils.js
@@ -14,10 +14,10 @@
   return pairs;
 })(window.location.search.substr(1).split('&'));
 
-function GetVideoSource(videoCount, index, codec) {
+function GetVideoSource(videoCount, index, codec, useLargeSizeVideo = false) {
   switch (codec) {
     case 'vp8':
-      if (videoCount <= 4) {
+      if (videoCount <= 4 || useLargeSizeVideo) {
         return './teddy1_vp8_640x360_30fps.webm';
       } else {
         if (index < 4)
@@ -31,7 +31,7 @@
 
     case 'vp9':
     default:
-      if (videoCount <= 4) {
+      if (videoCount <= 4 || useLargeSizeVideo) {
         return './teddy1_vp9_640x360_30fps.webm';
       } else {
         if (index < 4)
@@ -185,7 +185,7 @@
   const bar_count = 10;
   for (let i = 0; i < bar_count; ++i) {
     const array_index = i * 12;
-    const hBar = (i+1) * delta;
+    const hBar = (i + 1) * delta;
     const yBar = y - hIcon * 2 + hBar;
 
     rectVerts.set([
diff --git a/content/test/data/gpu/vc/webgl_video.js b/content/test/data/gpu/vc/webgl_video.js
index 3a4c9327..e6d111d6 100644
--- a/content/test/data/gpu/vc/webgl_video.js
+++ b/content/test/data/gpu/vc/webgl_video.js
@@ -158,8 +158,7 @@
   gl.enableVertexAttribArray(pos);
 }
 
-function createVertexBufferForAnimation(
-            gl, videos, videoRows, videoColumns) {
+function createVertexBufferForAnimation(gl, videos, videoRows, videoColumns) {
   const rectVerts = getArrayForAnimationVertexBuffer(videos, videoRows,
     videoColumns);
   const verticesBuffer = gl.createBuffer();
@@ -248,8 +247,8 @@
   }
 }
 
-function webglDrawVideoFrames(gl, videos, videoRows, videoColumns,
-                               addUI, addFPS) {
+function webglDrawVideoFrames(
+    gl, videos, videoRows, videoColumns, addUI, addFPS, capUIFPS) {
   initializePrograms(gl);
   initializeVideoTextures(gl, videos.length);
   if (addFPS) {
@@ -283,12 +282,14 @@
 
   const oneFrame = () => {
     const timestamp = performance.now();
-    const elapsed = timestamp - lastTimestamp;
-    if (elapsed < kFrameTime30Fps) {
-      window.requestAnimationFrame(oneFrame);
-      return;
+    if (capUIFPS) {
+      const elapsed = timestamp - lastTimestamp;
+      if (elapsed < kFrameTime30Fps) {
+        window.requestAnimationFrame(oneFrame);
+        return;
+      }
+      lastTimestamp = timestamp;
     }
-    lastTimestamp = timestamp;
 
     uiFrames++;
 
diff --git a/content/test/data/gpu/vc/webgl_videos_mxn.html b/content/test/data/gpu/vc/webgl_videos_mxn.html
index 38c0b7d5..ca4c4d9 100644
--- a/content/test/data/gpu/vc/webgl_videos_mxn.html
+++ b/content/test/data/gpu/vc/webgl_videos_mxn.html
@@ -4,6 +4,7 @@
 found in the LICENSE file.
 -->
 <html>
+
 <head>
   <title>WebGL MxN Video playbacks</title>
   <style>
@@ -25,6 +26,8 @@
     const _totalVideoHeight = 900;
     var hasUIOnTop = true;
     var hasFPSOnTop = true;
+    var capUIFPS = true;
+    var useLargeSizeVideo = false;
     var codec = 'vp9';
 
     async function startMxNVideos() {
@@ -54,6 +57,18 @@
       else if (codecString != 'vp9' && codecString != undefined)
         console.warn('Unsupported video codec format! Switch to default VP9.');
 
+      const capFPSOption = parsedString['cap_ui_fps']
+      if (capFPSOption == '0')
+        capUIFPS = false;
+      else if (capFPSOption == '1')
+        capUIFPS = true;
+
+      const useLargeSizeVideoOption = parsedString['use_large_size_video']
+      if (useLargeSizeVideoOption == '0')
+        useLargeSizeVideo = false;
+      else if (useLargeSizeVideoOption == '1')
+        useLargeSizeVideo = true;
+
       // Get the number of video rows and columns from the string.
       var videoRows = parsedString['rows'];
       var videoColumns = parsedString['columns'];
@@ -87,7 +102,7 @@
         video.autoplay = true;
         video.muted = true;
         video.display = "none";
-        video.src = GetVideoSource(videoCount, i, codec);
+        video.src = GetVideoSource(videoCount, i, codec, useLargeSizeVideo);
         video.width = videoWidth;
         video.height = videoHeight;
         video.crossorigin = "anonymous";
@@ -104,14 +119,16 @@
 
       // Simulate video playback by WebGL rendering.
       webglDrawVideoFrames(gl, videos, videoRows, videoColumns,
-        hasUIOnTop , hasFPSOnTop);
+        hasUIOnTop, hasFPSOnTop, capUIFPS);
     }
 
   </script>
 </head>
+
 <body onload="startMxNVideos()">
   <div id="container" style="position:absolute; top:0px; left:0px">
     <p id="message"></p>
   </div>
 </body>
-</html>
+
+</html>
\ No newline at end of file
diff --git a/content/test/data/gpu/vc/webgpu_video.js b/content/test/data/gpu/vc/webgpu_video.js
index 0a7b35c9..dea2407 100644
--- a/content/test/data/gpu/vc/webgpu_video.js
+++ b/content/test/data/gpu/vc/webgpu_video.js
@@ -127,7 +127,7 @@
 }
 
 function createVertexBufferForAnimation(
-            device, videos, videoRows, videoColumns) {
+    device, videos, videoRows, videoColumns) {
   const rectVerts = getArrayForAnimationVertexBuffer(videos, videoRows,
     videoColumns);
   const verticesBuffer = device.createBuffer({
@@ -156,8 +156,9 @@
   return verticesBuffer;
 }
 
-function webGpuDrawVideoFrames(gpuSetting, videos, videoRows, videoColumns,
-                               addUI, addFPS, useImportTextureApi) {
+function webGpuDrawVideoFrames(
+    gpuSetting, videos, videoRows, videoColumns, addUI, addFPS,
+    useImportTextureApi, capUIFPS, enableBackPressureWorkaround) {
   initializeFPSPanels();
 
   const {adapter, device, context, canvas} = gpuSetting;
@@ -316,8 +317,7 @@
 
   // For rendering the voice bar animation
   const vertexBufferForAnimation =
-          createVertexBufferForAnimation(
-            device, videos, videoRows, videoColumns);
+      createVertexBufferForAnimation(device, videos, videoRows, videoColumns);
 
   renderPipelineDescriptorForIcon.fragment.module = device.createShaderModule({
     code: wgslShaders.fragment_output_white,
@@ -429,25 +429,25 @@
     passEncoder.draw(/*vertexCount=*/ 8, 1, /*firstVertex=*/ 60);
   }
 
- function addFPSCommands(device, passEncoder) {
+  function addFPSCommands(device, passEncoder) {
     // FPS Panels
-   passEncoder.setPipeline(pipelineForFPS);
-   passEncoder.setVertexBuffer(0, vertexBufferForFPS);
-   for (let i = 0; i < fpsPanels.length; ++i) {
-     device.queue.copyExternalImageToTexture(
-       { source: fpsPanels[i].dom, origin: { x: 0, y: 0 }},
-       { texture: fpsTextures[i] },
-       {
-         width: fpsPanels[i].dom.width,
-         height: fpsPanels[i].dom.height,
-         depthOrArrayLayers: 1
-       },
-     );
-     const firstVertex = i * 6;
-     passEncoder.setBindGroup(0, fpsBindGroups[i]);
-     passEncoder.draw(6, 1, firstVertex, 0);
-   }
- }
+    passEncoder.setPipeline(pipelineForFPS);
+    passEncoder.setVertexBuffer(0, vertexBufferForFPS);
+    for (let i = 0; i < fpsPanels.length; ++i) {
+      device.queue.copyExternalImageToTexture(
+          {source: fpsPanels[i].dom, origin: {x: 0, y: 0}},
+          {texture: fpsTextures[i]},
+          {
+            width: fpsPanels[i].dom.width,
+            height: fpsPanels[i].dom.height,
+            depthOrArrayLayers: 1
+          },
+      );
+      const firstVertex = i * 6;
+      passEncoder.setBindGroup(0, fpsBindGroups[i]);
+      passEncoder.draw(6, 1, firstVertex, 0);
+    }
+  }
 
   // videos #0-#3 : 30 fps.
   // videos #3-#15: 15 fps.
@@ -472,13 +472,15 @@
   let lastTimestamp = performance.now();
 
   const oneFrame = () => {
-    const timestamp = performance.now();
-    const elapsed = timestamp - lastTimestamp;
-    if (elapsed < kFrameTime30Fps) {
-      window.requestAnimationFrame(oneFrame);
-      return;
+    if (capUIFPS) {
+      const timestamp = performance.now();
+      const elapsed = timestamp - lastTimestamp;
+      if (elapsed < kFrameTime30Fps) {
+        window.requestAnimationFrame(oneFrame);
+        return;
+      }
+      lastTimestamp = timestamp;
     }
-    lastTimestamp = timestamp;
 
     uiFrames++;
 
@@ -532,21 +534,27 @@
 
         // TODO(crbug.com/1289482): Workaround for backpressure mechanism
         // not working properly.
-        device.queue.onSubmittedWorkDone().then(() => {
+        if (enableBackPressureWorkaround) {
+          device.queue.onSubmittedWorkDone().then(() => {
+            window.requestAnimationFrame(oneFrame);
+          });
+        } else {
           window.requestAnimationFrame(oneFrame);
-        });
+        }
       });
   };
 
   const oneFrameWithImportTextureApi = () => {
-    // Target frame rate: 30 fps. rAF might run at 60 fps.
+    // Target frame rate: 30 fps when capUIFPS is true. rAF might run at 60 fps.
     const timestamp = performance.now();
-    const elapsed = timestamp - lastTimestamp;
-    if (elapsed < kFrameTime30Fps) {
-      window.requestAnimationFrame(oneFrameWithImportTextureApi);
-      return;
+    if (capUIFPS) {
+      const elapsed = timestamp - lastTimestamp;
+      if (elapsed < kFrameTime30Fps) {
+        window.requestAnimationFrame(oneFrameWithImportTextureApi);
+        return;
+      }
+      lastTimestamp = timestamp;
     }
-    lastTimestamp = timestamp;
 
     uiFrames++;
 
@@ -609,9 +617,13 @@
 
     // TODO(crbug.com/1289482): Workaround for backpressure mechanism
     // not working properly.
-    device.queue.onSubmittedWorkDone().then(() => {
+    if (enableBackPressureWorkaround) {
+      device.queue.onSubmittedWorkDone().then(() => {
+        window.requestAnimationFrame(oneFrameWithImportTextureApi);
+      });
+    } else {
       window.requestAnimationFrame(oneFrameWithImportTextureApi);
-    });
+    }
   };
 
   if (useImportTextureApi) {
diff --git a/content/test/data/gpu/vc/webgpu_videos_mxn.html b/content/test/data/gpu/vc/webgpu_videos_mxn.html
index ba7b0a0..6d18cef 100644
--- a/content/test/data/gpu/vc/webgpu_videos_mxn.html
+++ b/content/test/data/gpu/vc/webgpu_videos_mxn.html
@@ -4,6 +4,7 @@
 found in the LICENSE file.
 -->
 <html>
+
 <head>
   <title>WebGpu MxN Video playbacks</title>
   <style>
@@ -26,6 +27,9 @@
     var hasUIOnTop = true;
     var hasFPSOnTop = true;
     var useImportTextureApi = true;
+    var capUIFPS = true;
+    var useLargeSizeVideo = false;
+    var enableBackPressureWorkaround = true;
     var codec = 'vp9';
 
     async function startMxNVideos() {
@@ -63,6 +67,24 @@
       else if (codecString != 'vp9' && codecString != undefined)
         console.warn('Unsupported video codec format! Switch to default VP9.');
 
+      const capFPSOption = parsedString['cap_ui_fps']
+      if (capFPSOption == '0')
+        capUIFPS = false;
+      else if (capFPSOption == '1')
+        capUIFPS = true;
+
+      const useLargeSizeVideoOption = parsedString['use_large_size_video']
+      if (useLargeSizeVideoOption == '0')
+        useLargeSizeVideo = false;
+      else if (useLargeSizeVideoOption == '1')
+        useLargeSizeVideo = true;
+
+      const backPressureWorkaroundOption = parsedString['back_pressure_workaround']
+      if (backPressureWorkaroundOption == '0')
+        enableBackPressureWorkaround = false;
+      else if (backPressureWorkaroundOption == '1')
+        enableBackPressureWorkaround = true;
+
       // Get the number of video rows and columns from the string.
       var videoRows = parsedString['rows'];
       var videoColumns = parsedString['columns'];
@@ -96,7 +118,7 @@
         video.autoplay = true;
         video.muted = true;
         video.display = "none";
-        video.src = GetVideoSource(videoCount, i, codec);
+        video.src = GetVideoSource(videoCount, i, codec, useLargeSizeVideo);
         video.width = videoWidth;
         video.height = videoHeight;
         video.crossorigin = "anonymous";
@@ -113,14 +135,16 @@
 
       // Simulate video playback by WebGpu rendering.
       webGpuDrawVideoFrames(gpuSetting, videos, videoRows, videoColumns,
-        hasUIOnTop , hasFPSOnTop, useImportTextureApi);
+        hasUIOnTop, hasFPSOnTop, useImportTextureApi, capUIFPS, enableBackPressureWorkaround);
     }
 
   </script>
 </head>
+
 <body onload="startMxNVideos()">
   <div id="container" style="position:absolute; top:0px; left:0px">
     <p id="message"></p>
   </div>
 </body>
-</html>
+
+</html>
\ No newline at end of file
diff --git a/docs/webui_in_chrome.md b/docs/webui_in_chrome.md
index b65e8868..5b838397 100644
--- a/docs/webui_in_chrome.md
+++ b/docs/webui_in_chrome.md
@@ -161,7 +161,8 @@
   ]
   input_files_base_dir = rebase_path(".", "//")
   deps = [ ":build_ts" ]
-  manifest_files = [ "$target_gen_dir/$tsconfig.manifest" ]
+  # build_ts below must match the target name for the TS build stage.
+  manifest_files = [ "$target_gen_dir/build_ts.manifest" ]
 }
 
 grit("resources") {
diff --git a/extensions/browser/api/file_system/file_system_api.cc b/extensions/browser/api/file_system/file_system_api.cc
index e27a7ae8..032672a 100644
--- a/extensions/browser/api/file_system/file_system_api.cc
+++ b/extensions/browser/api/file_system/file_system_api.cc
@@ -1079,9 +1079,7 @@
   DCHECK(delegate);
   // Only kiosk apps in kiosk sessions can use this API.
   // Additionally it is enabled for allowlisted component extensions and apps.
-  if (delegate->GetGrantVolumesMode(browser_context(), render_frame_host(),
-                                    *extension()) ==
-      FileSystemDelegate::kGrantNone) {
+  if (!delegate->IsGrantable(browser_context(), *extension())) {
     return RespondNow(Error(kNotSupportedOnNonKioskSessionError));
   }
 
@@ -1118,14 +1116,12 @@
   DCHECK(delegate);
   // Only kiosk apps in kiosk sessions can use this API.
   // Additionally it is enabled for allowlisted component extensions and apps.
-  if (delegate->GetGrantVolumesMode(browser_context(), render_frame_host(),
-                                    *extension()) ==
-      FileSystemDelegate::kGrantNone) {
+  if (!delegate->IsGrantable(browser_context(), *extension())) {
     return RespondNow(Error(kNotSupportedOnNonKioskSessionError));
   }
 
   delegate->GetVolumeList(
-      browser_context(), *extension(),
+      browser_context(),
       base::BindOnce(&FileSystemGetVolumeListFunction::OnGotVolumeList, this),
       base::BindOnce(&FileSystemGetVolumeListFunction::OnError, this));
 
diff --git a/extensions/browser/api/file_system/file_system_delegate.h b/extensions/browser/api/file_system/file_system_delegate.h
index 820bcdc..e56a18b 100644
--- a/extensions/browser/api/file_system/file_system_delegate.h
+++ b/extensions/browser/api/file_system/file_system_delegate.h
@@ -24,7 +24,6 @@
 
 namespace content {
 class BrowserContext;
-class RenderFrameHost;
 class WebContents;
 }  // namespace content
 
@@ -44,8 +43,6 @@
   using VolumeListCallback =
       base::OnceCallback<void(const std::vector<api::file_system::Volume>&)>;
 
-  enum GrantVolumesMode { kGrantAll, kGrantNone, kGrantPerVolume };
-
   virtual ~FileSystemDelegate() {}
 
   virtual base::FilePath GetDefaultDirectory() = 0;
@@ -82,10 +79,8 @@
 
 #if BUILDFLAG(IS_CHROMEOS_ASH)
   // Checks whether the extension can be granted access.
-  virtual GrantVolumesMode GetGrantVolumesMode(
-      content::BrowserContext* browser_context,
-      content::RenderFrameHost* render_frame_host,
-      const Extension& extension) = 0;
+  virtual bool IsGrantable(content::BrowserContext* browser_context,
+                           const Extension& extension) = 0;
 
   // Grants or denies an extension's request for access to the named file
   // system. May prompt the user for consent.
@@ -99,7 +94,6 @@
 
   // Immediately calls VolumeListCallback or ErrorCallback.
   virtual void GetVolumeList(content::BrowserContext* browser_context,
-                             const Extension& extension,
                              VolumeListCallback success_callback,
                              ErrorCallback error_callback) = 0;
 #endif
diff --git a/extensions/browser/api/networking_private/networking_private_chromeos.cc b/extensions/browser/api/networking_private/networking_private_chromeos.cc
index 3f1cba1..f16e78c2 100644
--- a/extensions/browser/api/networking_private/networking_private_chromeos.cc
+++ b/extensions/browser/api/networking_private/networking_private_chromeos.cc
@@ -14,14 +14,14 @@
 #include "base/values.h"
 #include "chromeos/ash/components/network/device_state.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_activation_handler.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/ash/components/network/onc/network_onc_utils.h"
 #include "chromeos/ash/components/network/onc/onc_translator.h"
 #include "chromeos/ash/components/network/portal_detector/network_portal_detector.h"
 #include "chromeos/components/onc/onc_signature.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_activation_handler.h"
-#include "chromeos/network/network_certificate_handler.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
diff --git a/extensions/browser/api/networking_private/networking_private_chromeos_unittest.cc b/extensions/browser/api/networking_private/networking_private_chromeos_unittest.cc
index 571309f6..bce26705 100644
--- a/extensions/browser/api/networking_private/networking_private_chromeos_unittest.cc
+++ b/extensions/browser/api/networking_private/networking_private_chromeos_unittest.cc
@@ -12,12 +12,12 @@
 #include "base/strings/string_number_conversions.h"
 #include "base/strings/stringprintf.h"
 #include "chromeos/ash/components/network/managed_network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
 #include "chromeos/ash/components/network/network_handler_test_helper.h"
 #include "chromeos/dbus/shill/shill_device_client.h"
 #include "chromeos/dbus/shill/shill_profile_client.h"
 #include "chromeos/dbus/shill/shill_service_client.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_configuration_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/extensions/browser/api/networking_private/networking_private_event_router_chromeos.cc b/extensions/browser/api/networking_private/networking_private_event_router_chromeos.cc
index a8f1e0f..1d84883b 100644
--- a/extensions/browser/api/networking_private/networking_private_event_router_chromeos.cc
+++ b/extensions/browser/api/networking_private/networking_private_event_router_chromeos.cc
@@ -6,9 +6,9 @@
 
 #include "base/json/json_writer.h"
 #include "chromeos/ash/components/network/device_state.h"
+#include "chromeos/ash/components/network/network_certificate_handler.h"
 #include "chromeos/ash/components/network/onc/onc_translator.h"
 #include "chromeos/components/onc/onc_signature.h"
-#include "chromeos/network/network_certificate_handler.h"
 #include "chromeos/network/network_event_log.h"
 #include "chromeos/network/network_state.h"
 #include "chromeos/network/network_state_handler.h"
diff --git a/extensions/common/mojom/api_permission_id.mojom b/extensions/common/mojom/api_permission_id.mojom
index 18878c6..3d389ad 100644
--- a/extensions/common/mojom/api_permission_id.mojom
+++ b/extensions/common/mojom/api_permission_id.mojom
@@ -236,7 +236,7 @@
   kEnterpriseReportingPrivate = 210,
   kCecPrivate = 211,
   kSafeBrowsingPrivate = 212,
-  kFileSystemRequestDownloads = 213,
+  kDeleted_FileSystemRequestDownloads = 213,
   kDeleted_SystemPowerSource = 214,
   kArcAppsPrivate = 215,
   kEnterpriseHardwarePlatform = 216,
diff --git a/extensions/common/permissions/extensions_api_permissions.cc b/extensions/common/permissions/extensions_api_permissions.cc
index 712fb2a8..fd4a35a 100644
--- a/extensions/common/permissions/extensions_api_permissions.cc
+++ b/extensions/common/permissions/extensions_api_permissions.cc
@@ -87,8 +87,6 @@
      "fileSystem.requestFileSystem"},
     {APIPermissionID::kFileSystemRetainEntries, "fileSystem.retainEntries",
      APIPermissionInfo::kFlagDoesNotRequireManagedSessionFullLoginWarning},
-    {APIPermissionID::kFileSystemRequestDownloads,
-     "fileSystem.requestDownloads"},
     {APIPermissionID::kFileSystemWrite, "fileSystem.write",
      APIPermissionInfo::kFlagDoesNotRequireManagedSessionFullLoginWarning},
     {APIPermissionID::kHid, "hid"},
diff --git a/extensions/shell/browser/shell_network_controller_chromeos.cc b/extensions/shell/browser/shell_network_controller_chromeos.cc
index 06335a0..97067e29 100644
--- a/extensions/shell/browser/shell_network_controller_chromeos.cc
+++ b/extensions/shell/browser/shell_network_controller_chromeos.cc
@@ -11,8 +11,8 @@
 #include "base/strings/stringprintf.h"
 #include "base/time/time.h"
 #include "base/values.h"
-#include "chromeos/network/network_configuration_handler.h"
-#include "chromeos/network/network_connection_handler.h"
+#include "chromeos/ash/components/network/network_configuration_handler.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/network/network_device_handler.h"
 #include "chromeos/network/network_handler.h"
 #include "chromeos/network/network_handler_callbacks.h"
diff --git a/google_apis/BUILD.gn b/google_apis/BUILD.gn
index 1f74cd0..e696c43 100644
--- a/google_apis/BUILD.gn
+++ b/google_apis/BUILD.gn
@@ -9,25 +9,20 @@
 import("//third_party/protobuf/proto_library.gni")
 
 declare_args() {
-  # You can set the variable 'use_official_google_api_keys' to true
+  # Set the variable 'use_official_google_api_keys' to true
   # to use the Google-internal file containing official API keys
-  # for Google Chrome even in a developer build.  Setting this
-  # variable explicitly to true will cause your build to fail if the
-  # internal file is missing.
+  # even in a developer build.  Setting this variable explicitly to
+  # true will cause the build to fail if the internal file is missing.
   #
-  # The variable is documented here, but not handled in this file;
-  # see //google_apis/determine_use_official_keys.gypi for the
-  # implementation.
-  #
-  # Set the variable to false to not use the internal file, even when
-  # it exists in your checkout.
+  # Set the variable to false to not use the internal file, even for
+  # Chrome-branded builds or when it exists in your checkout.
   #
   # Leave it unset or set to "" to have the variable
   # implicitly set to true if you have
   # src/google_apis/internal/google_chrome_api_keys.h in your
   # checkout, and implicitly set to false if not.
   #
-  # Note that official builds always behave as if the variable
+  # Note that Chrome-branded builds always behave as if the variable
   # was explicitly set to true, i.e. they always use official keys,
   # and will fail to build if the internal file is missing.
   use_official_google_api_keys = ""
@@ -41,8 +36,8 @@
   # require server-side APIs may fail to work if no keys are
   # provided.
   #
-  # Note that if you are building an official build or if
-  # use_official_google_api_keys has been set to trie (explicitly or
+  # Note that when building a Chrome-branded build or if
+  # `use_official_google_api_keys` has been set to `true` (explicitly or
   # implicitly), these values will be ignored and the official
   # keys will be used instead.
   google_api_key = ""
@@ -67,7 +62,7 @@
 config("key_defines") {
   defines = []
 
-  # TODO(crbug.com/1171510): Refactor so use_official_google_api_keys can be
+  # TODO(crbug.com/1294915): Refactor so use_official_google_api_keys can be
   # used for Fuchsia.
   if (!is_fuchsia && (is_chrome_branded || use_official_google_api_keys)) {
     defines += [ "USE_OFFICIAL_GOOGLE_API_KEYS=1" ]
diff --git a/ios/chrome/app/first_run_app_state_agent.mm b/ios/chrome/app/first_run_app_state_agent.mm
index 1613d0e2..c261fba 100644
--- a/ios/chrome/app/first_run_app_state_agent.mm
+++ b/ios/chrome/app/first_run_app_state_agent.mm
@@ -248,7 +248,7 @@
       [[WelcomeToChromeViewController alloc]
           initWithBrowser:self.presentingInterface.browser
               mainBrowser:self.mainBrowser
-                presenter:self.presentingInterface.bvc
+                presenter:self.presentingInterface.syncPresenter
                dispatcher:welcomeHandler];
   self.welcomeToChromeController = welcomeToChrome;
   UINavigationController* navController =
diff --git a/ios/chrome/browser/flags/about_flags.mm b/ios/chrome/browser/flags/about_flags.mm
index b604a37..1924498 100644
--- a/ios/chrome/browser/flags/about_flags.mm
+++ b/ios/chrome/browser/flags/about_flags.mm
@@ -375,6 +375,19 @@
      std::size(kBubbleRichIPHRichWithSnooze), nullptr},
 };
 
+const FeatureEntry::FeatureParam kOmniboxPasteButtonBlueIconCapsule[] = {
+    {kOmniboxPasteButtonParameterName,
+     kOmniboxPasteButtonParameterBlueIconCapsule}};
+const FeatureEntry::FeatureParam kOmniboxPasteButtonBlueFullCapsule[] = {
+    {kOmniboxPasteButtonParameterName,
+     kOmniboxPasteButtonParameterBlueFullCapsule}};
+const FeatureEntry::FeatureVariation kOmniboxPasteButtonVariations[] = {
+    {"Icon only", kOmniboxPasteButtonBlueIconCapsule,
+     std::size(kOmniboxPasteButtonBlueIconCapsule), nullptr},
+    {"Icon and text", kOmniboxPasteButtonBlueFullCapsule,
+     std::size(kOmniboxPasteButtonBlueFullCapsule), nullptr},
+};
+
 const FeatureEntry::FeatureParam kPopupMenuBookmarkStringAddABookmark[] = {
     {kPopupMenuBookmarkStringParamName,
      kPopupMenuBookmarkStringParamAddABookmark}};
@@ -988,6 +1001,11 @@
      flag_descriptions::kAutofillEnableNewCardUnmaskPromptViewDescription,
      flags_ui::kOsIos,
      FEATURE_VALUE_TYPE(kAutofillEnableNewCardUnmaskPromptView)},
+    {"omnibox-paste-button", flag_descriptions::kOmniboxPasteButtonName,
+     flag_descriptions::kOmniboxPasteButtonDescription, flags_ui::kOsIos,
+     FEATURE_WITH_PARAMS_VALUE_TYPE(kOmniboxPasteButton,
+                                    kOmniboxPasteButtonVariations,
+                                    "OmniboxPasteButton")},
 };
 
 bool SkipConditionalFeatureEntry(const flags_ui::FeatureEntry& entry) {
diff --git a/ios/chrome/browser/flags/ios_chrome_flag_descriptions.cc b/ios/chrome/browser/flags/ios_chrome_flag_descriptions.cc
index 799de49..9cf514a 100644
--- a/ios/chrome/browser/flags/ios_chrome_flag_descriptions.cc
+++ b/ios/chrome/browser/flags/ios_chrome_flag_descriptions.cc
@@ -499,6 +499,11 @@
 const char kOmniboxNewImplementationDescription[] =
     "Uses a textfield implementation that doesn't use UILabels internally";
 
+const char kOmniboxPasteButtonName[] = "Omnibox paste to search button";
+const char kOmniboxPasteButtonDescription[] =
+    "Add a paste button when showing clipboard suggestions in the omnibox. iOS "
+    "16 and above.";
+
 const char kIOSOmniboxUpdatedPopupUIName[] = "Popup refresh";
 const char kIOSOmniboxUpdatedPopupUIDescription[] =
     "Enable the new SwiftUI Popup implementation";
diff --git a/ios/chrome/browser/flags/ios_chrome_flag_descriptions.h b/ios/chrome/browser/flags/ios_chrome_flag_descriptions.h
index befe2d07..4216128b 100644
--- a/ios/chrome/browser/flags/ios_chrome_flag_descriptions.h
+++ b/ios/chrome/browser/flags/ios_chrome_flag_descriptions.h
@@ -455,6 +455,11 @@
 extern const char kOmniboxNewImplementationName[];
 extern const char kOmniboxNewImplementationDescription[];
 
+// Title and description for the flag to enable paste button on clipboard
+// suggestion.
+extern const char kOmniboxPasteButtonName[];
+extern const char kOmniboxPasteButtonDescription[];
+
 // Title and description for the flag to enable the SwiftUI omnibox popup
 // implementation.
 extern const char kIOSOmniboxUpdatedPopupUIName[];
diff --git a/ios/chrome/browser/ui/authentication/signin/add_account_signin/BUILD.gn b/ios/chrome/browser/ui/authentication/signin/add_account_signin/BUILD.gn
index db2bdab..b4cd3b9 100644
--- a/ios/chrome/browser/ui/authentication/signin/add_account_signin/BUILD.gn
+++ b/ios/chrome/browser/ui/authentication/signin/add_account_signin/BUILD.gn
@@ -24,7 +24,6 @@
     "//ios/chrome/browser/ui/alert_coordinator",
     "//ios/chrome/browser/ui/authentication",
     "//ios/chrome/browser/ui/authentication/signin:signin_protected",
-    "//ios/chrome/browser/ui/elements:elements_internal",
     "//ios/public/provider/chrome/browser",
     "//ios/public/provider/chrome/browser/signin",
     "//ui/base",
diff --git a/ios/chrome/browser/ui/authentication/signin/add_account_signin/add_account_signin_coordinator.mm b/ios/chrome/browser/ui/authentication/signin/add_account_signin/add_account_signin_coordinator.mm
index c8cf8a2..b526960 100644
--- a/ios/chrome/browser/ui/authentication/signin/add_account_signin/add_account_signin_coordinator.mm
+++ b/ios/chrome/browser/ui/authentication/signin/add_account_signin/add_account_signin_coordinator.mm
@@ -17,7 +17,6 @@
 #import "ios/chrome/browser/ui/authentication/authentication_ui_util.h"
 #import "ios/chrome/browser/ui/authentication/signin/add_account_signin/add_account_signin_manager.h"
 #import "ios/chrome/browser/ui/authentication/signin/signin_coordinator+protected.h"
-#import "ios/chrome/browser/ui/elements/activity_overlay_coordinator.h"
 #import "ios/chrome/grit/ios_strings.h"
 #import "ios/public/provider/chrome/browser/chrome_browser_provider.h"
 #import "ios/public/provider/chrome/browser/signin/chrome_identity_interaction_manager.h"
@@ -50,11 +49,6 @@
 @property(nonatomic, assign, readonly) AddAccountSigninIntent signinIntent;
 // Account manager service to retrieve Chrome identities.
 @property(nonatomic, assign) ChromeAccountManagerService* accountManagerService;
-// Activity overlay coordinator needed while waiting for the add account sign-in
-// manager to be presented. This is needed if the network is slow or not
-// responding.
-@property(nonatomic, strong)
-    ActivityOverlayCoordinator* activityOverlayCoordinator;
 
 @end
 
@@ -110,10 +104,6 @@
 
 - (void)start {
   [super start];
-  self.activityOverlayCoordinator = [[ActivityOverlayCoordinator alloc]
-      initWithBaseViewController:self.baseViewController
-                         browser:self.browser];
-  [self.activityOverlayCoordinator start];
   self.accountManagerService =
       ChromeAccountManagerServiceFactory::GetForBrowserState(
           self.browser->GetBrowserState());
@@ -137,9 +127,6 @@
 
 - (void)stop {
   [super stop];
-  DCHECK(self.activityOverlayCoordinator);
-  [self.activityOverlayCoordinator stop];
-  self.activityOverlayCoordinator = nil;
   // If one of those 3 DCHECK() fails, -[AddAccountSigninCoordinator
   // runCompletionCallbackWithSigninResult] has not been called.
   DCHECK(!self.addAccountSigninManager);
diff --git a/ios/chrome/browser/ui/browser_view/browser_coordinator.h b/ios/chrome/browser/ui/browser_view/browser_coordinator.h
index 826d02f..93a3a6e 100644
--- a/ios/chrome/browser/ui/browser_view/browser_coordinator.h
+++ b/ios/chrome/browser/ui/browser_view/browser_coordinator.h
@@ -7,11 +7,12 @@
 
 #include "base/ios/block_types.h"
 #import "ios/chrome/browser/ui/coordinators/chrome_coordinator.h"
+#import "ios/chrome/browser/ui/settings/sync/utils/sync_presenter.h"
 
 @class BrowserViewController;
 
 // Coordinator for BrowserViewController.
-@interface BrowserCoordinator : ChromeCoordinator
+@interface BrowserCoordinator : ChromeCoordinator <SyncPresenter>
 
 // The main view controller.
 @property(nonatomic, strong, readonly) BrowserViewController* viewController;
diff --git a/ios/chrome/browser/ui/browser_view/browser_coordinator.mm b/ios/chrome/browser/ui/browser_view/browser_coordinator.mm
index 5dc5da53..dbc0411 100644
--- a/ios/chrome/browser/ui/browser_view/browser_coordinator.mm
+++ b/ios/chrome/browser/ui/browser_view/browser_coordinator.mm
@@ -27,6 +27,7 @@
 #import "ios/chrome/browser/follow/follow_tab_helper.h"
 #import "ios/chrome/browser/main/browser.h"
 #import "ios/chrome/browser/ntp/features.h"
+#import "ios/chrome/browser/ntp/new_tab_page_tab_helper.h"
 #import "ios/chrome/browser/prerender/preload_controller_delegate.h"
 #import "ios/chrome/browser/prerender/prerender_service.h"
 #import "ios/chrome/browser/prerender/prerender_service_factory.h"
@@ -68,6 +69,7 @@
 #import "ios/chrome/browser/ui/commands/policy_change_commands.h"
 #import "ios/chrome/browser/ui/commands/qr_generation_commands.h"
 #import "ios/chrome/browser/ui/commands/share_highlight_command.h"
+#import "ios/chrome/browser/ui/commands/show_signin_command.h"
 #import "ios/chrome/browser/ui/commands/snackbar_commands.h"
 #import "ios/chrome/browser/ui/commands/text_zoom_commands.h"
 #import "ios/chrome/browser/ui/commands/whats_new_commands.h"
@@ -168,6 +170,7 @@
                                   PolicyChangeCommands,
                                   PreloadControllerDelegate,
                                   RepostFormTabHelperDelegate,
+                                  SigninPresenter,
                                   ToolbarAccessoryCoordinatorDelegate,
                                   URLLoadingDelegate,
                                   WebStateListObserving>
@@ -1509,8 +1512,7 @@
   // The view controller should have been created.
   DCHECK(self.viewController);
 
-  SyncErrorBrowserAgent::FromBrowser(self.browser)
-      ->SetUIProviders(self.viewController, self.viewController);
+  SyncErrorBrowserAgent::FromBrowser(self.browser)->SetUIProviders(self, self);
 
   WebStateDelegateBrowserAgent::FromBrowser(self.browser)
       ->SetUIProviders(self.contextMenuProvider,
@@ -1585,6 +1587,11 @@
     CaptivePortalTabHelper::FromWebState(webState)->SetTabInsertionBrowserAgent(
         insertionAgent);
   }
+
+  if (NewTabPageTabHelper::FromWebState(webState)) {
+    NewTabPageTabHelper::FromWebState(webState)->SetDelegate(
+        self.viewController);
+  }
 }
 
 // Uninstalls delegates for `webState`.
@@ -1613,6 +1620,10 @@
     CaptivePortalTabHelper::FromWebState(webState)->SetTabInsertionBrowserAgent(
         nil);
   }
+
+  if (NewTabPageTabHelper::FromWebState(webState)) {
+    NewTabPageTabHelper::FromWebState(webState)->SetDelegate(nil);
+  }
 }
 
 #pragma mark - PasswordBreachCommands
@@ -1775,4 +1786,55 @@
   return self.browserContainerCoordinator.viewController.view;
 }
 
+#pragma mark - SyncPresenter (Public)
+
+- (void)showReauthenticateSignin {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+              showSignin:
+                  [[ShowSigninCommand alloc]
+                      initWithOperation:AuthenticationOperationReauthenticate
+                            accessPoint:signin_metrics::AccessPoint::
+                                            ACCESS_POINT_UNKNOWN]
+      baseViewController:self.viewController];
+}
+
+- (void)showSyncPassphraseSettings {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+      showSyncPassphraseSettingsFromViewController:self.viewController];
+}
+
+- (void)showGoogleServicesSettings {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+      showGoogleServicesSettingsFromViewController:self.viewController];
+}
+
+- (void)showAccountSettings {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+      showAccountsSettingsFromViewController:self.viewController];
+}
+
+- (void)showTrustedVaultReauthForFetchKeysWithTrigger:
+    (syncer::TrustedVaultUserActionTriggerForUMA)trigger {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+      showTrustedVaultReauthForFetchKeysFromViewController:self.viewController
+                                                   trigger:trigger];
+}
+
+- (void)showTrustedVaultReauthForDegradedRecoverabilityWithTrigger:
+    (syncer::TrustedVaultUserActionTriggerForUMA)trigger {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+      showTrustedVaultReauthForDegradedRecoverabilityFromViewController:
+          self.viewController
+                                                                trigger:
+                                                                    trigger];
+}
+
+#pragma mark - SigninPresenter
+
+- (void)showSignin:(ShowSigninCommand*)command {
+  [HandlerForProtocol(self.dispatcher, ApplicationCommands)
+              showSignin:command
+      baseViewController:self.viewController];
+}
+
 @end
diff --git a/ios/chrome/browser/ui/browser_view/browser_view_controller.h b/ios/chrome/browser/ui/browser_view/browser_view_controller.h
index 7413c49..26a2bb07 100644
--- a/ios/chrome/browser/ui/browser_view/browser_view_controller.h
+++ b/ios/chrome/browser/ui/browser_view/browser_view_controller.h
@@ -17,7 +17,6 @@
 #import "ios/chrome/browser/ui/ntp/logo_animation_controller.h"
 #import "ios/chrome/browser/ui/omnibox/popup/omnibox_popup_presenter.h"
 #import "ios/chrome/browser/ui/page_info/requirements/page_info_presentation.h"
-#import "ios/chrome/browser/ui/print/print_controller.h"
 #import "ios/chrome/browser/ui/settings/sync/utils/sync_presenter.h"
 #import "ios/chrome/browser/ui/thumb_strip/thumb_strip_supporting.h"
 #import "ios/chrome/browser/ui/toolbar/toolbar_coordinator_delegate.h"
@@ -84,9 +83,6 @@
                         LogoAnimationControllerOwnerOwner,
                         OmniboxPopupPresenterDelegate,
                         PageInfoPresentation,
-                        PrintControllerDelegate,
-                        SigninPresenter,
-                        SyncPresenter,
                         ThumbStripSupporting,
                         ToolbarCoordinatorDelegate,
                         WebNavigationNTPDelegate,
diff --git a/ios/chrome/browser/ui/browser_view/browser_view_controller.mm b/ios/chrome/browser/ui/browser_view/browser_view_controller.mm
index c47bf6c..01ab0eb 100644
--- a/ios/chrome/browser/ui/browser_view/browser_view_controller.mm
+++ b/ios/chrome/browser/ui/browser_view/browser_view_controller.mm
@@ -61,7 +61,6 @@
 #import "ios/chrome/browser/ui/commands/help_commands.h"
 #import "ios/chrome/browser/ui/commands/load_query_commands.h"
 #import "ios/chrome/browser/ui/commands/reading_list_add_command.h"
-#import "ios/chrome/browser/ui/commands/show_signin_command.h"
 #import "ios/chrome/browser/ui/commands/snackbar_commands.h"
 #import "ios/chrome/browser/ui/commands/text_zoom_commands.h"
 #import "ios/chrome/browser/ui/content_suggestions/content_suggestions_feature.h"
@@ -90,7 +89,6 @@
 #import "ios/chrome/browser/ui/ntp/new_tab_page_coordinator.h"
 #import "ios/chrome/browser/ui/ntp/ntp_util.h"
 #import "ios/chrome/browser/ui/popup_menu/popup_menu_coordinator.h"
-#import "ios/chrome/browser/ui/settings/sync/utils/sync_util.h"
 #import "ios/chrome/browser/ui/side_swipe/side_swipe_controller.h"
 #import "ios/chrome/browser/ui/side_swipe/swipe_view.h"
 #import "ios/chrome/browser/ui/start_surface/start_surface_features.h"
@@ -1040,12 +1038,6 @@
       notifier->RemoveObserver(_URLLoadingObserverBridge.get());
   }
 
-  // Uninstall delegates so that any delegate callbacks triggered by subsequent
-  // WebStateDestroyed() signals are not handled.
-  WebStateList* webStateList = self.browser->GetWebStateList();
-  for (int index = 0; index < webStateList->count(); ++index)
-    [self uninstallDelegatesForWebState:webStateList->GetWebStateAt(index)];
-
   // Disconnect child coordinators.
   if (base::FeatureList::IsEnabled(kModernTabStrip)) {
     [self.tabStripCoordinator stop];
@@ -1611,10 +1603,6 @@
   UrlLoadingNotifierBrowserAgent::FromBrowser(self.browser)
       ->AddObserver(_URLLoadingObserverBridge.get());
 
-  WebStateList* webStateList = self.browser->GetWebStateList();
-  for (int index = 0; index < webStateList->count(); ++index)
-    [self installDelegatesForWebState:webStateList->GetWebStateAt(index)];
-
   // Set the TTS playback controller's WebStateList.
   // TODO(crbug.com/1272528): Move this somewhere else -- BrowserCoordinator at
   // least.
@@ -2338,40 +2326,6 @@
 
 #pragma mark - Private Methods: Tab creation and selection
 
-// DEPRECATED -- Do not add further logic to this method.
-// Add all delegates to the provided `webState`.
-// Unregistration happens when the WebState is removed from the WebStateList.
-// TODO(crbug.com/1290819): Remove this method.
-- (void)installDelegatesForWebState:(web::WebState*)webState {
-  // If the WebState is unrealized, don't install the delegate. Instead they
-  // will be installed when -webStateRealized: method is called.
-  if (!webState->IsRealized())
-    return;
-
-  // TODO(crbug.com/1328039): Remove all use of the prerender service from BVC
-  // There should be no pre-rendered Tabs for this BrowserState.
-  DCHECK(!_prerenderService ||
-         !_prerenderService->IsWebStatePrerendered(webState));
-
-  NewTabPageTabHelper::FromWebState(webState)->SetDelegate(self);
-}
-
-// DEPRECATED -- Do not add further logic to this method.
-// Remove delegates from the provided `webState`.
-// TODO(crbug.com/1290819): Remove this method.
-- (void)uninstallDelegatesForWebState:(web::WebState*)webState {
-  // If the WebState is unrealized, then the delegate had not been installed
-  // and thus don't need to be uninstalled.
-  if (!webState->IsRealized())
-    return;
-
-  // TODO(crbug.com/1300911): Have BrowserCoordinator manage the NTP.
-  // No need to stop _ntpCoordinator with Single NTP enabled since shutdown will
-  // do that. In addition, uninstallDelegatesForWebState: is called for
-  // individual WebState removals, which should not trigger a stop.
-  NewTabPageTabHelper::FromWebState(webState)->SetDelegate(nil);
-}
-
 // Called when a `webState` is selected in the WebStateList. Make any required
 // view changes. The notification will not be sent when the `webState` is
 // already the selected WebState. `notifyToolbar` indicates whether the toolbar
@@ -3107,14 +3061,6 @@
   }
 }
 
-// TODO(crbug.com/1290819): When -installDelegatesForWebState is removed, this
-// method can be removed as well.
-- (void)webStateRealized:(web::WebState*)webState {
-  // The delegate were not installed because the WebState was not realized.
-  // Do it now so that the WebState behaves correctly.
-  [self installDelegatesForWebState:webState];
-}
-
 #pragma mark - OmniboxPopupPresenterDelegate methods.
 
 - (UIView*)popupParentViewForPresenter:(OmniboxPopupPresenter*)presenter {
@@ -3758,7 +3704,6 @@
   }
 
   [self stopNTPIfNeeded];
-  [self uninstallDelegatesForWebState:webState];
 }
 
 - (void)webStateList:(WebStateList*)webStateList
@@ -3774,9 +3719,6 @@
     didReplaceWebState:(web::WebState*)oldWebState
           withWebState:(web::WebState*)newWebState
                atIndex:(int)atIndex {
-  [self uninstallDelegatesForWebState:oldWebState];
-  [self installDelegatesForWebState:newWebState];
-
   // Add `newTab`'s view to the hierarchy if it's the current Tab.
   if (self.active && self.currentWebState == newWebState)
     [self displayWebState:newWebState];
@@ -3788,7 +3730,6 @@
               atIndex:(int)index
            activating:(BOOL)activating {
   DCHECK(webState);
-  [self installDelegatesForWebState:webState];
 
   DCHECK_EQ(self.browser->GetWebStateList(), webStateList);
 
@@ -4187,51 +4128,6 @@
   return _toolbarAccessoryPresenter;
 }
 
-#pragma mark - SigninPresenter
-
-- (void)showSignin:(ShowSigninCommand*)command {
-  [self.dispatcher showSignin:command baseViewController:self];
-}
-
-#pragma mark - SyncPresenter (Public)
-
-- (void)showReauthenticateSignin {
-  [self.dispatcher
-              showSignin:
-                  [[ShowSigninCommand alloc]
-                      initWithOperation:AuthenticationOperationReauthenticate
-                            accessPoint:signin_metrics::AccessPoint::
-                                            ACCESS_POINT_UNKNOWN]
-      baseViewController:self];
-}
-
-- (void)showSyncPassphraseSettings {
-  [self.dispatcher showSyncPassphraseSettingsFromViewController:self];
-}
-
-- (void)showGoogleServicesSettings {
-  [self.dispatcher showGoogleServicesSettingsFromViewController:self];
-}
-
-- (void)showAccountSettings {
-  [self.dispatcher showAccountsSettingsFromViewController:self];
-}
-
-- (void)showTrustedVaultReauthForFetchKeysWithTrigger:
-    (syncer::TrustedVaultUserActionTriggerForUMA)trigger {
-  [self.dispatcher
-      showTrustedVaultReauthForFetchKeysFromViewController:self
-                                                   trigger:trigger];
-}
-
-- (void)showTrustedVaultReauthForDegradedRecoverabilityWithTrigger:
-    (syncer::TrustedVaultUserActionTriggerForUMA)trigger {
-  [self.dispatcher
-      showTrustedVaultReauthForDegradedRecoverabilityFromViewController:self
-                                                                trigger:
-                                                                    trigger];
-}
-
 #pragma mark - NewTabPageTabHelperDelegate
 
 - (void)newTabPageHelperDidChangeVisibility:(NewTabPageTabHelper*)NTPHelper
@@ -4257,15 +4153,6 @@
   }
 }
 
-#pragma mark - PrintControllerDelegate
-
-- (UIViewController*)baseViewControllerForPrintPreview {
-  if (self.presentedViewController) {
-    return self.presentedViewController;
-  }
-  return self;
-}
-
 #pragma mark - Getters
 
 - (NewTabPageCoordinator*)ntpCoordinator {
diff --git a/ios/chrome/browser/ui/main/BUILD.gn b/ios/chrome/browser/ui/main/BUILD.gn
index 1446f762..fe53bd3 100644
--- a/ios/chrome/browser/ui/main/BUILD.gn
+++ b/ios/chrome/browser/ui/main/BUILD.gn
@@ -286,6 +286,7 @@
     "//ios/chrome/browser/ui/reading_list",
     "//ios/chrome/browser/ui/recent_tabs",
     "//ios/chrome/browser/ui/settings/sync",
+    "//ios/chrome/browser/ui/settings/sync/utils",
     "//ios/chrome/browser/ui/snackbar",
     "//ios/chrome/browser/ui/tabs:constants",
     "//ios/chrome/browser/ui/thumb_strip",
diff --git a/ios/chrome/browser/ui/main/browser_interface_provider.h b/ios/chrome/browser/ui/main/browser_interface_provider.h
index 24a0439..cfdd1cb 100644
--- a/ios/chrome/browser/ui/main/browser_interface_provider.h
+++ b/ios/chrome/browser/ui/main/browser_interface_provider.h
@@ -13,6 +13,7 @@
 @class BrowserCoordinator;
 @class BrowserViewController;
 class ChromeBrowserState;
+@protocol SyncPresenter;
 
 // A BrowserInterface is an abstraction that exposes an interface to the Chrome
 // user interface (and related model objects) to the application layer. Each
@@ -32,6 +33,7 @@
 // The BrowserViewController showing the current tab. The API surface this
 // property exposes will be refactored so that the BVC class isn't exposed.
 @property(nonatomic, readonly) BrowserViewController* bvc;
+@property(nonatomic, readonly) id<SyncPresenter> syncPresenter;
 // The active browser. This can never be nullptr.
 @property(nonatomic, readonly) Browser* browser;
 // The browser state for this interface. This can never be nullptr.
diff --git a/ios/chrome/browser/ui/main/browser_view_wrangler.mm b/ios/chrome/browser/ui/main/browser_view_wrangler.mm
index c935040..f54035ca4 100644
--- a/ios/chrome/browser/ui/main/browser_view_wrangler.mm
+++ b/ios/chrome/browser/ui/main/browser_view_wrangler.mm
@@ -27,6 +27,7 @@
 #import "ios/chrome/browser/ui/incognito_reauth/incognito_reauth_scene_agent.h"
 #import "ios/chrome/browser/ui/main/scene_state.h"
 #import "ios/chrome/browser/ui/main/scene_state_browser_agent.h"
+#import "ios/chrome/browser/ui/settings/sync/utils/sync_presenter.h"
 #import "ios/chrome/browser/web_state_list/web_state_list.h"
 
 #if !defined(__has_feature) || !__has_feature(objc_arc)
@@ -61,6 +62,10 @@
   return self.coordinator.viewController;
 }
 
+- (id<SyncPresenter>)syncPresenter {
+  return self.coordinator;
+}
+
 - (Browser*)browser {
   return self.coordinator.browser;
 }
diff --git a/ios/chrome/browser/ui/main/test/stub_browser_interface.h b/ios/chrome/browser/ui/main/test/stub_browser_interface.h
index 22645e3..1901379 100644
--- a/ios/chrome/browser/ui/main/test/stub_browser_interface.h
+++ b/ios/chrome/browser/ui/main/test/stub_browser_interface.h
@@ -12,12 +12,14 @@
 class Browser;
 @class BrowserViewController;
 class ChromeBrowserState;
+@protocol SyncPresenter;
 
 // Test double for BrowserInterface implementors. All properties are writable,
 // and have nil, nullptr, or NO as default values.
 @interface StubBrowserInterface : NSObject <BrowserInterface>
 @property(nonatomic, readwrite) UIViewController* viewController;
 @property(nonatomic, readwrite) BrowserViewController* bvc;
+@property(nonatomic, readwrite) id<SyncPresenter> syncPresenter;
 @property(nonatomic, readwrite) Browser* browser;
 @property(nonatomic, readwrite) ChromeBrowserState* browserState;
 @property(nonatomic, readwrite) BOOL incognito;
diff --git a/ios/chrome/browser/ui/omnibox/omnibox_ui_features.cc b/ios/chrome/browser/ui/omnibox/omnibox_ui_features.cc
index a469ab5..93bd7ed 100644
--- a/ios/chrome/browser/ui/omnibox/omnibox_ui_features.cc
+++ b/ios/chrome/browser/ui/omnibox/omnibox_ui_features.cc
@@ -6,3 +6,10 @@
 
 const base::Feature kEnableSuggestionsScrollingOnIPad{
     "EnableSuggestionsScrollingOnIPad", base::FEATURE_DISABLED_BY_DEFAULT};
+
+const base::Feature kOmniboxPasteButton{"OmniboxPasteButton",
+                                        base::FEATURE_DISABLED_BY_DEFAULT};
+
+const char kOmniboxPasteButtonParameterName[] = "PasteButtonVariant";
+const char kOmniboxPasteButtonParameterBlueIconCapsule[] = "SuggestionIcon";
+const char kOmniboxPasteButtonParameterBlueFullCapsule[] = "SuggestionTextIcon";
diff --git a/ios/chrome/browser/ui/omnibox/omnibox_ui_features.h b/ios/chrome/browser/ui/omnibox/omnibox_ui_features.h
index 143cdc7e..a1c835b 100644
--- a/ios/chrome/browser/ui/omnibox/omnibox_ui_features.h
+++ b/ios/chrome/browser/ui/omnibox/omnibox_ui_features.h
@@ -11,4 +11,14 @@
 // disable suggestions hiding on keyboard dismissal.
 extern const base::Feature kEnableSuggestionsScrollingOnIPad;
 
+// Feature flag to enable omnibox suggestions with iOS 16 `PasteButton`.
+extern const base::Feature kOmniboxPasteButton;
+
+// Feature parameter for kOmniboxPasteButton.
+extern const char kOmniboxPasteButtonParameterName[];
+// PasteButton on suggestion row, blue color with icon only and capsule shape.
+extern const char kOmniboxPasteButtonParameterBlueIconCapsule[];
+// PasteButton on suggestion row, blue color with icon/text and capsule shape.
+extern const char kOmniboxPasteButtonParameterBlueFullCapsule[];
+
 #endif  // IOS_CHROME_BROWSER_UI_OMNIBOX_OMNIBOX_UI_FEATURES_H_
diff --git a/ios/chrome/browser/ui/print/print_controller.h b/ios/chrome/browser/ui/print/print_controller.h
index 138b4bb..1703d43 100644
--- a/ios/chrome/browser/ui/print/print_controller.h
+++ b/ios/chrome/browser/ui/print/print_controller.h
@@ -9,13 +9,6 @@
 
 #import "ios/chrome/browser/web/print/web_state_printer.h"
 
-// The delegate for PrintController. Provide information needed to display the
-// UIPrintInteractionController.
-@protocol PrintControllerDelegate
-// The view controller the system print dialog should be presented from.
-- (UIViewController*)baseViewControllerForPrintPreview;
-@end
-
 // Interface for printing.
 @interface PrintController : NSObject <WebStatePrinter>
 
diff --git a/mojo/public/cpp/bindings/lib/interface_endpoint_client.cc b/mojo/public/cpp/bindings/lib/interface_endpoint_client.cc
index 72cf4ca..ded0d20 100644
--- a/mojo/public/cpp/bindings/lib/interface_endpoint_client.cc
+++ b/mojo/public/cpp/bindings/lib/interface_endpoint_client.cc
@@ -849,15 +849,16 @@
                 auto* info = ctx.event()->set_chrome_mojo_event_info();
                 info->set_mojo_interface_tag(interface_name_);
                 const auto method_info = method_info_callback_(*message);
-                info->set_ipc_hash(method_info.first);
-
-                const auto method_address =
-                    reinterpret_cast<uintptr_t>(method_info.second);
-                const absl::optional<size_t> location_iid =
-                    base::trace_event::InternedUnsymbolizedSourceLocation::Get(
-                        &ctx, method_address);
-                if (location_iid) {
-                  info->set_mojo_interface_method_iid(*location_iid);
+                if (method_info) {
+                  info->set_ipc_hash((*method_info)());
+                  const auto method_address =
+                      reinterpret_cast<uintptr_t>(method_info);
+                  const absl::optional<size_t> location_iid =
+                      base::trace_event::InternedUnsymbolizedSourceLocation::
+                          Get(&ctx, method_address);
+                  if (location_iid) {
+                    info->set_mojo_interface_method_iid(*location_iid);
+                  }
                 }
 
                 static const uint8_t* flow_enabled =
diff --git a/mojo/public/cpp/bindings/message_metadata_helpers.h b/mojo/public/cpp/bindings/message_metadata_helpers.h
index 6c1a0075..23b09d1 100644
--- a/mojo/public/cpp/bindings/message_metadata_helpers.h
+++ b/mojo/public/cpp/bindings/message_metadata_helpers.h
@@ -6,17 +6,20 @@
 #define MOJO_PUBLIC_CPP_BINDINGS_MESSAGE_METADATA_HELPERS_H_
 
 #include <cstdint>
-#include <utility>
 
 namespace mojo {
 
 class Message;
 
-// Alias for a function taking mojo::Message and returning an IPC hash (stable
-// across Chrome versions) + an address of the symbol representing the
-// mojo method name.
-using MessageToMethodInfoCallback =
-    std::pair<uint32_t, const void*> (*)(Message&);
+using IPCStableHashFunction = uint32_t (*)();
+// Alias for a function taking mojo::Message and returning a pointer to a
+// function that computes an IPC hash (stable across Chrome versions).
+// An address of the returned function is used for identifying mojo
+// method after symbolization.
+// The callback could have returned a pair (function address, IPC hash value)
+// instead, but returning only the function address results in ~20k binary size
+// savings.
+using MessageToMethodInfoCallback = IPCStableHashFunction (*)(Message&);
 
 // Alias for a function taking mojo::Message and returning method name.
 using MessageToMethodNameCallback = const char* (*)(Message&);
diff --git a/mojo/public/cpp/bindings/tests/bindings_perftest.cc b/mojo/public/cpp/bindings/tests/bindings_perftest.cc
index 14bf038..173c6c8 100644
--- a/mojo/public/cpp/bindings/tests/bindings_perftest.cc
+++ b/mojo/public/cpp/bindings/tests/bindings_perftest.cc
@@ -28,8 +28,8 @@
 
 const char kTestInterfaceName[] = "TestInterface";
 
-std::pair<uint32_t, const void*> MessageToMethodInfo(Message& message) {
-  return {-1, nullptr};
+IPCStableHashFunction MessageToMethodInfo(Message& message) {
+  return nullptr;
 }
 
 const char* MessageToMethodName(Message& message) {
diff --git a/mojo/public/cpp/bindings/tests/multiplex_router_unittest.cc b/mojo/public/cpp/bindings/tests/multiplex_router_unittest.cc
index f28e6cac..c04c386 100644
--- a/mojo/public/cpp/bindings/tests/multiplex_router_unittest.cc
+++ b/mojo/public/cpp/bindings/tests/multiplex_router_unittest.cc
@@ -25,8 +25,8 @@
 
 const char kTestInterfaceName[] = "TestInterface";
 
-std::pair<uint32_t, const void*> MessageToMethodInfo(Message& message) {
-  return {-1, nullptr};
+IPCStableHashFunction MessageToMethodInfo(Message& message) {
+  return nullptr;
 }
 
 const char* MessageToMethodName(Message& message) {
diff --git a/mojo/public/tools/bindings/generators/cpp_templates/interface_declaration.tmpl b/mojo/public/tools/bindings/generators/cpp_templates/interface_declaration.tmpl
index bbac331..c53d4ea 100644
--- a/mojo/public/tools/bindings/generators/cpp_templates/interface_declaration.tmpl
+++ b/mojo/public/tools/bindings/generators/cpp_templates/interface_declaration.tmpl
@@ -15,8 +15,10 @@
 class {{export_attribute}} {{interface.name}}
     : public {{interface.name}}InterfaceBase {
  public:
+  using IPCStableHashFunction = uint32_t(*)();
+
   static const char Name_[];
-  static std::pair<uint32_t, const void*> MessageToMethodInfo_(mojo::Message& message);
+  static IPCStableHashFunction MessageToMethodInfo_(mojo::Message& message);
   static const char* MessageToMethodName_(mojo::Message& message);
 
 
@@ -61,7 +63,7 @@
 {#--- Per method symbols #}
 {%- for method in interface.methods %}
   struct {{method.name}}_Sym {
-    NOINLINE static void IPCSymbol();
+    NOINLINE static uint32_t IPCStableHash();
   };
 {%- endfor %}
 #endif // !BUILDFLAG(IS_FUCHSIA)
diff --git a/mojo/public/tools/bindings/generators/cpp_templates/interface_definition.tmpl b/mojo/public/tools/bindings/generators/cpp_templates/interface_definition.tmpl
index 9beaa2cc..d538eaa 100644
--- a/mojo/public/tools/bindings/generators/cpp_templates/interface_definition.tmpl
+++ b/mojo/public/tools/bindings/generators/cpp_templates/interface_definition.tmpl
@@ -45,23 +45,19 @@
 {%-   endif %}
 {%- endfor %}
 
-std::pair<uint32_t, const void*> {{interface.name}}::MessageToMethodInfo_(mojo::Message& message) {
+{{interface.name}}::IPCStableHashFunction {{interface.name}}::MessageToMethodInfo_(mojo::Message& message) {
+#if !BUILDFLAG(IS_FUCHSIA)
 {%- if interface.methods %}
   switch (message.name()) {
 {%-   for method in interface.methods %}
     case internal::k{{interface.name}}_{{method.name}}_Name: {
-      constexpr uint32_t value = base::MD5Hash32Constexpr(
-              "(Impl){{namespace_as_string}}::{{interface.name}}::{{method.name}}");
-#if BUILDFLAG(IS_FUCHSIA)
-        return std::make_pair(value, nullptr);
-#else
-        return std::make_pair(value, reinterpret_cast<const void*>(&{{interface.name}}::{{method.name}}_Sym::IPCSymbol));
-#endif // BUILDFLAG(IS_FUCHSIA)
+      return &{{interface.name}}::{{method.name}}_Sym::IPCStableHash;
     }
 {%-   endfor %}
   }
 {%- endif %}
-  return std::make_pair(0, nullptr);
+#endif  // !BUILDFLAG(IS_FUCHSIA)
+  return nullptr;
 }
 
 
@@ -98,10 +94,18 @@
 
 #if !BUILDFLAG(IS_FUCHSIA)
 {%-   for method in interface.methods %}
-void {{interface.name}}::{{method.name}}_Sym::IPCSymbol() {
+uint32_t {{interface.name}}::{{method.name}}_Sym::IPCStableHash() {
   // This method's address is used for indetifiying the mojo method name after
-  // symblozation. So each IPCSymbol should have a unique address.
-  NO_CODE_FOLDING();
+  // symbolization. So each IPCStableHash should have a unique address.
+  // We cannot use NO_CODE_FOLDING() here - it relies on the uniqueness of
+  // __LINE__ value, which is not unique accross different mojo modules.
+  // The code below is very similar to NO_CODE_FOLDING, but it uses a unique
+  // hash instead of __LINE__.
+  constexpr uint32_t kHash = base::MD5Hash32Constexpr(
+          "(Impl){{namespace_as_string}}::{{interface.name}}::{{method.name}}");
+  const uint32_t hash = kHash;
+  base::debug::Alias(&hash);
+  return hash;
 }
 {%-   endfor %}
 # endif // !BUILDFLAG(IS_FUCHSIA)
diff --git a/net/base/features.cc b/net/base/features.cc
index 4196be6..15af33b 100644
--- a/net/base/features.cc
+++ b/net/base/features.cc
@@ -108,6 +108,9 @@
 const base::FeatureParam<int> kUseDnsHttpsSvcbExtraTimePercent{
     &kUseDnsHttpsSvcb, "UseDnsHttpsSvcbExtraTimePercent", 0};
 
+const base::Feature kUseDnsHttpsSvcbAlpn{"UseDnsHttpsSvcbAlpn",
+                                         base::FEATURE_DISABLED_BY_DEFAULT};
+
 const base::Feature kEnableTLS13EarlyData{"EnableTLS13EarlyData",
                                           base::FEATURE_DISABLED_BY_DEFAULT};
 
diff --git a/net/base/features.h b/net/base/features.h
index ae47f39..c841edfb 100644
--- a/net/base/features.h
+++ b/net/base/features.h
@@ -169,6 +169,9 @@
 NET_EXPORT extern const base::FeatureParam<int>
     kUseDnsHttpsSvcbExtraTimePercent;
 
+// Update protocol using ALPN information in HTTPS DNS records.
+NET_EXPORT extern const base::Feature kUseDnsHttpsSvcbAlpn;
+
 // Enables TLS 1.3 early data.
 NET_EXPORT extern const base::Feature kEnableTLS13EarlyData;
 
diff --git a/net/http/alternative_service.h b/net/http/alternative_service.h
index 91dbc76..90656bf 100644
--- a/net/http/alternative_service.h
+++ b/net/http/alternative_service.h
@@ -27,13 +27,19 @@
   // Alternate Protocol was used by winning a race with a normal connection.
   ALTERNATE_PROTOCOL_USAGE_WON_RACE = 1,
   // Alternate Protocol was not used by losing a race with a normal connection.
-  ALTERNATE_PROTOCOL_USAGE_LOST_RACE = 2,
+  ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE = 2,
   // Alternate Protocol was not used because no Alternate-Protocol information
   // was available when the request was issued, but an Alternate-Protocol header
   // was present in the response.
   ALTERNATE_PROTOCOL_USAGE_MAPPING_MISSING = 3,
   // Alternate Protocol was not used because it was marked broken.
   ALTERNATE_PROTOCOL_USAGE_BROKEN = 4,
+  // HTTPS DNS protocol upgrade job was used without racing with a normal
+  // connection and an Alternate Protocol job.
+  ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE = 5,
+  // HTTPS DNS protocol upgrade job won a race with a normal connection and
+  // an Alternate Protocol job.
+  ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE = 6,
   // Maximum value for the enum.
   ALTERNATE_PROTOCOL_USAGE_MAX,
 };
diff --git a/net/http/http_server_properties_manager.cc b/net/http/http_server_properties_manager.cc
index b2fd54f..403f239 100644
--- a/net/http/http_server_properties_manager.cc
+++ b/net/http/http_server_properties_manager.cc
@@ -4,6 +4,7 @@
 
 #include "net/http/http_server_properties_manager.h"
 
+#include <algorithm>
 #include <utility>
 
 #include "base/bind.h"
@@ -715,7 +716,7 @@
   // Convert |server_info_map| to a list Value and add it to
   // |http_server_properties_dict|.
   base::Value::List servers_list;
-  for (const auto& [key, server_info] : base::Reversed(server_info_map)) {
+  for (const auto& [key, server_info] : server_info_map) {
     // If can't convert the NetworkIsolationKey to a value, don't save to disk.
     // Generally happens because the key is for a unique origin.
     base::Value network_isolation_key_value;
@@ -750,6 +751,9 @@
                     std::move(network_isolation_key_value));
     servers_list.Append(std::move(server_dict));
   }
+  // Reverse `servers_list`. The least recently used item will be in the front.
+  std::reverse(servers_list.begin(), servers_list.end());
+
   http_server_properties_dict.Set(kServersKey, std::move(servers_list));
 
   http_server_properties_dict.Set(kVersionKey, kVersionNumber);
diff --git a/net/http/http_server_properties_manager_unittest.cc b/net/http/http_server_properties_manager_unittest.cc
index ca52a87..87aaabd 100644
--- a/net/http/http_server_properties_manager_unittest.cc
+++ b/net/http/http_server_properties_manager_unittest.cc
@@ -2376,22 +2376,19 @@
       std::move(pref_delegate), /*net_log=*/nullptr, GetMockTickClock());
   unowned_pref_delegate->InitializePrefs(saved_value);
 
-  // Only the first of the values learned for kNetworkIsolationKey1 should have
+  // Only the last of the values learned for kNetworkIsolationKey1 should have
   // been saved, and the value for kNetworkIsolationKey2 as well. The canonical
   // suffix logic should still be respected.
-  //
-  // TODO(mmenke): Preferring the oldest value seems unexpected.
-  // https://crbug.com/994842.
   EXPECT_EQ(
-      1u,
+      2u,
       properties->GetAlternativeServiceInfos(kServer1, kNetworkIsolationKey1)
           .size());
   EXPECT_EQ(
-      1u,
+      2u,
       properties->GetAlternativeServiceInfos(kServer2, kNetworkIsolationKey1)
           .size());
   EXPECT_EQ(
-      1u,
+      2u,
       properties->GetAlternativeServiceInfos(kServer3, kNetworkIsolationKey1)
           .size());
   EXPECT_EQ(
diff --git a/net/http/http_stream_factory.h b/net/http/http_stream_factory.h
index 694d071..9ba1e633 100644
--- a/net/http/http_stream_factory.h
+++ b/net/http/http_stream_factory.h
@@ -46,8 +46,17 @@
   class NET_EXPORT_PRIVATE JobFactory;
 
   enum JobType {
+    // Job that will connect via HTTP/1 or HTTP/2. This may be paused for a
+    // while when ALTERNATIVE or DNS_ALPN_H3 job was created.
     MAIN,
+    // Job that will connect via HTTP/3 iff Chrome has received an Alt-Svc
+    // header from the origin.
     ALTERNATIVE,
+    // Job that will connect via HTTP/3 iff an "h3" value was found in the ALPN
+    // list of an HTTPS DNS record.
+    DNS_ALPN_H3,
+    // Job that will preconnect. This uses HTTP/3 iff Chrome has received an
+    // Alt-Svc header from the origin. Otherwise, it use HTTP/1 or HTTP/2.
     PRECONNECT,
   };
 
diff --git a/net/http/http_stream_factory_job.cc b/net/http/http_stream_factory_job.cc
index 93ff6b8..968b9ea4 100644
--- a/net/http/http_stream_factory_job.cc
+++ b/net/http/http_stream_factory_job.cc
@@ -71,12 +71,27 @@
 
 }  // namespace
 
+const char* NetLogHttpStreamJobType(HttpStreamFactory::JobType job_type) {
+  switch (job_type) {
+    case HttpStreamFactory::MAIN:
+      return "main";
+    case HttpStreamFactory::ALTERNATIVE:
+      return "alternative";
+    case HttpStreamFactory::DNS_ALPN_H3:
+      return "dns_alpn_h3";
+    case HttpStreamFactory::PRECONNECT:
+      return "preconnect";
+  }
+  return "";
+}
+
 // Returns parameters associated with the start of a HTTP stream job.
 base::Value NetLogHttpStreamJobParams(const NetLogSource& source,
                                       const GURL& original_url,
                                       const GURL& url,
                                       bool expect_spdy,
                                       bool using_quic,
+                                      HttpStreamFactory::JobType job_type,
                                       RequestPriority priority) {
   base::Value::Dict dict;
   if (source.IsValid())
@@ -86,6 +101,7 @@
   dict.Set("expect_spdy", expect_spdy);
   dict.Set("using_quic", using_quic);
   dict.Set("priority", RequestPriorityToString(priority));
+  dict.Set("type", NetLogHttpStreamJobType(job_type));
   return base::Value(std::move(dict));
 }
 
@@ -142,7 +158,8 @@
                  origin_url_.SchemeIs(url::kWssScheme)),
       using_quic_(
           alternative_protocol == kProtoQUIC ||
-          (ShouldForceQuic(session, destination_, proxy_info, using_ssl_))),
+          (ShouldForceQuic(session, destination_, proxy_info, using_ssl_)) ||
+          job_type == DNS_ALPN_H3),
       quic_version_(quic_version),
       expect_spdy_(alternative_protocol == kProtoHTTP2 && !using_quic_),
       quic_request_(session_->quic_stream_factory()),
@@ -179,8 +196,10 @@
         session->context().quic_context->params()->supported_versions[0];
   }
 
-  if (using_quic_)
-    DCHECK_NE(quic_version_, quic::ParsedQuicVersion::Unsupported());
+  if (using_quic_) {
+    DCHECK((quic_version_ != quic::ParsedQuicVersion::Unsupported()) ||
+           (job_type_ == DNS_ALPN_H3));
+  }
 
   DCHECK(session);
   if (alternative_protocol != kProtoUnknown) {
@@ -274,7 +293,7 @@
 }
 
 void HttpStreamFactory::Job::Orphan() {
-  DCHECK_EQ(job_type_, ALTERNATIVE);
+  DCHECK(job_type_ == ALTERNATIVE || job_type_ == DNS_ALPN_H3);
   net_log_.AddEvent(NetLogEventType::HTTP_STREAM_JOB_ORPHANED);
 
   // Watching for SPDY sessions isn't supported on orphaned jobs.
@@ -304,6 +323,16 @@
                                                             is_websocket_);
 }
 
+bool HttpStreamFactory::Job::HasAvailableQuicSession() const {
+  if (!using_quic_)
+    return false;
+  bool require_dns_https_alpn = (job_type_ == DNS_ALPN_H3);
+  return quic_request_.CanUseExistingSession(
+      origin_url_, request_info_.privacy_mode, request_info_.socket_tag,
+      request_info_.network_isolation_key, request_info_.secure_dns_policy,
+      require_dns_https_alpn, destination_);
+}
+
 bool HttpStreamFactory::Job::was_alpn_negotiated() const {
   return was_alpn_negotiated_;
 }
@@ -627,7 +656,7 @@
     net_log_.BeginEvent(NetLogEventType::HTTP_STREAM_JOB, [&] {
       return NetLogHttpStreamJobParams(net_log->source(), request_info_.url,
                                        origin_url_, expect_spdy_, using_quic_,
-                                       priority_);
+                                       job_type_, priority_);
     });
     net_log->AddEventReferencingSource(
         NetLogEventType::HTTP_STREAM_REQUEST_STARTED_JOB, net_log_.source());
@@ -879,13 +908,14 @@
     ssl_config = &server_ssl_config_;
   }
   DCHECK(url.SchemeIs(url::kHttpsScheme));
+  bool require_dns_https_alpn = (job_type_ == DNS_ALPN_H3);
 
   int rv = quic_request_.Request(
       std::move(destination), quic_version_, request_info_.privacy_mode,
       priority_, request_info_.socket_tag, request_info_.network_isolation_key,
       request_info_.secure_dns_policy, proxy_info_.is_direct(),
-      /*require_dns_https_alpn=*/false, ssl_config->GetCertVerifyFlags(), url,
-      net_log_, &net_error_details_,
+      require_dns_https_alpn, ssl_config->GetCertVerifyFlags(), url, net_log_,
+      &net_error_details_,
       base::BindOnce(&Job::OnFailedOnDefaultNetwork, ptr_factory_.GetWeakPtr()),
       io_callback_);
   if (rv == OK) {
@@ -908,7 +938,7 @@
 }
 
 void HttpStreamFactory::Job::OnFailedOnDefaultNetwork(int result) {
-  DCHECK_EQ(job_type_, ALTERNATIVE);
+  DCHECK(job_type_ == ALTERNATIVE || job_type_ == DNS_ALPN_H3);
   DCHECK(using_quic_);
   delegate_->OnFailedOnDefaultNetwork(this);
 }
@@ -1257,7 +1287,7 @@
 HttpStreamFactory::JobFactory::~JobFactory() = default;
 
 std::unique_ptr<HttpStreamFactory::Job>
-HttpStreamFactory::JobFactory::CreateMainJob(
+HttpStreamFactory::JobFactory::CreateJob(
     HttpStreamFactory::Job::Delegate* delegate,
     HttpStreamFactory::JobType job_type,
     HttpNetworkSession* session,
@@ -1270,31 +1300,9 @@
     GURL origin_url,
     bool is_websocket,
     bool enable_ip_based_pooling,
-    NetLog* net_log) {
-  return std::make_unique<HttpStreamFactory::Job>(
-      delegate, job_type, session, request_info, priority, proxy_info,
-      server_ssl_config, proxy_ssl_config, std::move(destination), origin_url,
-      kProtoUnknown, quic::ParsedQuicVersion::Unsupported(), is_websocket,
-      enable_ip_based_pooling, net_log);
-}
-
-std::unique_ptr<HttpStreamFactory::Job>
-HttpStreamFactory::JobFactory::CreateAltSvcJob(
-    HttpStreamFactory::Job::Delegate* delegate,
-    HttpStreamFactory::JobType job_type,
-    HttpNetworkSession* session,
-    const HttpRequestInfo& request_info,
-    RequestPriority priority,
-    const ProxyInfo& proxy_info,
-    const SSLConfig& server_ssl_config,
-    const SSLConfig& proxy_ssl_config,
-    url::SchemeHostPort destination,
-    GURL origin_url,
+    NetLog* net_log,
     NextProto alternative_protocol,
-    quic::ParsedQuicVersion quic_version,
-    bool is_websocket,
-    bool enable_ip_based_pooling,
-    NetLog* net_log) {
+    quic::ParsedQuicVersion quic_version) {
   return std::make_unique<HttpStreamFactory::Job>(
       delegate, job_type, session, request_info, priority, proxy_info,
       server_ssl_config, proxy_ssl_config, std::move(destination), origin_url,
diff --git a/net/http/http_stream_factory_job.h b/net/http/http_stream_factory_job.h
index 6fbf76d9..17d04e80 100644
--- a/net/http/http_stream_factory_job.h
+++ b/net/http/http_stream_factory_job.h
@@ -186,7 +186,7 @@
   virtual void Resume();
 
   // Called when |this| is orphaned by Delegate. This is valid for
-  // ALTERNATIVE job only.
+  // ALTERNATIVE job and DNS_ALPN_H3 job.
   void Orphan();
 
   void SetPriority(RequestPriority priority);
@@ -195,6 +195,10 @@
   // spdy session.
   bool HasAvailableSpdySession() const;
 
+  // Returns true if the current request can be immediately sent on a existing
+  // QUIC session.
+  bool HasAvailableQuicSession() const;
+
   const GURL& origin_url() const { return origin_url_; }
   RequestPriority priority() const { return priority_; }
   bool was_alpn_negotiated() const;
@@ -475,7 +479,7 @@
 
   virtual ~JobFactory();
 
-  virtual std::unique_ptr<HttpStreamFactory::Job> CreateMainJob(
+  virtual std::unique_ptr<HttpStreamFactory::Job> CreateJob(
       HttpStreamFactory::Job::Delegate* delegate,
       HttpStreamFactory::JobType job_type,
       HttpNetworkSession* session,
@@ -488,24 +492,10 @@
       GURL origin_url,
       bool is_websocket,
       bool enable_ip_based_pooling,
-      NetLog* net_log);
-
-  virtual std::unique_ptr<HttpStreamFactory::Job> CreateAltSvcJob(
-      HttpStreamFactory::Job::Delegate* delegate,
-      HttpStreamFactory::JobType job_type,
-      HttpNetworkSession* session,
-      const HttpRequestInfo& request_info,
-      RequestPriority priority,
-      const ProxyInfo& proxy_info,
-      const SSLConfig& server_ssl_config,
-      const SSLConfig& proxy_ssl_config,
-      url::SchemeHostPort destination,
-      GURL origin_url,
-      NextProto alternative_protocol,
-      quic::ParsedQuicVersion quic_version,
-      bool is_websocket,
-      bool enable_ip_based_pooling,
-      NetLog* net_log);
+      NetLog* net_log,
+      NextProto alternative_protocol = kProtoUnknown,
+      quic::ParsedQuicVersion quic_version =
+          quic::ParsedQuicVersion::Unsupported());
 };
 
 }  // namespace net
diff --git a/net/http/http_stream_factory_job_controller.cc b/net/http/http_stream_factory_job_controller.cc
index a1eddbb..74669aa 100644
--- a/net/http/http_stream_factory_job_controller.cc
+++ b/net/http/http_stream_factory_job_controller.cc
@@ -16,8 +16,10 @@
 #include "base/threading/thread_task_runner_handle.h"
 #include "base/trace_event/memory_usage_estimator.h"
 #include "base/values.h"
+#include "net/base/features.h"
 #include "net/base/host_mapping_rules.h"
 #include "net/base/load_flags.h"
+#include "net/base/net_errors.h"
 #include "net/base/privacy_mode.h"
 #include "net/base/proxy_server.h"
 #include "net/base/proxy_string_util.h"
@@ -94,6 +96,12 @@
   }
 }
 
+// Generate a AlternativeService for DNS alt job. Note: Chrome does not yet
+// support different port DNS alpn.
+AlternativeService GetAlternativeServiceForDnsJob(const GURL& url) {
+  return AlternativeService(kProtoQUIC, HostPortPair::FromURL(url));
+}
+
 }  // namespace
 
 // The maximum time to wait for the alternate job to complete before resuming
@@ -165,6 +173,7 @@
 HttpStreamFactory::JobController::~JobController() {
   main_job_.reset();
   alternative_job_.reset();
+  dns_alpn_h3_job_.reset();
   bound_job_ = nullptr;
   if (proxy_resolve_request_) {
     DCHECK_EQ(STATE_RESOLVE_PROXY_COMPLETE, next_state_);
@@ -224,6 +233,9 @@
     return main_job_->GetLoadState();
   if (alternative_job_)
     return alternative_job_->GetLoadState();
+  if (dns_alpn_h3_job_)
+    return dns_alpn_h3_job_->GetLoadState();
+
   // When proxy resolution fails, there is no job created and
   // NotifyRequestFailed() is executed one message loop iteration later.
   return LOAD_STATE_IDLE;
@@ -231,15 +243,20 @@
 
 void HttpStreamFactory::JobController::OnRequestComplete() {
   DCHECK(request_);
-
-  CancelJobs();
   request_ = nullptr;
-  if (bound_job_) {
+
+  if (!job_bound_) {
+    alternative_job_.reset();
+    main_job_.reset();
+    dns_alpn_h3_job_.reset();
+  } else {
     if (bound_job_->job_type() == MAIN) {
       main_job_.reset();
-    } else {
-      DCHECK(bound_job_->job_type() == ALTERNATIVE);
+    } else if (bound_job_->job_type() == ALTERNATIVE) {
       alternative_job_.reset();
+    } else {
+      DCHECK(bound_job_->job_type() == DNS_ALPN_H3);
+      dns_alpn_h3_job_.reset();
     }
     bound_job_ = nullptr;
   }
@@ -258,6 +275,9 @@
   if (alternative_job_) {
     alternative_job_->SetPriority(priority);
   }
+  if (dns_alpn_h3_job_) {
+    dns_alpn_h3_job_->SetPriority(priority);
+  }
 }
 
 void HttpStreamFactory::JobController::OnStreamReady(
@@ -348,12 +368,18 @@
     Job* job,
     int status,
     const SSLConfig& used_ssl_config) {
-  if (job->job_type() == ALTERNATIVE) {
-    DCHECK_EQ(alternative_job_.get(), job);
-    OnAlternativeServiceJobFailed(status);
-  } else {
+  DCHECK_NE(OK, status);
+  if (job->job_type() == MAIN) {
     DCHECK_EQ(main_job_.get(), job);
     main_job_net_error_ = status;
+  } else if (job->job_type() == ALTERNATIVE) {
+    DCHECK_EQ(alternative_job_.get(), job);
+    DCHECK_NE(kProtoUnknown, alternative_service_info_.protocol());
+    alternative_job_net_error_ = status;
+  } else {
+    DCHECK_EQ(job->job_type(), DNS_ALPN_H3);
+    DCHECK_EQ(dns_alpn_h3_job_.get(), job);
+    dns_alpn_h3_job_net_error_ = status;
   }
 
   MaybeResumeMainJob(job, base::TimeDelta());
@@ -371,14 +397,19 @@
   DCHECK(job);
 
   if (!bound_job_) {
-    if (main_job_ && alternative_job_) {
+    if (GetJobCount() >= 2) {
       // Hey, we've got other jobs! Maybe one of them will succeed, let's just
       // ignore this failure.
       if (job->job_type() == MAIN) {
+        DCHECK_EQ(main_job_.get(), job);
         main_job_.reset();
-      } else {
-        DCHECK(job->job_type() == ALTERNATIVE);
+      } else if (job->job_type() == ALTERNATIVE) {
+        DCHECK_EQ(alternative_job_.get(), job);
         alternative_job_.reset();
+      } else {
+        DCHECK_EQ(job->job_type(), DNS_ALPN_H3);
+        DCHECK_EQ(dns_alpn_h3_job_.get(), job);
+        dns_alpn_h3_job_.reset();
       }
       return;
     } else {
@@ -401,8 +432,14 @@
 }
 
 void HttpStreamFactory::JobController::OnFailedOnDefaultNetwork(Job* job) {
-  DCHECK_EQ(job->job_type(), ALTERNATIVE);
-  alternative_job_failed_on_default_network_ = true;
+  if (job->job_type() == ALTERNATIVE) {
+    DCHECK_EQ(alternative_job_.get(), job);
+    alternative_job_failed_on_default_network_ = true;
+  } else {
+    DCHECK_EQ(job->job_type(), DNS_ALPN_H3);
+    DCHECK_EQ(dns_alpn_h3_job_.get(), job);
+    dns_alpn_h3_job_failed_on_default_network_ = true;
+  }
 }
 
 void HttpStreamFactory::JobController::OnCertificateError(
@@ -483,9 +520,13 @@
   if (job->job_type() == MAIN) {
     DCHECK_EQ(main_job_.get(), job);
     main_job_.reset();
-  } else {
+  } else if (job->job_type() == ALTERNATIVE) {
     DCHECK_EQ(alternative_job_.get(), job);
     alternative_job_.reset();
+  } else {
+    DCHECK_EQ(job->job_type(), DNS_ALPN_H3);
+    DCHECK_EQ(dns_alpn_h3_job_.get(), job);
+    dns_alpn_h3_job_.reset();
   }
 
   MaybeNotifyFactoryOfCompletion();
@@ -530,15 +571,23 @@
   main_job_net_error_ = OK;
   alternative_job_net_error_ = OK;
   alternative_job_failed_on_default_network_ = false;
+  dns_alpn_h3_job_net_error_ = OK;
+  dns_alpn_h3_job_failed_on_default_network_ = false;
 }
 
 void HttpStreamFactory::JobController::MaybeResumeMainJob(
     Job* job,
     const base::TimeDelta& delay) {
   DCHECK(delay == base::TimeDelta() || delay == main_job_wait_time_);
-  DCHECK(job == main_job_.get() || job == alternative_job_.get());
+  DCHECK(job == main_job_.get() || job == alternative_job_.get() ||
+         job == dns_alpn_h3_job_.get());
 
-  if (job != alternative_job_.get() || !main_job_)
+  if (job == main_job_.get())
+    return;
+  if (job == dns_alpn_h3_job_.get() && alternative_job_) {
+    return;
+  }
+  if (!main_job_)
     return;
 
   main_job_is_blocked_ = false;
@@ -568,9 +617,9 @@
 
 bool HttpStreamFactory::JobController::ShouldWait(Job* job) {
   // The alternative job never waits.
-  if (job == alternative_job_.get())
+  if (job == alternative_job_.get() || job == dns_alpn_h3_job_.get())
     return false;
-
+  DCHECK_EQ(main_job_.get(), job);
   if (main_job_is_blocked_)
     return true;
 
@@ -636,6 +685,7 @@
     // iteration later to avoid re-entrancy.
     DCHECK(!main_job_);
     DCHECK(!alternative_job_);
+    DCHECK(!dns_alpn_h3_job_);
     base::ThreadTaskRunnerHandle::Get()->PostTask(
         FROM_HERE,
         base::BindOnce(&HttpStreamFactory::JobController::NotifyRequestFailed,
@@ -762,30 +812,33 @@
           url::SchemeHostPort(alternative_url);
       ConvertWsToHttp(alternative_destination);
 
-      main_job_ = job_factory_->CreateAltSvcJob(
+      main_job_ = job_factory_->CreateJob(
           this, PRECONNECT, session_, request_info_, IDLE, proxy_info_,
           server_ssl_config_, proxy_ssl_config_,
-          std::move(alternative_destination), origin_url,
-          alternative_service_info_.protocol(), quic_version, is_websocket_,
-          enable_ip_based_pooling_, session_->net_log());
+          std::move(alternative_destination), origin_url, is_websocket_,
+          enable_ip_based_pooling_, session_->net_log(),
+          alternative_service_info_.protocol(), quic_version);
     } else {
-      main_job_ = job_factory_->CreateMainJob(
+      main_job_ = job_factory_->CreateJob(
           this, PRECONNECT, session_, request_info_, IDLE, proxy_info_,
           server_ssl_config_, proxy_ssl_config_, std::move(destination),
           origin_url, is_websocket_, enable_ip_based_pooling_,
           session_->net_log());
     }
     main_job_->Preconnect(num_streams_);
+    // TODO(crbug.com/1317943): Consider using DNS_ALPN_H3 job for preconnect.
     return OK;
   }
-  main_job_ = job_factory_->CreateMainJob(
+  main_job_ = job_factory_->CreateJob(
       this, MAIN, session_, request_info_, priority_, proxy_info_,
       server_ssl_config_, proxy_ssl_config_, std::move(destination), origin_url,
       is_websocket_, enable_ip_based_pooling_, net_log_.net_log());
+
   // Alternative Service can only be set for HTTPS requests while Alternative
   // Proxy is set for HTTP requests.
   if (alternative_service_info_.protocol() != kProtoUnknown) {
     DCHECK(request_info_.url.SchemeIs(url::kHttpsScheme));
+    DCHECK(!is_websocket_);
     DVLOG(1) << "Selected alternative service (host: "
              << alternative_service_info_.host_port_pair().host()
              << " port: " << alternative_service_info_.host_port_pair().port()
@@ -799,28 +852,86 @@
         url::SchemeHostPort(alternative_url);
     ConvertWsToHttp(alternative_destination);
 
-    alternative_job_ = job_factory_->CreateAltSvcJob(
+    alternative_job_ = job_factory_->CreateJob(
         this, ALTERNATIVE, session_, request_info_, priority_, proxy_info_,
         server_ssl_config_, proxy_ssl_config_,
-        std::move(alternative_destination), origin_url,
-        alternative_service_info_.protocol(), quic_version, is_websocket_,
-        enable_ip_based_pooling_, net_log_.net_log());
+        std::move(alternative_destination), origin_url, is_websocket_,
+        enable_ip_based_pooling_, net_log_.net_log(),
+        alternative_service_info_.protocol(), quic_version);
+  }
 
+  if (base::FeatureList::IsEnabled(features::kUseDnsHttpsSvcbAlpn) &&
+      base::EqualsCaseInsensitiveASCII(origin_url.scheme(),
+                                       url::kHttpsScheme) &&
+      session_->IsQuicEnabled() && proxy_info_.is_direct() &&
+      !session_->http_server_properties()->IsAlternativeServiceBroken(
+          GetAlternativeServiceForDnsJob(origin_url),
+          request_info_.network_isolation_key)) {
+    DCHECK(!is_websocket_);
+    url::SchemeHostPort dns_alpn_h3_destination =
+        url::SchemeHostPort(origin_url);
+    dns_alpn_h3_job_ = job_factory_->CreateJob(
+        this, DNS_ALPN_H3, session_, request_info_, priority_, proxy_info_,
+        server_ssl_config_, proxy_ssl_config_,
+        std::move(dns_alpn_h3_destination), origin_url, is_websocket_,
+        enable_ip_based_pooling_, net_log_.net_log());
+  }
+
+  ClearInappropriateJobs();
+
+  if (alternative_job_ || dns_alpn_h3_job_) {
+    // TODO(crbug.com/1317943): Consider not to block the main job when an
+    // active session is available for the main job and |alternative_job_|
+    // doesn't exists and |dns_alpn_h3_job_| exists. This may make the fallback
+    // logic faster when QUIC connection is unstable on the network. But we need
+    // to support DNS alpn job for preconnect before doing so. Currently
+    // preconnect job is triggered for all navigations by
+    // features::kNavigationRequestPreconnect. And the preconnect job doesn't
+    // support DNS HTTPS alpn and establishes non-HTTP/3 connection for the
+    // first connection. So when this method is called after the preconnect
+    // request, an active session may be available for the main job, and the
+    // DNS alpn job may be unintentionally disturbed.
     main_job_is_blocked_ = true;
+  }
+
+  if (alternative_job_) {
     alternative_job_->Start(request_->stream_type());
   }
 
-  // Even if |alternative_job| has already finished, it will not have notified
-  // the request yet, since we defer that to the next iteration of the
-  // MessageLoop, so starting |main_job_| is always safe.
-  main_job_->Start(request_->stream_type());
+  if (dns_alpn_h3_job_) {
+    dns_alpn_h3_job_->Start(request_->stream_type());
+  }
+
+  if (main_job_) {
+    main_job_->Start(request_->stream_type());
+  }
   return OK;
 }
 
+void HttpStreamFactory::JobController::ClearInappropriateJobs() {
+  if (dns_alpn_h3_job_ && dns_alpn_h3_job_->HasAvailableQuicSession()) {
+    // Clear |main_job_| and |alternative_job_| here not to start them when
+    // there is an active session available for |dns_alpn_h3_job_|.
+    main_job_.reset();
+    alternative_job_.reset();
+  }
+
+  if (alternative_job_ && dns_alpn_h3_job_ &&
+      (alternative_job_->HasAvailableQuicSession() ||
+       (alternative_service_info_.alternative_service() ==
+        GetAlternativeServiceForDnsJob(request_info_.url)))) {
+    // Clear |dns_alpn_h3_job_|, when there is an active session available for
+    // |alternative_job_| or |alternative_job_| was created for the same
+    // destination.
+    dns_alpn_h3_job_.reset();
+  }
+}
+
 void HttpStreamFactory::JobController::BindJob(Job* job) {
   DCHECK(request_);
   DCHECK(job);
-  DCHECK(job == alternative_job_.get() || job == main_job_.get());
+  DCHECK(job == alternative_job_.get() || job == main_job_.get() ||
+         job == dns_alpn_h3_job_.get());
   DCHECK(!job_bound_);
   DCHECK(!bound_job_);
 
@@ -837,54 +948,73 @@
   OrphanUnboundJob();
 }
 
-void HttpStreamFactory::JobController::CancelJobs() {
-  DCHECK(request_);
-  if (job_bound_)
-    return;
-  if (alternative_job_)
-    alternative_job_.reset();
-  if (main_job_)
-    main_job_.reset();
-}
-
 void HttpStreamFactory::JobController::OrphanUnboundJob() {
   DCHECK(request_);
   DCHECK(bound_job_);
 
-  if (bound_job_->job_type() == MAIN && alternative_job_) {
-    DCHECK(!is_websocket_);
-    // Allow |alternative_job_| to run to completion, rather than resetting it
-    // to check if there is any broken alternative service to report.
-    // OnOrphanedJobComplete() will clean up |this| when the job completes.
-    alternative_job_->Orphan();
+  if (bound_job_->job_type() == MAIN) {
+    // Allow |alternative_job_| and |dns_alpn_h3_job_| to run to completion,
+    // rather than resetting them to check if there is any broken alternative
+    // service to report. OnOrphanedJobComplete() will clean up |this| when the
+    // jobs complete.
+    if (alternative_job_) {
+      DCHECK(!is_websocket_);
+      alternative_job_->Orphan();
+    }
+    if (dns_alpn_h3_job_) {
+      DCHECK(!is_websocket_);
+      dns_alpn_h3_job_->Orphan();
+    }
     return;
   }
 
-  if (bound_job_->job_type() == ALTERNATIVE && main_job_ &&
-      !alternative_job_failed_on_default_network_) {
-    // |request_| is bound to the alternative job and the alternative job
-    // succeeds on the default network. This means that the main job
-    // is no longer needed, so cancel it now. Pending ConnectJobs will return
-    // established sockets to socket pools if applicable.
-    // https://crbug.com/757548.
-    // The main job still needs to run if the alternative job succeeds on the
-    // alternate network in order to figure out whether QUIC should be marked as
-    // broken until the default network changes.
-    DCHECK_EQ(OK, alternative_job_net_error_);
-    main_job_.reset();
+  if (bound_job_->job_type() == ALTERNATIVE) {
+    if (!alternative_job_failed_on_default_network_ && !dns_alpn_h3_job_) {
+      // |request_| is bound to the alternative job and the alternative job
+      // succeeds on the default network, and there is no DNS alt job. This
+      // means that the main job is no longer needed, so cancel it now. Pending
+      // ConnectJobs will return established sockets to socket pools if
+      // applicable.
+      // https://crbug.com/757548.
+      // The main job still needs to run if the alternative job succeeds on the
+      // alternate network in order to figure out whether QUIC should be marked
+      // as broken until the default network changes. And also the main job
+      // still needs to run if the DNS alt job exists to figure out whether
+      // the DNS alpn service is broken.
+      DCHECK(!main_job_ || (alternative_job_net_error_ == OK));
+      main_job_.reset();
+    }
+    // Allow |dns_alpn_h3_job_| to run to completion, rather than resetting
+    // it to check if there is any broken alternative service to report.
+    // OnOrphanedJobComplete() will clean up |this| when the job completes.
+    if (dns_alpn_h3_job_) {
+      DCHECK(!is_websocket_);
+      dns_alpn_h3_job_->Orphan();
+    }
+  }
+  if (bound_job_->job_type() == DNS_ALPN_H3) {
+    if (!dns_alpn_h3_job_failed_on_default_network_ && !alternative_job_) {
+      DCHECK(!main_job_ || (dns_alpn_h3_job_net_error_ == OK));
+      main_job_.reset();
+    }
+    // Allow |alternative_job_| to run to completion, rather than resetting
+    // it to check if there is any broken alternative service to report.
+    // OnOrphanedJobComplete() will clean up |this| when the job completes.
+    if (alternative_job_) {
+      DCHECK(!is_websocket_);
+      alternative_job_->Orphan();
+    }
   }
 }
 
 void HttpStreamFactory::JobController::OnJobSucceeded(Job* job) {
   DCHECK(job);
-
   if (!bound_job_) {
-    if (main_job_ && alternative_job_)
+    if ((main_job_ && alternative_job_) || dns_alpn_h3_job_)
       ReportAlternateProtocolUsage(job);
     BindJob(job);
     return;
   }
-  DCHECK(bound_job_);
 }
 
 void HttpStreamFactory::JobController::MarkRequestComplete(
@@ -895,77 +1025,75 @@
     request_->Complete(was_alpn_negotiated, negotiated_protocol, using_spdy);
 }
 
-void HttpStreamFactory::JobController::OnAlternativeServiceJobFailed(
-    int net_error) {
-  DCHECK_EQ(alternative_job_->job_type(), ALTERNATIVE);
-  DCHECK_NE(OK, net_error);
-  DCHECK_NE(kProtoUnknown, alternative_service_info_.protocol());
-
-  alternative_job_net_error_ = net_error;
-}
-
-void HttpStreamFactory::JobController::MaybeReportBrokenAlternativeService() {
+void HttpStreamFactory::JobController::MaybeReportBrokenAlternativeService(
+    const AlternativeService& alt_service,
+    int alt_job_net_error,
+    bool alt_job_failed_on_default_network,
+    const std::string& histogram_name_for_failure) {
   // If alternative job succeeds on the default network, no brokenness to
   // report.
-  if (alternative_job_net_error_ == OK &&
-      !alternative_job_failed_on_default_network_)
+  if (alt_job_net_error == OK && !alt_job_failed_on_default_network)
     return;
 
   // No brokenness to report if the main job fails.
   if (main_job_net_error_ != OK)
     return;
 
-  DCHECK(alternative_service_info_.protocol() != kProtoUnknown);
+  // No need to record DNS_NO_MACHING_SUPPORTED_ALPN error.
+  if (alt_job_net_error == ERR_DNS_NO_MACHING_SUPPORTED_ALPN)
+    return;
 
-  if (alternative_job_failed_on_default_network_ &&
-      alternative_job_net_error_ == OK) {
+  if (alt_job_failed_on_default_network && alt_job_net_error == OK) {
     // Alternative job failed on the default network but succeeds on the
     // non-default network, mark alternative service broken until the default
     // network changes.
     session_->http_server_properties()
         ->MarkAlternativeServiceBrokenUntilDefaultNetworkChanges(
-            alternative_service_info_.alternative_service(),
-            request_info_.network_isolation_key);
-    // Reset error status for Jobs after reporting brokenness.
-    ResetErrorStatusForJobs();
+            alt_service, request_info_.network_isolation_key);
     return;
   }
 
-  if (alternative_job_net_error_ == ERR_NETWORK_CHANGED ||
-      alternative_job_net_error_ == ERR_INTERNET_DISCONNECTED ||
-      (alternative_job_net_error_ == ERR_NAME_NOT_RESOLVED &&
-       request_info_.url.host() ==
-           alternative_service_info_.alternative_service().host)) {
+  if (alt_job_net_error == ERR_NETWORK_CHANGED ||
+      alt_job_net_error == ERR_INTERNET_DISCONNECTED ||
+      (alt_job_net_error == ERR_NAME_NOT_RESOLVED &&
+       request_info_.url.host() == alt_service.host)) {
     // No need to mark alternative service as broken.
-    // Reset error status for Jobs.
-    ResetErrorStatusForJobs();
     return;
   }
 
   // Report brokenness if alternative job failed.
-  base::UmaHistogramSparse("Net.AlternateServiceFailed",
-                           -alternative_job_net_error_);
+  base::UmaHistogramSparse(histogram_name_for_failure, -alt_job_net_error);
 
   HistogramBrokenAlternateProtocolLocation(
       BROKEN_ALTERNATE_PROTOCOL_LOCATION_HTTP_STREAM_FACTORY_JOB_ALT);
   session_->http_server_properties()->MarkAlternativeServiceBroken(
-      alternative_service_info_.alternative_service(),
-      request_info_.network_isolation_key);
-  // Reset error status for Jobs after reporting brokenness.
-  ResetErrorStatusForJobs();
+      alt_service, request_info_.network_isolation_key);
 }
 
 void HttpStreamFactory::JobController::MaybeNotifyFactoryOfCompletion() {
-  if (!main_job_ && !alternative_job_) {
-    // Both jobs are gone, report brokenness if apply. Error status for Jobs
-    // will be reset after reporting to avoid redundant reporting.
-    MaybeReportBrokenAlternativeService();
-  }
+  if (main_job_ || alternative_job_ || dns_alpn_h3_job_)
+    return;
 
-  if (!request_ && !main_job_ && !alternative_job_) {
-    DCHECK(!bound_job_);
-    factory_->OnJobControllerComplete(this);
-  }
+  // All jobs are gone.
+  // Report brokenness for the alternate jobs if apply.
+  MaybeReportBrokenAlternativeService(
+      alternative_service_info_.alternative_service(),
+      alternative_job_net_error_, alternative_job_failed_on_default_network_,
+      "Net.AlternateServiceFailed");
+  // Report for the DNS alt job if apply.
+  MaybeReportBrokenAlternativeService(
+      GetAlternativeServiceForDnsJob(request_info_.url),
+      dns_alpn_h3_job_net_error_, dns_alpn_h3_job_failed_on_default_network_,
+      "Net.AlternateServiceForDnsAlpnH3Failed");
+
+  // Reset error status for Jobs after reporting brokenness to avoid redundant
+  // reporting.
+  ResetErrorStatusForJobs();
+
+  if (request_)
+    return;
+  DCHECK(!bound_job_);
+  factory_->OnJobControllerComplete(this);
 }
 
 void HttpStreamFactory::JobController::NotifyRequestFailed(int rv) {
@@ -1161,25 +1289,35 @@
 
 void HttpStreamFactory::JobController::ReportAlternateProtocolUsage(
     Job* job) const {
-  DCHECK(main_job_ && alternative_job_);
+  DCHECK((main_job_ && alternative_job_) || dns_alpn_h3_job_);
 
   bool is_google_host = HasGoogleHost(job->origin_url());
 
   if (job == main_job_.get()) {
-    HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_LOST_RACE,
+    HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
                                     is_google_host);
     return;
   }
+  if (job == alternative_job_.get()) {
+    if (job->using_existing_quic_session()) {
+      HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_NO_RACE,
+                                      is_google_host);
+      return;
+    }
 
-  DCHECK_EQ(alternative_job_.get(), job);
-  if (job->using_existing_quic_session()) {
-    HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_NO_RACE,
+    HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_WON_RACE,
                                     is_google_host);
-    return;
   }
-
-  HistogramAlternateProtocolUsage(ALTERNATE_PROTOCOL_USAGE_WON_RACE,
-                                  is_google_host);
+  if (job == dns_alpn_h3_job_.get()) {
+    if (job->using_existing_quic_session()) {
+      HistogramAlternateProtocolUsage(
+          ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE,
+          is_google_host);
+      return;
+    }
+    HistogramAlternateProtocolUsage(
+        ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, is_google_host);
+  }
 }
 
 bool HttpStreamFactory::JobController::IsJobOrphaned(Job* job) const {
@@ -1189,7 +1327,7 @@
 int HttpStreamFactory::JobController::ReconsiderProxyAfterError(Job* job,
                                                                 int error) {
   // ReconsiderProxyAfterError() should only be called when the last job fails.
-  DCHECK(!(alternative_job_ && main_job_));
+  DCHECK_EQ(1, GetJobCount());
   DCHECK(!proxy_resolve_request_);
   DCHECK(session_);
 
@@ -1213,6 +1351,7 @@
   // Abandon all Jobs and start over.
   job_bound_ = false;
   bound_job_ = nullptr;
+  dns_alpn_h3_job_.reset();
   alternative_job_.reset();
   main_job_.reset();
   ResetErrorStatusForJobs();
diff --git a/net/http/http_stream_factory_job_controller.h b/net/http/http_stream_factory_job_controller.h
index ec698c4e..5206db8 100644
--- a/net/http/http_stream_factory_job_controller.h
+++ b/net/http/http_stream_factory_job_controller.h
@@ -52,6 +52,7 @@
   // Used in tests only for verification purpose.
   const Job* main_job() const { return main_job_.get(); }
   const Job* alternative_job() const { return alternative_job_.get(); }
+  const Job* dns_alpn_h3_job() const { return dns_alpn_h3_job_.get(); }
 
   void RewriteUrlWithHostMappingRules(GURL& url);
 
@@ -185,10 +186,6 @@
   // still associated with |request_|.
   void BindJob(Job* job);
 
-  // Called when |request_| is destructed.
-  // Job(s) associated with but not bound to |request_| will be deleted.
-  void CancelJobs();
-
   // Called after BindJob() to notify the unbound job that its result should be
   // ignored by JobController. The unbound job can be canceled or continue until
   // completion.
@@ -200,15 +197,14 @@
   // Called when a Job succeeds.
   void OnJobSucceeded(Job* job);
 
+  // Clears inappropriate jobs before starting them.
+  void ClearInappropriateJobs();
+
   // Marks completion of the |request_|.
   void MarkRequestComplete(bool was_alpn_negotiated,
                            NextProto negotiated_protocol,
                            bool using_spdy);
 
-  // Must be called when the alternative service job fails. |net_error| is the
-  // net error of the failed alternative service job.
-  void OnAlternativeServiceJobFailed(int net_error);
-
   // Called when all Jobs complete. Reports alternative service brokenness to
   // HttpServerProperties if apply and resets net errors afterwards:
   // - report broken if the main job has no error and the alternative job has an
@@ -216,7 +212,11 @@
   // - report broken until default network change if the main job has no error,
   //   the alternative job has no error, but the alternative job failed on the
   //   default network.
-  void MaybeReportBrokenAlternativeService();
+  void MaybeReportBrokenAlternativeService(
+      const AlternativeService& alt_service,
+      int alt_job_net_error,
+      bool alt_job_failed_on_default_network,
+      const std::string& histogram_name_for_failure);
 
   void MaybeNotifyFactoryOfCompletion();
 
@@ -233,8 +233,10 @@
   void ResumeMainJob();
 
   // Reset error status to default value for Jobs:
-  // - reset |main_job_net_error_| and |alternative_job_net_error_| to OK;
-  // - reset |alternative_job_failed_on_default_network_| to false.
+  // - reset |main_job_net_error_| and |alternative_job_net_error_| and
+  //   |dns_alpn_h3_job_net_error_| to OK;
+  // - reset |alternative_job_failed_on_default_network_| and
+  //   |dns_alpn_h3_job_failed_on_default_network_| to false.
   void ResetErrorStatusForJobs();
 
   AlternativeServiceInfo GetAlternativeServiceInfoFor(
@@ -272,6 +274,11 @@
   // Returns true if QUIC is allowed for |host|.
   bool IsQuicAllowedForHost(const std::string& host);
 
+  int GetJobCount() const {
+    return (main_job_ ? 1 : 0) + (alternative_job_ ? 1 : 0) +
+           (dns_alpn_h3_job_ ? 1 : 0);
+  }
+
   raw_ptr<HttpStreamFactory> factory_;
   raw_ptr<HttpNetworkSession> session_;
   raw_ptr<JobFactory> job_factory_;
@@ -302,6 +309,7 @@
   // |main_job_| to proceed and then race the two jobs.
   std::unique_ptr<Job> main_job_;
   std::unique_ptr<Job> alternative_job_;
+  std::unique_ptr<Job> dns_alpn_h3_job_;
   // The alternative service used by |alternative_job_|
   // (or by |main_job_| if |is_preconnect_|.)
   AlternativeServiceInfo alternative_service_info_;
@@ -313,6 +321,10 @@
   int alternative_job_net_error_ = OK;
   // Set to true if the alternative job failed on the default network.
   bool alternative_job_failed_on_default_network_ = false;
+  // Net error code of the DNS HTTPS ALPN job. Set to OK by default.
+  int dns_alpn_h3_job_net_error_ = OK;
+  // Set to true if the DNS HTTPS ALPN job failed on the default network.
+  bool dns_alpn_h3_job_failed_on_default_network_ = false;
 
   // True if a Job has ever been bound to the |request_|.
   bool job_bound_ = false;
diff --git a/net/http/http_stream_factory_job_controller_unittest.cc b/net/http/http_stream_factory_job_controller_unittest.cc
index a8cc3a8..59f06e7 100644
--- a/net/http/http_stream_factory_job_controller_unittest.cc
+++ b/net/http/http_stream_factory_job_controller_unittest.cc
@@ -16,6 +16,7 @@
 #include "base/memory/scoped_refptr.h"
 #include "base/run_loop.h"
 #include "base/strings/stringprintf.h"
+#include "base/test/bind.h"
 #include "base/test/metrics/histogram_tester.h"
 #include "base/test/scoped_feature_list.h"
 #include "base/test/task_environment.h"
@@ -30,6 +31,7 @@
 #include "net/base/test_proxy_delegate.h"
 #include "net/dns/mock_host_resolver.h"
 #include "net/dns/public/secure_dns_policy.h"
+#include "net/http/alternative_service.h"
 #include "net/http/http_basic_stream.h"
 #include "net/http/http_network_session_peer.h"
 #include "net/http/http_response_headers.h"
@@ -46,9 +48,11 @@
 #include "net/proxy_resolution/mock_proxy_resolver.h"
 #include "net/proxy_resolution/proxy_config_service_fixed.h"
 #include "net/proxy_resolution/proxy_info.h"
+#include "net/quic/crypto/proof_verifier_chromium.h"
 #include "net/quic/mock_crypto_client_stream_factory.h"
 #include "net/quic/mock_quic_context.h"
 #include "net/quic/mock_quic_data.h"
+#include "net/quic/quic_http_stream.h"
 #include "net/quic/quic_stream_factory.h"
 #include "net/quic/quic_stream_factory_peer.h"
 #include "net/quic/quic_test_packet_maker.h"
@@ -79,6 +83,10 @@
 
 const char kServerHostname[] = "www.example.com";
 
+// The default delay for main job defined in QuicStreamFactory::
+// GetTimeDelayForWaitingJob().
+const int kDefaultDelayMilliSecsForWaitingJob = 300;
+
 class FailingProxyResolverFactory : public ProxyResolverFactory {
  public:
   FailingProxyResolverFactory() : ProxyResolverFactory(false) {}
@@ -173,13 +181,23 @@
     HttpStreamFactoryJobPeer::SetQuicConnectionFailedOnDefaultNetwork(
         job_controller->alternative_job_.get());
   }
+  static void SetDnsAlpnH3JobFailedOnDefaultNetwork(
+      HttpStreamFactory::JobController* job_controller) {
+    DCHECK(job_controller->dns_alpn_h3_job() != nullptr);
+    HttpStreamFactoryJobPeer::SetQuicConnectionFailedOnDefaultNetwork(
+        job_controller->dns_alpn_h3_job_.get());
+  }
 };
 
-class HttpStreamFactoryJobControllerTest : public TestWithTaskEnvironment {
+class HttpStreamFactoryJobControllerTestBase : public TestWithTaskEnvironment {
  public:
-  HttpStreamFactoryJobControllerTest()
+  explicit HttpStreamFactoryJobControllerTestBase(bool dns_https_alpn_enabled)
       : TestWithTaskEnvironment(
-            base::test::TaskEnvironment::TimeSource::MOCK_TIME) {
+            base::test::TaskEnvironment::TimeSource::MOCK_TIME),
+        dns_https_alpn_enabled_(dns_https_alpn_enabled) {
+    if (dns_https_alpn_enabled_) {
+      feature_list_.InitWithFeatures({features::kUseDnsHttpsSvcbAlpn}, {});
+    }
     FLAGS_quic_enable_http3_grease_randomness = false;
     CreateSessionDeps();
   }
@@ -228,6 +246,8 @@
 
     if (quic_data_)
       quic_data_->AddSocketDataToFactory(session_deps_.socket_factory.get());
+    if (quic_data2_)
+      quic_data2_->AddSocketDataToFactory(session_deps_.socket_factory.get());
     if (tcp_data_)
       session_deps_.socket_factory->AddSocketDataProvider(tcp_data_.get());
 
@@ -260,16 +280,20 @@
     return test_proxy_delegate_.get();
   }
 
-  HttpStreamFactoryJobControllerTest(
-      const HttpStreamFactoryJobControllerTest&) = delete;
-  HttpStreamFactoryJobControllerTest& operator=(
-      const HttpStreamFactoryJobControllerTest&) = delete;
+  HttpStreamFactoryJobControllerTestBase(
+      const HttpStreamFactoryJobControllerTestBase&) = delete;
+  HttpStreamFactoryJobControllerTestBase& operator=(
+      const HttpStreamFactoryJobControllerTestBase&) = delete;
 
-  ~HttpStreamFactoryJobControllerTest() override {
+  ~HttpStreamFactoryJobControllerTestBase() override {
     if (quic_data_) {
       EXPECT_TRUE(quic_data_->AllReadDataConsumed());
       EXPECT_TRUE(quic_data_->AllWriteDataConsumed());
     }
+    if (quic_data2_) {
+      EXPECT_TRUE(quic_data2_->AllReadDataConsumed());
+      EXPECT_TRUE(quic_data2_->AllWriteDataConsumed());
+    }
     if (tcp_data_) {
       EXPECT_TRUE(tcp_data_->AllReadDataConsumed());
       EXPECT_TRUE(tcp_data_->AllWriteDataConsumed());
@@ -325,6 +349,8 @@
       const quic::ParsedQuicVersion& expected_version,
       const quic::ParsedQuicVersionVector& supported_versions);
 
+  bool dns_https_alpn_enabled() const { return dns_https_alpn_enabled_; }
+
   quic::ParsedQuicVersion version_ = DefaultSupportedQuicVersions().front();
   RecordingNetLogObserver net_log_observer_;
   NetLogWithSource net_log_with_source_{
@@ -339,6 +365,7 @@
   std::unique_ptr<HttpStreamRequest> request_;
   std::unique_ptr<SequencedSocketData> tcp_data_;
   std::unique_ptr<MockQuicData> quic_data_;
+  std::unique_ptr<MockQuicData> quic_data2_;
   MockCryptoClientStreamFactory crypto_client_stream_factory_;
   QuicTestPacketMaker client_maker_{version_,
                                     quic::QuicUtils::CreateRandomConnectionId(
@@ -355,11 +382,26 @@
   bool delay_main_job_with_available_spdy_session_ = true;
 
  private:
+  bool dns_https_alpn_enabled_;
   std::unique_ptr<TestProxyDelegate> test_proxy_delegate_;
   bool create_job_controller_ = true;
+
+  base::test::ScopedFeatureList feature_list_;
 };
 
-TEST_F(HttpStreamFactoryJobControllerTest, ProxyResolutionFailsSync) {
+class HttpStreamFactoryJobControllerTest
+    : public HttpStreamFactoryJobControllerTestBase,
+      public ::testing::WithParamInterface<bool> {
+ protected:
+  HttpStreamFactoryJobControllerTest()
+      : HttpStreamFactoryJobControllerTestBase(GetParam()) {}
+};
+
+INSTANTIATE_TEST_SUITE_P(All,
+                         HttpStreamFactoryJobControllerTest,
+                         testing::Bool());
+
+TEST_P(HttpStreamFactoryJobControllerTest, ProxyResolutionFailsSync) {
   ProxyConfig proxy_config;
   proxy_config.set_pac_url(GURL("http://fooproxyurl"));
   proxy_config.set_pac_mandatory(true);
@@ -396,7 +438,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, ProxyResolutionFailsAsync) {
+TEST_P(HttpStreamFactoryJobControllerTest, ProxyResolutionFailsAsync) {
   ProxyConfig proxy_config;
   proxy_config.set_pac_url(GURL("http://fooproxyurl"));
   proxy_config.set_pac_mandatory(true);
@@ -437,7 +479,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, NoSupportedProxies) {
+TEST_P(HttpStreamFactoryJobControllerTest, NoSupportedProxies) {
   session_deps_.proxy_resolution_service =
       ConfiguredProxyResolutionService::CreateFixedFromPacResult(
           "QUIC myproxy.org:443", TRAFFIC_ANNOTATION_FOR_TESTS);
@@ -464,8 +506,10 @@
 }
 
 class JobControllerReconsiderProxyAfterErrorTest
-    : public HttpStreamFactoryJobControllerTest {
+    : public HttpStreamFactoryJobControllerTestBase {
  public:
+  JobControllerReconsiderProxyAfterErrorTest()
+      : HttpStreamFactoryJobControllerTestBase(false) {}
   void Initialize(
       std::unique_ptr<ProxyResolutionService> proxy_resolution_service) {
     session_deps_.proxy_resolution_service =
@@ -1131,7 +1175,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, OnStreamFailedWithNoAlternativeJob) {
+TEST_P(HttpStreamFactoryJobControllerTest, OnStreamFailedWithNoAlternativeJob) {
   tcp_data_ = std::make_unique<SequencedSocketData>();
   tcp_data_->set_connect_data(MockConnect(ASYNC, ERR_FAILED));
 
@@ -1155,7 +1199,7 @@
   base::RunLoop().RunUntilIdle();
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, OnStreamReadyWithNoAlternativeJob) {
+TEST_P(HttpStreamFactoryJobControllerTest, OnStreamReadyWithNoAlternativeJob) {
   tcp_data_ = std::make_unique<SequencedSocketData>();
   tcp_data_->set_connect_data(MockConnect(ASYNC, OK));
 
@@ -1179,7 +1223,7 @@
 
 // Test we cancel Jobs correctly when the Request is explicitly canceled
 // before any Job is bound to Request.
-TEST_F(HttpStreamFactoryJobControllerTest, CancelJobsBeforeBinding) {
+TEST_P(HttpStreamFactoryJobControllerTest, CancelJobsBeforeBinding) {
   // Use COLD_START to make the alt job pending.
   crypto_client_stream_factory_.set_handshake_mode(
       MockCryptoClientStream::COLD_START);
@@ -1214,7 +1258,7 @@
 // Test that the controller does not create alternative job when the advertised
 // versions in AlternativeServiceInfo do not contain any version that is
 // supported.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        DoNotCreateAltJobIfQuicVersionsUnsupported) {
   tcp_data_ = std::make_unique<SequencedSocketData>();
   tcp_data_->set_connect_data(MockConnect(ASYNC, OK));
@@ -1241,7 +1285,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        DoNotDelayMainJobIfQuicWasRecentlyBroken) {
   crypto_client_stream_factory_.set_handshake_mode(
       MockCryptoClientStream::COLD_START);
@@ -1299,7 +1343,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        DelayMainJobAfterRecentlyBrokenQuicWasConfirmed) {
   crypto_client_stream_factory_.set_handshake_mode(
       MockCryptoClientStream::COLD_START);
@@ -1363,7 +1407,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-void HttpStreamFactoryJobControllerTest::TestOnStreamFailedForBothJobs(
+void HttpStreamFactoryJobControllerTestBase::TestOnStreamFailedForBothJobs(
     bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddConnect(ASYNC, ERR_FAILED);
@@ -1402,20 +1446,21 @@
 
 // This test verifies that the alternative service is not marked broken if both
 // jobs fail, and the alternative job is not retried on the alternate network.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        OnStreamFailedForBothJobsWithoutQuicRetry) {
   TestOnStreamFailedForBothJobs(false);
 }
 
 // This test verifies that the alternative service is not marked broken if both
 // jobs fail, and the alternative job is retried on the alternate network.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        OnStreamFailedForBothJobsWithQuicRetriedOnAlternateNetwork) {
   TestOnStreamFailedForBothJobs(true);
 }
 
-void HttpStreamFactoryJobControllerTest::TestAltJobFailsAfterMainJobSucceeded(
-    bool alt_job_retried_on_non_default_network) {
+void HttpStreamFactoryJobControllerTestBase::
+    TestAltJobFailsAfterMainJobSucceeded(
+        bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(ASYNC, ERR_FAILED);
   crypto_client_stream_factory_.set_handshake_mode(
@@ -1470,7 +1515,7 @@
 // This test verifies that the alternatvie service is marked broken when the
 // alternative job fails on default after the main job succeeded.  The
 // brokenness should not be cleared when the default network changes.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobFailsOnDefaultNetworkAfterMainJobSucceeded) {
   TestAltJobFailsAfterMainJobSucceeded(false);
 }
@@ -1478,13 +1523,13 @@
 // This test verifies that the alternatvie service is marked broken when the
 // alternative job fails on both networks after the main job succeeded.  The
 // brokenness should not be cleared when the default network changes.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobFailsOnBothNetworksAfterMainJobSucceeded) {
   TestAltJobFailsAfterMainJobSucceeded(true);
 }
 
 // Tests that when alt job succeeds, main job is destroyed.
-TEST_F(HttpStreamFactoryJobControllerTest, AltJobSucceedsMainJobDestroyed) {
+TEST_P(HttpStreamFactoryJobControllerTest, AltJobSucceedsMainJobDestroyed) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
   // Use cold start and complete alt job manually.
@@ -1531,7 +1576,7 @@
 // Tests that if alt job succeeds and main job is blocked, main job should be
 // cancelled immediately. |request_| completion will clean up the JobController.
 // Regression test for crbug.com/678768.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobSucceedsMainJobBlockedControllerDestroyed) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   if (version_.UsesHttp3()) {
@@ -1572,7 +1617,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        SpdySessionKeyHasOriginHostPortPair) {
   session_deps_.enable_http2_alternative_service = true;
 
@@ -1612,7 +1657,7 @@
 
 // Tests that if an orphaned job completes after |request_| is gone,
 // JobController will be cleaned up.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        OrphanedJobCompletesControllerDestroyed) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
@@ -1666,8 +1711,9 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-void HttpStreamFactoryJobControllerTest::TestAltJobSucceedsAfterMainJobFailed(
-    bool alt_job_retried_on_non_default_network) {
+void HttpStreamFactoryJobControllerTestBase::
+    TestAltJobSucceedsAfterMainJobFailed(
+        bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
   // Use cold start and complete alt job manually.
@@ -1721,19 +1767,19 @@
 
 // This test verifies that the alternative service is not mark broken if the
 // alternative job succeeds on the default network after the main job failed.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobSucceedsOnDefaultNetworkAfterMainJobFailed) {
   TestAltJobSucceedsAfterMainJobFailed(false);
 }
 
 // This test verifies that the alternative service is not mark broken if the
 // alternative job succeeds on the alternate network after the main job failed.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobSucceedsOnAlternateNetwrokAfterMainJobFailed) {
   TestAltJobSucceedsAfterMainJobFailed(true);
 }
 
-void HttpStreamFactoryJobControllerTest::
+void HttpStreamFactoryJobControllerTestBase::
     TestAltJobSucceedsAfterMainJobSucceeded(
         bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
@@ -1801,7 +1847,7 @@
 
 // This test verifies that the alternative service is not marked broken if the
 // alternative job succeeds on the default network after the main job succeeded.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobSucceedsOnDefaultNetworkAfterMainJobSucceeded) {
   TestAltJobSucceedsAfterMainJobSucceeded(false);
 }
@@ -1811,12 +1857,12 @@
 // network, which failed on the default network previously, after the main job
 // succeeded.  The brokenness should be cleared when the default network
 // changes.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltJobSucceedsOnAlternateNetworkAfterMainJobSucceeded) {
   TestAltJobSucceedsAfterMainJobSucceeded(true);
 }
 
-void HttpStreamFactoryJobControllerTest::
+void HttpStreamFactoryJobControllerTestBase::
     TestMainJobSucceedsAfterAltJobSucceeded(
         bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
@@ -1878,7 +1924,7 @@
 
 // This test verifies that the alternative service is not marked broken if the
 // main job succeeds after the alternative job succeeded on the default network.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterAltJobSucceededOnDefaultNetwork) {
   TestMainJobSucceedsAfterAltJobSucceeded(false);
 }
@@ -1888,13 +1934,14 @@
 // succeeded on the non-default network, i.e., failed on the default network
 // previously.  The brokenness should be cleared when the default network
 // changes.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterAltJobSucceededOnAlternateNetwork) {
   TestMainJobSucceedsAfterAltJobSucceeded(true);
 }
 
-void HttpStreamFactoryJobControllerTest::TestMainJobFailsAfterAltJobSucceeded(
-    bool alt_job_retried_on_non_default_network) {
+void HttpStreamFactoryJobControllerTestBase::
+    TestMainJobFailsAfterAltJobSucceeded(
+        bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
   // Use cold start and complete alt job manually.
@@ -1943,7 +1990,7 @@
 
 // This test verifies that the alternative service is not marked broken if the
 // main job fails after the alternative job succeeded on the default network.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobFailsAfterAltJobSucceededOnDefaultNetwork) {
   TestMainJobFailsAfterAltJobSucceeded(false);
 }
@@ -1951,13 +1998,14 @@
 // This test verifies that the alternative service is not marked broken if the
 // main job fails after the alternative job succeeded on the non-default
 // network, i.e., failed on the default network previously.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobFailsAfterAltJobSucceededOnAlternateNetwork) {
   TestMainJobFailsAfterAltJobSucceeded(true);
 }
 
-void HttpStreamFactoryJobControllerTest::TestMainJobSucceedsAfterAltJobFailed(
-    bool alt_job_retried_on_non_default_network) {
+void HttpStreamFactoryJobControllerTestBase::
+    TestMainJobSucceedsAfterAltJobFailed(
+        bool alt_job_retried_on_non_default_network) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddConnect(SYNCHRONOUS, ERR_FAILED);
 
@@ -2009,7 +2057,7 @@
 
 // This test verifies that the alternative service will be marked broken when
 // the alternative job fails on the default network and main job succeeds later.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterAltJobFailedOnDefaultNetwork) {
   TestMainJobSucceedsAfterAltJobFailed(false);
 }
@@ -2017,15 +2065,15 @@
 // This test verifies that the alternative service will be marked broken when
 // the alternative job fails on both default and alternate networks and main job
 // succeeds later.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterAltJobFailedOnBothNetworks) {
   TestMainJobSucceedsAfterAltJobFailed(true);
 }
 
-void HttpStreamFactoryJobControllerTest::TestMainJobSucceedsAfterIgnoredError(
-    int net_error,
-    bool expect_broken,
-    std::string alternate_host) {
+void HttpStreamFactoryJobControllerTestBase::
+    TestMainJobSucceedsAfterIgnoredError(int net_error,
+                                         bool expect_broken,
+                                         std::string alternate_host) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddConnect(SYNCHRONOUS, net_error);
   tcp_data_ = std::make_unique<SequencedSocketData>();
@@ -2071,27 +2119,27 @@
 
 // Verifies that if the alternative job fails due to a connection change event,
 // then the alternative service is not marked as broken.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterConnectionChanged) {
   TestMainJobSucceedsAfterIgnoredError(ERR_NETWORK_CHANGED);
 }
 
 // Verifies that if the alternative job fails due to a disconnected network,
 // then the alternative service is not marked as broken.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterInternetDisconnected) {
   TestMainJobSucceedsAfterIgnoredError(ERR_INTERNET_DISCONNECTED);
 }
 
 // Verifies that if the alternative job fails due to a DNS failure,
 // then the alternative service is not marked as broken.
-TEST_F(HttpStreamFactoryJobControllerTest, MainJobSucceedsAfterDnsFailure) {
+TEST_P(HttpStreamFactoryJobControllerTest, MainJobSucceedsAfterDnsFailure) {
   TestMainJobSucceedsAfterIgnoredError(ERR_NAME_NOT_RESOLVED);
 }
 
 // Verifies that if the alternative job fails due to a DNS failure on a
 // different name, then the alternative service is marked as broken.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        MainJobSucceedsAfterDnsFailureWithAlternateName) {
   TestMainJobSucceedsAfterIgnoredError(ERR_NAME_NOT_RESOLVED, true,
                                        "alternate.google.com");
@@ -2099,7 +2147,7 @@
 
 // Regression test for crbug/621069.
 // Get load state after main job fails and before alternative job succeeds.
-TEST_F(HttpStreamFactoryJobControllerTest, GetLoadStateAfterMainJobFailed) {
+TEST_P(HttpStreamFactoryJobControllerTest, GetLoadStateAfterMainJobFailed) {
   // Use COLD_START to complete alt job manually.
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
@@ -2146,7 +2194,7 @@
   EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, ResumeMainJobWhenAltJobStalls) {
+TEST_P(HttpStreamFactoryJobControllerTest, ResumeMainJobWhenAltJobStalls) {
   // Use COLD_START to stall alt job.
   quic_data_ = std::make_unique<MockQuicData>(version_);
   quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
@@ -2179,7 +2227,7 @@
   base::RunLoop().RunUntilIdle();
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, InvalidPortForQuic) {
+TEST_P(HttpStreamFactoryJobControllerTest, InvalidPortForQuic) {
   HttpRequestInfo request_info;
   request_info.method = "GET";
   request_info.url = GURL("https://www.google.com");
@@ -2205,7 +2253,7 @@
 
 // Verifies that the main job is not resumed until after the alt job completes
 // host resolution.
-TEST_F(HttpStreamFactoryJobControllerTest, HostResolutionHang) {
+TEST_P(HttpStreamFactoryJobControllerTest, HostResolutionHang) {
   auto hanging_resolver = std::make_unique<MockHostResolver>();
   hanging_resolver->set_ondemand_mode(true);
   hanging_resolver->rules()->AddRule("www.google.com", "1.2.3.4");
@@ -2277,13 +2325,13 @@
   // OnStreamFailed will post a task to resume the main job immediately but
   // won't call Resume() on the main job since it's been resumed already.
   EXPECT_CALL(*job_factory_.main_job(), Resume()).Times(0);
-  quic_data.GetSequencedSocketData()->Resume();
+  quic_data.Resume();
   FastForwardUntilNoTasksRemain();
   // Alt job should be cleaned up
   EXPECT_FALSE(job_controller_->alternative_job());
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, DelayedTCP) {
+TEST_P(HttpStreamFactoryJobControllerTest, DelayedTCP) {
   HttpRequestInfo request_info;
   request_info.method = "GET";
   request_info.url = GURL("https://www.google.com");
@@ -2338,13 +2386,13 @@
 
   // Unpause mock quic data and run all remaining tasks. Alt-job should fail
   // and be cleaned up.
-  quic_data.GetSequencedSocketData()->Resume();
+  quic_data.Resume();
   FastForwardUntilNoTasksRemain();
   EXPECT_FALSE(job_controller_->alternative_job());
 }
 
 // Regression test for crbug.com/789560.
-TEST_F(HttpStreamFactoryJobControllerTest, ResumeMainJobLaterCanceled) {
+TEST_P(HttpStreamFactoryJobControllerTest, ResumeMainJobLaterCanceled) {
   std::unique_ptr<ConfiguredProxyResolutionService> proxy_resolution_service =
       ConfiguredProxyResolutionService::CreateDirect();
   ConfiguredProxyResolutionService* proxy_resolution_service_raw =
@@ -2422,7 +2470,7 @@
 // http_server_properties cached an inappropriate large srtt for the server,
 // which would potentially delay the main job for a extremely long time in
 // delayed tcp case.
-TEST_F(HttpStreamFactoryJobControllerTest, DelayedTCPWithLargeSrtt) {
+TEST_P(HttpStreamFactoryJobControllerTest, DelayedTCPWithLargeSrtt) {
   // The max delay time should be in sync with .cc file.
   base::TimeDelta kMaxDelayTimeForMainJob = base::Seconds(3);
 
@@ -2479,14 +2527,14 @@
 
   // Unpause mock quic data and run all remaining tasks. Alt-job  should fail
   // and be cleaned up.
-  quic_data.GetSequencedSocketData()->Resume();
+  quic_data.Resume();
   FastForwardUntilNoTasksRemain();
   EXPECT_FALSE(job_controller_->alternative_job());
 }
 
 // TODO(https://crbug.com/1007502): Disabled because the pending task count does
 //                                  not match expectations.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        DISABLED_ResumeMainJobImmediatelyOnStreamFailed) {
   HttpRequestInfo request_info;
   request_info.method = "GET";
@@ -2538,7 +2586,7 @@
   // Now unpause the mock quic data to fail the alt job. This should immediately
   // resume the main job.
   EXPECT_CALL(*job_factory_.main_job(), Resume()).Times(1);
-  quic_data.GetSequencedSocketData()->Resume();
+  quic_data.Resume();
   FastForwardBy(base::TimeDelta());
 
   EXPECT_TRUE(job_controller_->main_job());
@@ -2554,7 +2602,7 @@
   FastForwardUntilNoTasksRemain();
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest, PreconnectToHostWithValidAltSvc) {
+TEST_P(HttpStreamFactoryJobControllerTest, PreconnectToHostWithValidAltSvc) {
   quic_data_ = std::make_unique<MockQuicData>(version_);
   if (version_.UsesHttp3()) {
     quic_data_->AddWrite(SYNCHRONOUS,
@@ -2584,7 +2632,7 @@
 }
 
 // When preconnect to a H2 supported server, only 1 connection is opened.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        PreconnectMultipleStreamsToH2Server) {
   tcp_data_ = std::make_unique<SequencedSocketData>();
   tcp_data_->set_connect_data(MockConnect(ASYNC, OK));
@@ -2616,7 +2664,7 @@
 
 // Check that the logic to only preconnect a single socket to servers with H2
 // support respects NetworkIsolationKeys.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        PreconnectMultipleStreamsToH2ServerWithNetworkIsolationKey) {
   base::test::ScopedFeatureList feature_list;
   // It's not strictly necessary to enable
@@ -2704,7 +2752,7 @@
   }
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        DonotDelayMainJobIfHasAvailableSpdySession) {
   SetNotDelayMainJobWithAvailableSpdySession();
   HttpRequestInfo request_info;
@@ -2758,7 +2806,7 @@
 
 // Check the case that while a preconnect is waiting in the H2 request queue,
 // and a SPDY session appears, the job completes successfully.
-TEST_F(HttpStreamFactoryJobControllerTest, SpdySessionInterruptsPreconnect) {
+TEST_P(HttpStreamFactoryJobControllerTest, SpdySessionInterruptsPreconnect) {
   // Make sure there is only one socket connect.
   MockWrite writes[] = {MockWrite(SYNCHRONOUS, ERR_IO_PENDING, 0)};
   MockRead reads[] = {MockRead(SYNCHRONOUS, ERR_IO_PENDING, 1)};
@@ -2832,7 +2880,7 @@
 //       OnConnectComplete() is called in the end of the test.
 //   [3] Normal non-preconnect request to other.example.org. This request must
 //       succeed even while the preconnect request [2] is paused.
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        PreconnectJobDoesntBlockIpBasedPooling) {
   // Make sure that both "www.example.org" and "other.example.org" are pointing
   // to the same IP address.
@@ -2879,6 +2927,11 @@
         &request_delegate_,
         /*websocket_handshake_stream_create_helper=*/nullptr,
         NetLogWithSource(), HttpStreamRequest::HTTP_STREAM, DEFAULT_PRIORITY);
+    if (dns_https_alpn_enabled()) {
+      EXPECT_CALL(*job_factory_.main_job(), Resume())
+          .Times(1)
+          .WillOnce([this]() { job_factory_.main_job()->DoResume(); });
+    }
     base::RunLoop run_loop;
     EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
         .WillOnce([&run_loop]() { run_loop.Quit(); });
@@ -2953,6 +3006,11 @@
             NetLogWithSource(), HttpStreamRequest::HTTP_STREAM,
             DEFAULT_PRIORITY);
 
+    if (dns_https_alpn_enabled()) {
+      EXPECT_CALL(*job_factory_.main_job(), Resume())
+          .Times(1)
+          .WillOnce([this]() { job_factory_.main_job()->DoResume(); });
+    }
     base::RunLoop run_loop;
     EXPECT_CALL(request_delegate, OnStreamReadyImpl(_, _, _))
         .WillOnce([&run_loop]() { run_loop.Quit(); });
@@ -2970,8 +3028,10 @@
 }
 
 class JobControllerLimitMultipleH2Requests
-    : public HttpStreamFactoryJobControllerTest {
+    : public HttpStreamFactoryJobControllerTestBase {
  protected:
+  JobControllerLimitMultipleH2Requests()
+      : HttpStreamFactoryJobControllerTestBase(false) {}
   const int kNumRequests = 5;
   void SetUp() override { SkipCreatingJobController(); }
 };
@@ -3432,8 +3492,12 @@
 }
 
 class HttpStreamFactoryJobControllerMisdirectedRequestRetry
-    : public HttpStreamFactoryJobControllerTest,
-      public ::testing::WithParamInterface<::testing::tuple<bool, bool>> {};
+    : public HttpStreamFactoryJobControllerTestBase,
+      public ::testing::WithParamInterface<::testing::tuple<bool, bool>> {
+ public:
+  HttpStreamFactoryJobControllerMisdirectedRequestRetry()
+      : HttpStreamFactoryJobControllerTestBase(false) {}
+};
 
 INSTANTIATE_TEST_SUITE_P(
     All,
@@ -3489,9 +3553,12 @@
 }
 
 class HttpStreamFactoryJobControllerPreconnectTest
-    : public HttpStreamFactoryJobControllerTest,
+    : public HttpStreamFactoryJobControllerTestBase,
       public ::testing::WithParamInterface<bool> {
  protected:
+  HttpStreamFactoryJobControllerPreconnectTest()
+      : HttpStreamFactoryJobControllerTestBase(false) {}
+
   void SetUp() override {
     if (!GetParam()) {
       scoped_feature_list_.InitFromCommandLine(std::string(),
@@ -3562,7 +3629,7 @@
 // Test that GetAlternativeServiceInfoFor will include a list of advertised
 // versions, which contains a version that is supported. Returns an empty list
 // if advertised versions are missing in HttpServerProperties.
-TEST_F(HttpStreamFactoryJobControllerTest, GetAlternativeServiceInfoFor) {
+TEST_P(HttpStreamFactoryJobControllerTest, GetAlternativeServiceInfoFor) {
   HttpRequestInfo request_info;
   request_info.method = "GET";
   request_info.url = GURL("https://www.google.com");
@@ -3656,7 +3723,7 @@
   EXPECT_EQ(0u, alt_svc_info.advertised_versions().size());
 }
 
-void HttpStreamFactoryJobControllerTest::TestAltSvcVersionSelection(
+void HttpStreamFactoryJobControllerTestBase::TestAltSvcVersionSelection(
     const std::string& alt_svc_header,
     const quic::ParsedQuicVersion& expected_version,
     const quic::ParsedQuicVersionVector& supported_versions) {
@@ -3689,7 +3756,7 @@
       << quic::ParsedQuicVersionVectorToString(advertised_versions);
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltSvcVersionSelectionFindsFirstMatch) {
   TestAltSvcVersionSelection(
       "h3-Q050=\":443\"; ma=2592000,"
@@ -3700,7 +3767,7 @@
       quic::ParsedQuicVersion::Q050(), quic::AllSupportedVersions());
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltSvcVersionSelectionFindsFirstMatchInverse) {
   TestAltSvcVersionSelection(
       "h3-Q043=\":443\"; ma=2592000,"
@@ -3710,7 +3777,7 @@
       quic::ParsedQuicVersion::Q043(), quic::AllSupportedVersions());
 }
 
-TEST_F(HttpStreamFactoryJobControllerTest,
+TEST_P(HttpStreamFactoryJobControllerTest,
        AltSvcVersionSelectionWithInverseOrderingNewFormat) {
   // Server prefers Q043 but client prefers Q046.
   TestAltSvcVersionSelection(
@@ -3724,7 +3791,7 @@
 // Tests that if HttpNetworkSession has a non-empty QUIC host allowlist,
 // then GetAlternativeServiceFor() will not return any QUIC alternative service
 // that's not on the allowlist.
-TEST_F(HttpStreamFactoryJobControllerTest, QuicHostAllowlist) {
+TEST_P(HttpStreamFactoryJobControllerTest, QuicHostAllowlist) {
   HttpRequestInfo request_info;
   request_info.method = "GET";
   request_info.url = GURL("https://www.google.com");
@@ -3779,4 +3846,1017 @@
   EXPECT_EQ(0u, alt_svc_info.advertised_versions().size());
 }
 
+// Tests specific to UseDnsHttpsAlpn feature.
+class HttpStreamFactoryJobControllerDnsHttpsAlpnTest
+    : public HttpStreamFactoryJobControllerTestBase {
+ protected:
+  HttpStreamFactoryJobControllerDnsHttpsAlpnTest()
+      : HttpStreamFactoryJobControllerTestBase(true) {}
+
+  void SetUp() override { SkipCreatingJobController(); }
+
+  void EnableOndemandHostResolver() {
+    session_deps_.host_resolver->set_synchronous_mode(false);
+    session_deps_.host_resolver->set_ondemand_mode(true);
+  }
+
+  HttpRequestInfo CreateTestHttpRequestInfo() {
+    HttpRequestInfo request_info;
+    request_info.method = "GET";
+    request_info.url = GURL("https://www.example.org");
+    return request_info;
+  }
+
+  void RegisterMockHttpsRecord() {
+    HostResolverEndpointResult endpoint_result1;
+    endpoint_result1.ip_endpoints = {IPEndPoint(IPAddress::IPv4Localhost(), 0)};
+    endpoint_result1.metadata.supported_protocol_alpns = {
+        quic::QuicVersionLabelToString(quic::CreateQuicVersionLabel(version_))};
+
+    HostResolverEndpointResult endpoint_result2;
+    endpoint_result2.ip_endpoints = {IPEndPoint(IPAddress::IPv4Localhost(), 0)};
+
+    std::vector<HostResolverEndpointResult> endpoints;
+    endpoints.push_back(endpoint_result1);
+    endpoints.push_back(endpoint_result2);
+    session_deps_.host_resolver->rules()->AddRule("www.example.org",
+                                                  std::move(endpoints));
+  }
+
+  std::unique_ptr<HttpStreamRequest> CreateJobControllerAndStart(
+      const HttpRequestInfo& request_info) {
+    job_controller_ = new HttpStreamFactory::JobController(
+        factory_, &request_delegate_, session_.get(), &default_job_factory_,
+        request_info, is_preconnect_, false /* is_websocket */,
+        enable_ip_based_pooling_, enable_alternative_services_,
+        delay_main_job_with_available_spdy_session_, SSLConfig(), SSLConfig());
+    HttpStreamFactoryPeer::AddJobController(factory_, job_controller_);
+    return job_controller_->Start(
+        &request_delegate_, nullptr, net_log_with_source_,
+        HttpStreamRequest::HTTP_STREAM, DEFAULT_PRIORITY);
+  }
+
+  void PrepareForMainJob() {
+    tcp_data_ = std::make_unique<SequencedSocketData>();
+    tcp_data_->set_connect_data(MockConnect(ASYNC, ERR_IO_PENDING)); /* pause */
+    ssl_data_ = std::make_unique<SSLSocketDataProvider>(ASYNC, OK);
+    session_deps_.socket_factory->AddSSLSocketDataProvider(ssl_data_.get());
+  }
+
+  void PrepareForFirstQuicJob() {
+    crypto_client_stream_factory_.set_handshake_mode(
+        MockCryptoClientStream::COLD_START);
+    quic_data_ = std::make_unique<MockQuicData>(version_);
+    quic_data_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
+    if (version_.UsesHttp3()) {
+      quic_data_->AddWrite(
+          SYNCHRONOUS,
+          CreateQuicTestPacketMakerForClient().MakeInitialSettingsPacket(1));
+    }
+  }
+  void PrepareForFirstQuicJobFailure() {
+    crypto_client_stream_factory_.set_handshake_mode(
+        MockCryptoClientStream::COLD_START);
+    quic_data_ = std::make_unique<MockQuicData>(version_);
+    quic_data_->AddRead(ASYNC, ERR_IO_PENDING);  // Pause
+    quic_data_->AddRead(ASYNC, ERR_FAILED);
+  }
+
+  void PrepareForSecondQuicJob() {
+    quic_data2_ = std::make_unique<MockQuicData>(version_);
+    quic_data2_->AddRead(SYNCHRONOUS, ERR_IO_PENDING);
+    if (version_.UsesHttp3()) {
+      quic_data2_->AddWrite(
+          SYNCHRONOUS,
+          CreateQuicTestPacketMakerForClient().MakeInitialSettingsPacket(1));
+    }
+  }
+
+  void MakeMainJobSucceed(bool expect_stream_ready) {
+    if (expect_stream_ready) {
+      base::RunLoop run_loop;
+      EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+          .Times(1)
+          .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+      tcp_data_->socket()->OnConnectComplete(MockConnect());
+      run_loop.Run();
+    } else {
+      EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _)).Times(0);
+      tcp_data_->socket()->OnConnectComplete(MockConnect());
+      base::RunLoop().RunUntilIdle();
+    }
+  }
+
+  void MakeQuicJobScceed(size_t index, bool expect_stream_ready) {
+    ASSERT_GT(crypto_client_stream_factory_.streams().size(), index);
+    MockCryptoClientStream* stream =
+        crypto_client_stream_factory_.streams()[index].get();
+    ASSERT_TRUE(stream);
+
+    if (expect_stream_ready) {
+      base::RunLoop run_loop;
+      EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+          .Times(1)
+          .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+      stream->NotifySessionOneRttKeyAvailable();
+      run_loop.Run();
+    } else {
+      EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _)).Times(0);
+      stream->NotifySessionOneRttKeyAvailable();
+      base::RunLoop().RunUntilIdle();
+    }
+  }
+
+  void CheckJobsStatus(bool main_job_exists,
+                       bool alternative_job_exists,
+                       bool dns_alpn_h3_job_exists,
+                       const std::string& scoped_trace_message = "") {
+    SCOPED_TRACE(scoped_trace_message);
+    EXPECT_EQ(main_job_exists, !!job_controller_->main_job());
+    EXPECT_EQ(alternative_job_exists, !!job_controller_->alternative_job());
+    EXPECT_EQ(dns_alpn_h3_job_exists, !!job_controller_->dns_alpn_h3_job());
+  }
+
+  std::unique_ptr<QuicHttpStream> ConnectQuicHttpStream(
+      bool alt_destination,
+      bool require_dns_https_alpn) {
+    NetErrorDetails net_error_details;
+    QuicStreamRequest quic_request(session_->quic_stream_factory());
+    url::SchemeHostPort scheme_host_port(
+        url::kHttpsScheme,
+        alt_destination ? "alt.example.org" : "www.example.org", 443);
+    absl::optional<int> quic_request_result;
+
+    CHECK_EQ(ERR_IO_PENDING,
+             quic_request.Request(
+                 scheme_host_port,
+                 require_dns_https_alpn ? quic::ParsedQuicVersion::Unsupported()
+                                        : version_,
+                 PRIVACY_MODE_DISABLED, DEFAULT_PRIORITY, SocketTag(),
+                 NetworkIsolationKey(), SecureDnsPolicy::kAllow,
+                 /*use_dns_aliases=*/true, require_dns_https_alpn,
+                 /*cert_verify_flags=*/0, GURL("https://www.example.org/"),
+                 net_log_with_source_, &net_error_details,
+                 base::BindLambdaForTesting([&](int result) {}),
+                 base::BindLambdaForTesting([&quic_request_result](int result) {
+                   quic_request_result = result;
+                 })));
+    CHECK_EQ(1u, crypto_client_stream_factory_.streams().size());
+    CHECK(crypto_client_stream_factory_.streams()[0]);
+    crypto_client_stream_factory_.streams()[0]
+        ->NotifySessionOneRttKeyAvailable();
+    base::RunLoop().RunUntilIdle();
+    CHECK(quic_request_result);
+    CHECK_EQ(OK, *quic_request_result);
+
+    std::unique_ptr<QuicChromiumClientSession::Handle> session =
+        quic_request.ReleaseSessionHandle();
+    std::set<std::string> dns_aliases =
+        session->GetDnsAliasesForSessionKey(quic_request.session_key());
+    auto stream = std::make_unique<QuicHttpStream>(std::move(session),
+                                                   std::move(dns_aliases));
+    return stream;
+  }
+
+  bool IsAlternativeServiceBroken(GURL& url) {
+    return session_->http_server_properties()->IsAlternativeServiceBroken(
+        AlternativeService(kProtoQUIC, HostPortPair::FromURL(url)),
+        NetworkIsolationKey());
+  }
+
+ private:
+  QuicTestPacketMaker CreateQuicTestPacketMakerForClient() {
+    return QuicTestPacketMaker(version_,
+                               quic::QuicUtils::CreateRandomConnectionId(
+                                   quic_context_.random_generator()),
+                               quic_context_.clock(), "www.example.org",
+                               quic::Perspective::IS_CLIENT, false);
+  }
+
+  // Use real Jobs so that Job::Resume() is not mocked out. When main job is
+  // resumed it will use mock socket data.
+  HttpStreamFactory::JobFactory default_job_factory_;
+
+  // Used for man job connection.
+  std::unique_ptr<SSLSocketDataProvider> ssl_data_;
+};
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       NoHttpsRecordSyncHostResolve) {
+  PrepareForMainJob();
+  Initialize(HttpRequestInfo());
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  // The main job should be synchronously resumed, as host is resolved
+  // synchronously.
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  base::RunLoop().RunUntilIdle();
+
+  // |dns_alpn_h3_job| must fail when there is no valid supported alpn. And
+  // must be deleted.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS ALPN job must be deleted.");
+
+  base::HistogramTester histogram_tester;
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  // Net.AlternateProtocolUsage must not record anything, when HTTPS record with
+  // alpn is not available.
+  histogram_tester.ExpectTotalCount("Net.AlternateProtocolUsage", 0);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       NoHttpsRecordAsyncHostResolveResumeMainWithoutDelay) {
+  EnableOndemandHostResolver();
+  PrepareForMainJob();
+  Initialize(HttpRequestInfo());
+
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  // The main job should be resumed quickly after resolving the host.
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+
+  // Resolve the host resolve request from |dns_alpn_h3_job|.
+  session_deps_.host_resolver->ResolveAllPending();
+  base::RunLoop().RunUntilIdle();
+
+  // |dns_alpn_h3_job| must fail when there is no valid supported alpn. And
+  // must be deleted.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS ALPN job must be deleted.");
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  // The host resolve request from the main job must be resolved using the
+  // cached result.
+  EXPECT_TRUE(tcp_data_->socket());
+
+  base::HistogramTester histogram_tester;
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  // Net.AlternateProtocolUsage must not record anything, when HTTPS record with
+  // alpn is not available.
+  histogram_tester.ExpectTotalCount("Net.AlternateProtocolUsage", 0);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       NoHttpsRecordAsyncHostResolveResumeMainWithoutDelayQuicWorkedNetwork) {
+  EnableOndemandHostResolver();
+  PrepareForMainJob();
+  Initialize(HttpRequestInfo());
+
+  QuicStreamFactory* quic_stream_factory = session_->quic_stream_factory();
+  quic_stream_factory->set_is_quic_known_to_work_on_current_network(true);
+
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+  // Main job must be waiting.
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+
+  // Resolve the host resolve request from |dns_alpn_h3_job|.
+  session_deps_.host_resolver->ResolveAllPending();
+  base::RunLoop().RunUntilIdle();
+
+  // |dns_alpn_h3_job| must fail when there is no valid supported alpn. And
+  // must be deleted.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS ALPN job must be deleted.");
+  // The main job should be resumed quickly after resolving the host.
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  // The host resolve request from the main job must be resolved using the
+  // cached result.
+  EXPECT_TRUE(tcp_data_->socket());
+
+  base::HistogramTester histogram_tester;
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  // Net.AlternateProtocolUsage must not record anything, when HTTPS record with
+  // alpn is not available.
+  histogram_tester.ExpectTotalCount("Net.AlternateProtocolUsage", 0);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       MainJobNoDelayOnQuicNotWorkedNetworkSyncHostResolve) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+  // |main_job| is not blocked, because the hostname is resolved synchronously
+  // and |is_quic_known_to_work_on_current_network| is false for this test.
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // The success of |dns_alpn_h3_job| deletes |main_job|.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Main job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       MainJobNoDelayOnQuicNotWorkedNetworkAsyncHostResolve) {
+  EnableOndemandHostResolver();
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  // |main_job| is blocked until host resolves.
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+  base::RunLoop().RunUntilIdle();
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+
+  // Resolve the host resolve request from |dns_alpn_h3_job|.
+  session_deps_.host_resolver->ResolveAllPending();
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+  base::RunLoop().RunUntilIdle();
+
+  // |main_job| should have been resumed quickly because
+  // |is_quic_known_to_work_on_current_network| is false for this test.
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+  // |dns_alpn_h3_job| must not fail when there is a valid supported alpn.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Both main job and DNS ALPN job must be alive");
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // The success of |dns_alpn_h3_job| deletes |main_job|.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Main job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       MainJobDelayOnQuicWorkedNetwork) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  QuicStreamFactory* quic_stream_factory = session_->quic_stream_factory();
+  quic_stream_factory->set_is_quic_known_to_work_on_current_network(true);
+
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+  base::RunLoop().RunUntilIdle();
+  // |dns_alpn_h3_job| must not fail when there is a valid supported alpn.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Both main job and DNS ALPN job must be alive");
+
+  // The main job should be waiting until kDefaultDelayMilliSecsForWaitingJob
+  // amount of time has passed.
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+  FastForwardBy(base::Milliseconds(kDefaultDelayMilliSecsForWaitingJob - 1));
+  EXPECT_TRUE(job_controller_->main_job()->is_waiting());
+  FastForwardBy(base::Milliseconds(1));
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // The success of |dns_alpn_h3_job| deletes |main_job|.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Main job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       MainJobSucceedsDnsAlpnH3JobSucceeds) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+  base::RunLoop().RunUntilIdle();
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+  // |main_job| is not blocked, because the hostname is resolved synchronously
+  // and |is_quic_known_to_work_on_current_network| is false for this test.
+  EXPECT_FALSE(job_controller_->main_job()->is_waiting());
+
+  base::HistogramTester histogram_tester;
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage", ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
+      1);
+
+  // The success of |main_job| doesn't delete |dns_alpn_h3_job|.
+  EXPECT_TRUE(job_controller_->dns_alpn_h3_job());
+
+  // Make |dns_alpn_h3_job| complete.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       ActiveSessionAvailableForMainJob) {
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+  PrepareForFirstQuicJob();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  // Put a SpdySession in the pool.
+  SpdySessionKey key(HostPortPair::FromURL(request_info.url),
+                     ProxyServer::Direct(), PRIVACY_MODE_DISABLED,
+                     SpdySessionKey::IsProxySession::kFalse, SocketTag(),
+                     NetworkIsolationKey(), SecureDnsPolicy::kAllow);
+  std::ignore = CreateFakeSpdySession(session_->spdy_session_pool(), key);
+
+  request_ = CreateJobControllerAndStart(request_info);
+  // |dns_alpn_h3_job| must be created even when an active session is
+  // available for |main_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  base::HistogramTester histogram_tester;
+  // Run the message loop to make |main_job| succeed and status will be
+  // reported to Request.
+  {
+    base::RunLoop run_loop;
+    EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+        .Times(1)
+        .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+    run_loop.Run();
+  }
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage", ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
+      1);
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "DNS ALPN job must be alive");
+
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS ALPN job must be deleted");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       ActiveSessionAvailableForAltSvcJob) {
+  PrepareForMainJob();
+  RegisterMockHttpsRecord();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  PrepareForFirstQuicJob();
+
+  Initialize(HttpRequestInfo());
+
+  auto stream = ConnectQuicHttpStream(/*alt_destination=*/true,
+                                      /*require_dns_https_alpn=*/false);
+
+  url::SchemeHostPort server(request_info.url);
+  AlternativeService alternative_service(kProtoQUIC, "alt.example.org", 443);
+  SetAlternativeService(request_info, alternative_service);
+
+  request_ = CreateJobControllerAndStart(request_info);
+
+  // |dns_alpn_h3_job| must not be created when an active session is
+  // available for |alternative_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "Main job and alternative job must be created.");
+
+  base::HistogramTester histogram_tester;
+  // Run the message loop to make |alternative_job| succeed and status will be
+  // reported to Request.
+  {
+    base::RunLoop run_loop;
+    EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+        .Times(1)
+        .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+    run_loop.Run();
+  }
+  histogram_tester.ExpectUniqueSample("Net.AlternateProtocolUsage",
+                                      ALTERNATE_PROTOCOL_USAGE_NO_RACE, 1);
+
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "Main job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       ActiveSessionAvailableForDnsAlpnH3Job) {
+  PrepareForFirstQuicJob();
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  auto stream = ConnectQuicHttpStream(/*alt_destination=*/false,
+                                      /*require_dns_https_alpn=*/true);
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and alternative job must not be available.");
+
+  base::HistogramTester histogram_tester;
+  // Run the message loop to make |dns_alpn_h3_job| succeed and status will be
+  // reported to Request.
+  {
+    base::RunLoop run_loop;
+    EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+        .Times(1)
+        .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+    run_loop.Run();
+  }
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE, 1);
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "DNS alpn H3 job must exist.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       ActiveSessionAvailableForMainJobAndDnsAlpnH3Job) {
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+  PrepareForFirstQuicJob();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  // Put a SpdySession in the pool.
+  SpdySessionKey key(HostPortPair::FromURL(request_info.url),
+                     ProxyServer::Direct(), PRIVACY_MODE_DISABLED,
+                     SpdySessionKey::IsProxySession::kFalse, SocketTag(),
+                     NetworkIsolationKey(), SecureDnsPolicy::kAllow);
+  std::ignore = CreateFakeSpdySession(session_->spdy_session_pool(), key);
+
+  auto stream = ConnectQuicHttpStream(/*alt_destination=*/false,
+                                      /*require_dns_https_alpn=*/true);
+  request_ = CreateJobControllerAndStart(CreateTestHttpRequestInfo());
+
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job must not be available.");
+
+  base::HistogramTester histogram_tester;
+  // Run the message loop to make |dns_alpn_h3_job| succeed and status will be
+  // reported to Request.
+  {
+    base::RunLoop run_loop;
+    EXPECT_CALL(request_delegate_, OnStreamReadyImpl(_, _, _))
+        .Times(1)
+        .WillOnce(Invoke([&run_loop]() { run_loop.Quit(); }));
+    run_loop.Run();
+  }
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE, 1);
+
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "DNS alpn H3 job must exist.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       DonotStartDnsAlpnH3JobWhenSameHostDefaultPortAltJobCreated) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  url::SchemeHostPort server(request_info.url);
+  AlternativeService alternative_service(kProtoQUIC, "www.example.org", 443);
+  SetAlternativeService(request_info, alternative_service);
+
+  request_ = CreateJobControllerAndStart(request_info);
+  // |dns_alpn_h3_job| must be deleted when a same origin alt service
+  // was registered.
+  CheckJobsStatus(
+      true, true, false,
+      "All types of jobs are created, but DNS alpn job must be deleted");
+
+  base::HistogramTester histogram_tester;
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage", ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
+      1);
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "Alternate job must not be deleted");
+
+  // Make |alternative_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       AllJobsCreatedMainJobSucceedAltJobSucceedDnsJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  PrepareForSecondQuicJob();
+
+  // Use cold start and complete `alternative_job` and `dns_alpn_h3_job`
+  // manually.
+  crypto_client_stream_factory_.set_handshake_mode(
+      MockCryptoClientStream::COLD_START);
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  url::SchemeHostPort server(request_info.url);
+  AlternativeService alternative_service(kProtoQUIC, "alt.example.org", 443);
+  SetAlternativeService(request_info, alternative_service);
+
+  request_ = CreateJobControllerAndStart(request_info);
+  // |dns_alpn_h3_job| must be created when a different origin alt service
+  // was registered.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "All types of jobs are created");
+
+  base::HistogramTester histogram_tester;
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage", ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
+      1);
+
+  // The success of |main_job| doesn't delete |alternative_job| and
+  // |dns_alpn_h3_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  // Make |alternative_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Alternate job must be deleted.");
+
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(1, /*expect_stream_ready=*/false);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS alpn job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       AllJobsCreatedAltJobSucceedDnsJobSucceedMainJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  PrepareForSecondQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  url::SchemeHostPort server(request_info.url);
+  AlternativeService alternative_service(kProtoQUIC, "alt.example.org", 443);
+  SetAlternativeService(request_info, alternative_service);
+
+  request_ = CreateJobControllerAndStart(request_info);
+  // |dns_alpn_h3_job| must be created when a different origin alt service
+  // was registered.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "All types of jobs are created");
+
+  base::HistogramTester histogram_tester;
+  // Make |alternative_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample("Net.AlternateProtocolUsage",
+                                      ALTERNATE_PROTOCOL_USAGE_WON_RACE, 1);
+
+  // The success of |alternative_job| doesn't delete |main_job| and
+  // |dns_alpn_h3_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(1, /*expect_stream_ready=*/false);
+
+  // The success of |dns_alpn_h3_job| doesn't delete |main_job| and
+  // |alternative_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS alpn job must be deleted.");
+
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/false);
+
+  // |main_job| should be cleared.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "Alternate job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       AllJobsCreatedDnsJobSucceedAltJobSucceedMainJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+  PrepareForSecondQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+
+  url::SchemeHostPort server(request_info.url);
+  AlternativeService alternative_service(kProtoQUIC, "alt.example.org", 443);
+  SetAlternativeService(request_info, alternative_service);
+
+  request_ = CreateJobControllerAndStart(request_info);
+  // |dns_alpn_h3_job| must be created when a different origin alt service
+  // was registered.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "All types of jobs are created");
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(1, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // The success of |dns_alpn_h3_job| doesn't delete |main_job| and
+  // |alternative_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/true,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  // Make |alternative_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+
+  // The success of |alternative_job| doesn't delete |main_job| and
+  // |dns_alpn_h3_job|.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Alternate job must be deleted.");
+
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/false);
+
+  // |main_job| should be cleared.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Main job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       DnsJobFailOnDefaultNetworkDnsJobFailMainJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJobFailure();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  request_ = CreateJobControllerAndStart(request_info);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  JobControllerPeer::SetDnsAlpnH3JobFailedOnDefaultNetwork(job_controller_);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| fail.
+  quic_data_->Resume();
+  base::RunLoop().RunUntilIdle();
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false, "DNS alpn job be deleted.");
+
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  // Net.AlternateProtocolUsage must not record anything, when DNS alpn job
+  // failed.
+  histogram_tester.ExpectTotalCount("Net.AlternateProtocolUsage", 0);
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/false,
+                  "DNS alpn job must be deleted.");
+
+  request_.reset();
+  EXPECT_TRUE(IsAlternativeServiceBroken(request_info.url));
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+  histogram_tester.ExpectUniqueSample("Net.AlternateServiceForDnsAlpnH3Failed",
+                                      -ERR_QUIC_PROTOCOL_ERROR, 1);
+
+  // Verify the brokenness is not cleared when the default network changes.
+  session_->http_server_properties()->OnDefaultNetworkChanged();
+  EXPECT_TRUE(IsAlternativeServiceBroken(request_info.url));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       DnsJobFailOnDefaultNetworkMainJobSucceedDnsJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  base::HistogramTester histogram_tester;
+  request_ = CreateJobControllerAndStart(request_info);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  JobControllerPeer::SetDnsAlpnH3JobFailedOnDefaultNetwork(job_controller_);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage", ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE,
+      1);
+
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "DNS alpn job must not be deleted.");
+
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/false);
+
+  request_.reset();
+  histogram_tester.ExpectTotalCount("Net.AlternateServiceForDnsAlpnH3Failed",
+                                    0);
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+  EXPECT_TRUE(IsAlternativeServiceBroken(request_info.url));
+
+  // Verify the brokenness is cleared when the default network changes.
+  session_->http_server_properties()->OnDefaultNetworkChanged();
+  EXPECT_FALSE(IsAlternativeServiceBroken(request_info.url));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       DnsJobSucceedMainJobCanceled) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  request_ = CreateJobControllerAndStart(request_info);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // Main job is canceled.
+  CheckJobsStatus(/*main_job_exists=*/false, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Main job must be deleted");
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
+TEST_F(HttpStreamFactoryJobControllerDnsHttpsAlpnTest,
+       DnsJobFailOnDefaultNetworkDnsJobSucceedMainJobSucceed) {
+  PrepareForMainJob();
+  PrepareForFirstQuicJob();
+
+  HttpRequestInfo request_info = CreateTestHttpRequestInfo();
+
+  RegisterMockHttpsRecord();
+
+  Initialize(HttpRequestInfo());
+  request_ = CreateJobControllerAndStart(request_info);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job and DNS ALPN job must be created.");
+
+  JobControllerPeer::SetDnsAlpnH3JobFailedOnDefaultNetwork(job_controller_);
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true, "Jobs must not be deleted.");
+
+  base::HistogramTester histogram_tester;
+  // Make |dns_alpn_h3_job| succeed.
+  MakeQuicJobScceed(0, /*expect_stream_ready=*/true);
+  histogram_tester.ExpectUniqueSample(
+      "Net.AlternateProtocolUsage",
+      ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE, 1);
+
+  // Main job is not canceled, because |dns_alpn_h3_job| has failed on the
+  // default network.
+  CheckJobsStatus(/*main_job_exists=*/true, /*alternative_job_exists=*/false,
+                  /*dns_alpn_h3_job_exists=*/true,
+                  "Main job must not be deleted.");
+
+  // Make |main_job| succeed.
+  MakeMainJobSucceed(/*expect_stream_ready=*/false);
+
+  request_.reset();
+  EXPECT_TRUE(HttpStreamFactoryPeer::IsJobControllerDeleted(factory_));
+}
+
 }  // namespace net::test
diff --git a/net/http/http_stream_factory_test_util.cc b/net/http/http_stream_factory_test_util.cc
index 5b7a376b..4ff0eee 100644
--- a/net/http/http_stream_factory_test_util.cc
+++ b/net/http/http_stream_factory_test_util.cc
@@ -52,11 +52,15 @@
 
 MockHttpStreamFactoryJob::~MockHttpStreamFactoryJob() = default;
 
+void MockHttpStreamFactoryJob::DoResume() {
+  HttpStreamFactory::Job::Resume();
+}
+
 TestJobFactory::TestJobFactory() = default;
 
 TestJobFactory::~TestJobFactory() = default;
 
-std::unique_ptr<HttpStreamFactory::Job> TestJobFactory::CreateMainJob(
+std::unique_ptr<HttpStreamFactory::Job> TestJobFactory::CreateJob(
     HttpStreamFactory::Job::Delegate* delegate,
     HttpStreamFactory::JobType job_type,
     HttpNetworkSession* session,
@@ -69,48 +73,32 @@
     GURL origin_url,
     bool is_websocket,
     bool enable_ip_based_pooling,
-    NetLog* net_log) {
-  if (override_main_job_url_)
-    origin_url = main_job_alternative_url_;
-
-  auto main_job = std::make_unique<MockHttpStreamFactoryJob>(
-      delegate, job_type, session, request_info, priority, proxy_info,
-      SSLConfig(), SSLConfig(), std::move(destination), origin_url,
-      kProtoUnknown, quic::ParsedQuicVersion::Unsupported(), is_websocket,
-      enable_ip_based_pooling, net_log);
-
-  // Keep raw pointer to Job but pass ownership.
-  main_job_ = main_job.get();
-
-  return std::move(main_job);
-}
-
-std::unique_ptr<HttpStreamFactory::Job> TestJobFactory::CreateAltSvcJob(
-    HttpStreamFactory::Job::Delegate* delegate,
-    HttpStreamFactory::JobType job_type,
-    HttpNetworkSession* session,
-    const HttpRequestInfo& request_info,
-    RequestPriority priority,
-    const ProxyInfo& proxy_info,
-    const SSLConfig& server_ssl_config,
-    const SSLConfig& proxy_ssl_config,
-    url::SchemeHostPort destination,
-    GURL origin_url,
-    NextProto alternative_protocol,
-    quic::ParsedQuicVersion quic_version,
-    bool is_websocket,
-    bool enable_ip_based_pooling,
-    NetLog* net_log) {
-  auto alternative_job = std::make_unique<MockHttpStreamFactoryJob>(
+    NetLog* net_log,
+    NextProto alternative_protocol = kProtoUnknown,
+    quic::ParsedQuicVersion quic_version =
+        quic::ParsedQuicVersion::Unsupported()) {
+  auto job = std::make_unique<MockHttpStreamFactoryJob>(
       delegate, job_type, session, request_info, priority, proxy_info,
       SSLConfig(), SSLConfig(), std::move(destination), origin_url,
       alternative_protocol, quic_version, is_websocket, enable_ip_based_pooling,
       net_log);
 
   // Keep raw pointer to Job but pass ownership.
-  alternative_job_ = alternative_job.get();
-
-  return std::move(alternative_job);
+  switch (job_type) {
+    case HttpStreamFactory::MAIN:
+      main_job_ = job.get();
+      break;
+    case HttpStreamFactory::ALTERNATIVE:
+      alternative_job_ = job.get();
+      break;
+    case HttpStreamFactory::DNS_ALPN_H3:
+      dns_alpn_h3_job_ = job.get();
+      break;
+    case HttpStreamFactory::PRECONNECT:
+      main_job_ = job.get();
+      break;
+  }
+  return job;
 }
 
 }  // namespace net
diff --git a/net/http/http_stream_factory_test_util.h b/net/http/http_stream_factory_test_util.h
index ac89b431..4aed769f 100644
--- a/net/http/http_stream_factory_test_util.h
+++ b/net/http/http_stream_factory_test_util.h
@@ -125,6 +125,8 @@
   MOCK_METHOD0(Resume, void());
 
   MOCK_METHOD0(Orphan, void());
+
+  void DoResume();
 };
 
 // JobFactory for creating MockHttpStreamFactoryJobs.
@@ -133,7 +135,7 @@
   TestJobFactory();
   ~TestJobFactory() override;
 
-  std::unique_ptr<HttpStreamFactory::Job> CreateMainJob(
+  std::unique_ptr<HttpStreamFactory::Job> CreateJob(
       HttpStreamFactory::Job::Delegate* delegate,
       HttpStreamFactory::JobType job_type,
       HttpNetworkSession* session,
@@ -146,38 +148,18 @@
       GURL origin_url,
       bool is_websocket,
       bool enable_ip_based_pooling,
-      NetLog* net_log) override;
-
-  std::unique_ptr<HttpStreamFactory::Job> CreateAltSvcJob(
-      HttpStreamFactory::Job::Delegate* delegate,
-      HttpStreamFactory::JobType job_type,
-      HttpNetworkSession* session,
-      const HttpRequestInfo& request_info,
-      RequestPriority priority,
-      const ProxyInfo& proxy_info,
-      const SSLConfig& server_ssl_config,
-      const SSLConfig& proxy_ssl_config,
-      url::SchemeHostPort destination,
-      GURL origin_url,
+      NetLog* net_log,
       NextProto alternative_protocol,
-      quic::ParsedQuicVersion quic_version,
-      bool is_websocket,
-      bool enable_ip_based_pooling,
-      NetLog* net_log) override;
+      quic::ParsedQuicVersion quic_version) override;
 
   MockHttpStreamFactoryJob* main_job() const { return main_job_; }
   MockHttpStreamFactoryJob* alternative_job() const { return alternative_job_; }
-
-  void UseDifferentURLForMainJob(GURL url) {
-    override_main_job_url_ = true;
-    main_job_alternative_url_ = url;
-  }
+  MockHttpStreamFactoryJob* dns_alpn_h3_job() const { return dns_alpn_h3_job_; }
 
  private:
   raw_ptr<MockHttpStreamFactoryJob> main_job_ = nullptr;
   raw_ptr<MockHttpStreamFactoryJob> alternative_job_ = nullptr;
-  bool override_main_job_url_ = false;
-  GURL main_job_alternative_url_;
+  raw_ptr<MockHttpStreamFactoryJob> dns_alpn_h3_job_ = nullptr;
 };
 
 }  // namespace net
diff --git a/net/log/net_log_event_type_list.h b/net/log/net_log_event_type_list.h
index dc199c7..6f28dba 100644
--- a/net/log/net_log_event_type_list.h
+++ b/net/log/net_log_event_type_list.h
@@ -1118,8 +1118,11 @@
 //      "original_url": <The URL to create a stream for>,
 //      "url": <The URL actually being used, possibly different from
 //              original_url if using an alternate service>,
-//      "alternate_service": <The alternate service being used>,
+//      "expect_spdy": <Boolean indicating whether the Job will use SPDY>,
+//      "using_quic": <Boolean indicating whether the Job will use QUIC>,
 //      "priority": <The priority of the Job>,
+//      "type": <The type of this Job ("main", "alternative", "dns_alpn_h3",
+//               "preconnect")>,
 //   }
 EVENT_TYPE(HTTP_STREAM_JOB)
 
diff --git a/net/quic/mock_crypto_client_stream.h b/net/quic/mock_crypto_client_stream.h
index d6bf54b..0abfd5e 100644
--- a/net/quic/mock_crypto_client_stream.h
+++ b/net/quic/mock_crypto_client_stream.h
@@ -6,6 +6,7 @@
 #define NET_QUIC_MOCK_CRYPTO_CLIENT_STREAM_H_
 
 #include "base/memory/raw_ptr.h"
+#include "base/memory/weak_ptr.h"
 #include "net/quic/crypto/proof_verifier_chromium.h"
 #include "net/third_party/quiche/src/quiche/quic/core/crypto/crypto_handshake.h"
 #include "net/third_party/quiche/src/quiche/quic/core/crypto/crypto_protocol.h"
@@ -88,6 +89,10 @@
   // Notify session that 0-RTT setup is complete.
   void NotifySessionZeroRttComplete();
 
+  base::WeakPtr<MockCryptoClientStream> GetWeakPtr() {
+    return weak_factory_.GetWeakPtr();
+  }
+
   static quic::CryptoHandshakeMessage GetDummyCHLOMessage();
 
  protected:
@@ -111,6 +116,7 @@
   const quic::QuicServerId server_id_;
   raw_ptr<const net::ProofVerifyDetailsChromium> proof_verify_details_;
   const quic::QuicConfig config_;
+  base::WeakPtrFactory<MockCryptoClientStream> weak_factory_{this};
 };
 
 }  // namespace net
diff --git a/net/quic/mock_crypto_client_stream_factory.cc b/net/quic/mock_crypto_client_stream_factory.cc
index f60b3a1..8f901443 100644
--- a/net/quic/mock_crypto_client_stream_factory.cc
+++ b/net/quic/mock_crypto_client_stream_factory.cc
@@ -32,10 +32,16 @@
     proof_verify_details = proof_verify_details_queue_.front();
     proof_verify_details_queue_.pop();
   }
-  last_stream_ = new MockCryptoClientStream(
+  raw_ptr<MockCryptoClientStream> stream = new MockCryptoClientStream(
       server_id, session, nullptr, *(config_.get()), crypto_config,
       handshake_mode_, proof_verify_details, use_mock_crypter_);
-  return last_stream_;
+  streams_.push_back(stream->GetWeakPtr());
+  return stream;
+}
+
+MockCryptoClientStream* MockCryptoClientStreamFactory::last_stream() const {
+  CHECK(!streams_.empty());
+  return streams_.back().get();
 }
 
 }  // namespace net
diff --git a/net/quic/mock_crypto_client_stream_factory.h b/net/quic/mock_crypto_client_stream_factory.h
index 2a703b8..0a4d6efc 100644
--- a/net/quic/mock_crypto_client_stream_factory.h
+++ b/net/quic/mock_crypto_client_stream_factory.h
@@ -6,6 +6,7 @@
 #define NET_QUIC_MOCK_CRYPTO_CLIENT_STREAM_FACTORY_H_
 
 #include <memory>
+#include <vector>
 
 #include "base/containers/queue.h"
 #include "base/memory/raw_ptr.h"
@@ -50,7 +51,10 @@
     proof_verify_details_queue_.push(proof_verify_details);
   }
 
-  MockCryptoClientStream* last_stream() const { return last_stream_; }
+  MockCryptoClientStream* last_stream() const;
+  const std::vector<base::WeakPtr<MockCryptoClientStream>>& streams() const {
+    return streams_;
+  }
 
   // Sets initial config for new sessions.
   void SetConfig(const quic::QuicConfig& config);
@@ -58,7 +62,7 @@
  private:
   MockCryptoClientStream::HandshakeMode handshake_mode_ =
       MockCryptoClientStream::CONFIRM_HANDSHAKE;
-  raw_ptr<MockCryptoClientStream> last_stream_ = nullptr;
+  std::vector<base::WeakPtr<MockCryptoClientStream>> streams_;
   base::queue<const ProofVerifyDetailsChromium*> proof_verify_details_queue_;
   std::unique_ptr<quic::QuicConfig> config_;
   bool use_mock_crypter_ = false;
diff --git a/net/quic/quic_stream_factory.cc b/net/quic/quic_stream_factory.cc
index 75f6d15a..d6c3e6b 100644
--- a/net/quic/quic_stream_factory.cc
+++ b/net/quic/quic_stream_factory.cc
@@ -1136,6 +1136,21 @@
   session_ = std::move(session);
 }
 
+bool QuicStreamRequest::CanUseExistingSession(
+    const GURL& url,
+    PrivacyMode privacy_mode,
+    const SocketTag& socket_tag,
+    const NetworkIsolationKey& network_isolation_key,
+    SecureDnsPolicy secure_dns_policy,
+    bool require_dns_https_alpn,
+    const url::SchemeHostPort& destination) const {
+  return factory_->CanUseExistingSession(
+      QuicSessionKey(HostPortPair::FromURL(url), privacy_mode, socket_tag,
+                     network_isolation_key, secure_dns_policy,
+                     require_dns_https_alpn),
+      destination);
+}
+
 QuicStreamFactory::QuicSessionAliasKey::QuicSessionAliasKey(
     url::SchemeHostPort destination,
     QuicSessionKey session_key)
@@ -1234,13 +1249,15 @@
 
 bool QuicStreamFactory::CanUseExistingSession(
     const QuicSessionKey& session_key,
-    const url::SchemeHostPort& destination) {
+    const url::SchemeHostPort& destination) const {
   if (base::Contains(active_sessions_, session_key))
     return true;
 
   for (const auto& key_value : active_sessions_) {
     QuicChromiumClientSession* session = key_value.second;
-    if (destination == all_sessions_[session].destination() &&
+    const auto& it = all_sessions_.find(session);
+    if ((it != all_sessions_.end()) &&
+        (destination == it->second.destination()) &&
         session->CanPool(session_key.host(), session_key)) {
       return true;
     }
diff --git a/net/quic/quic_stream_factory.h b/net/quic/quic_stream_factory.h
index c509693..cc52bec 100644
--- a/net/quic/quic_stream_factory.h
+++ b/net/quic/quic_stream_factory.h
@@ -183,6 +183,14 @@
 
   const NetLogWithSource& net_log() const { return net_log_; }
 
+  bool CanUseExistingSession(const GURL& url,
+                             PrivacyMode privacy_mode,
+                             const SocketTag& socket_tag,
+                             const NetworkIsolationKey& network_isolation_key,
+                             SecureDnsPolicy secure_dns_policy,
+                             bool require_dns_https_alpn,
+                             const url::SchemeHostPort& destination) const;
+
  private:
   raw_ptr<QuicStreamFactory> factory_;
   QuicSessionKey session_key_;
@@ -258,7 +266,7 @@
   // request can be pooled to an existing session to the IP address of
   // |destination|.
   bool CanUseExistingSession(const QuicSessionKey& session_key,
-                             const url::SchemeHostPort& destination);
+                             const url::SchemeHostPort& destination) const;
 
   // Fetches a QuicChromiumClientSession to |host_port_pair| which will be
   // owned by |request|.
diff --git a/services/network/BUILD.gn b/services/network/BUILD.gn
index 5361116a..7c7dd11 100644
--- a/services/network/BUILD.gn
+++ b/services/network/BUILD.gn
@@ -77,6 +77,10 @@
     "network_quality_estimator_manager.h",
     "network_service.cc",
     "network_service.h",
+    "network_service_memory_cache.cc",
+    "network_service_memory_cache.h",
+    "network_service_memory_cache_writer.cc",
+    "network_service_memory_cache_writer.h",
     "network_service_network_delegate.cc",
     "network_service_network_delegate.h",
     "network_service_proxy_delegate.cc",
@@ -357,6 +361,7 @@
     "network_context_unittest.cc",
     "network_qualities_pref_delegate_unittest.cc",
     "network_quality_estimator_manager_unittest.cc",
+    "network_service_memory_cache_unittest.cc",
     "network_service_proxy_delegate_unittest.cc",
     "network_service_unittest.cc",
     "pending_callback_chain_unittest.cc",
diff --git a/services/network/network_context.cc b/services/network/network_context.cc
index 9fbb457b9..9f9d54b 100644
--- a/services/network/network_context.cc
+++ b/services/network/network_context.cc
@@ -2178,6 +2178,13 @@
   return &http_auth_merged_preferences_;
 }
 
+NetworkServiceMemoryCache* NetworkContext::GetMemoryCache() {
+  if (!base::FeatureList::IsEnabled(features::kNetworkServiceMemoryCache)) {
+    return nullptr;
+  }
+  return &memory_cache_;
+}
+
 size_t NetworkContext::NumOpenWebTransports() const {
   return std::count_if(web_transports_.begin(), web_transports_.end(),
                        [](const std::unique_ptr<WebTransport>& transport) {
diff --git a/services/network/network_context.h b/services/network/network_context.h
index 051a33d..34b3e31 100644
--- a/services/network/network_context.h
+++ b/services/network/network_context.h
@@ -46,6 +46,7 @@
 #include "services/network/http_cache_data_counter.h"
 #include "services/network/http_cache_data_remover.h"
 #include "services/network/network_qualities_pref_delegate.h"
+#include "services/network/network_service_memory_cache.h"
 #include "services/network/public/cpp/cors/origin_access_list.h"
 #include "services/network/public/cpp/network_service_buildflags.h"
 #include "services/network/public/cpp/transferable_directory.h"
@@ -572,6 +573,9 @@
 
   WebBundleManager& GetWebBundleManager() { return web_bundle_manager_; }
 
+  // May return null if the in-memory cache is disabled.
+  NetworkServiceMemoryCache* GetMemoryCache();
+
   // Returns the current same-origin-policy exceptions.  For more details see
   // network::mojom::NetworkContextParams::cors_origin_access_list and
   // network::mojom::NetworkContext::SetCorsOriginAccessListsForOrigin.
@@ -881,6 +885,8 @@
   // manages the lifetiem of a WebBundleURLLoaderFactory object.
   WebBundleManager web_bundle_manager_;
 
+  NetworkServiceMemoryCache memory_cache_;
+
   // Whether all external consumers are expected to provide a non-empty
   // NetworkIsolationKey with all requests. When set, enabled a variety of
   // DCHECKs on APIs used by external callers.
diff --git a/services/network/network_service_memory_cache.cc b/services/network/network_service_memory_cache.cc
new file mode 100644
index 0000000..8fafa850
--- /dev/null
+++ b/services/network/network_service_memory_cache.cc
@@ -0,0 +1,242 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "services/network/network_service_memory_cache.h"
+
+#include "base/memory/ref_counted_memory.h"
+#include "base/memory/scoped_refptr.h"
+#include "base/metrics/field_trial_params.h"
+#include "net/base/load_flags.h"
+#include "net/base/network_isolation_key.h"
+#include "net/http/http_cache.h"
+#include "net/http/http_response_headers.h"
+#include "net/http/http_status_code.h"
+#include "net/http/http_util.h"
+#include "net/url_request/url_request.h"
+#include "services/network/network_context.h"
+#include "services/network/network_service_memory_cache_writer.h"
+#include "services/network/public/cpp/features.h"
+#include "services/network/public/cpp/resource_request.h"
+#include "services/network/url_loader.h"
+#include "url/gurl.h"
+#include "url/origin.h"
+
+namespace network {
+
+namespace {
+
+// TODO(https://crbug.com/1339708): Adjust the default size based on stats.
+const base::FeatureParam<int> kNetworkServiceMemoryCacheMaxTotalSize{
+    &features::kNetworkServiceMemoryCache, "max_total_size", 64 * 1024 * 1024};
+
+std::string GenerateCacheKeyForResourceRequest(
+    const ResourceRequest& resource_request,
+    const net::NetworkIsolationKey& network_isolation_key) {
+  const bool is_subframe_document_resource =
+      resource_request.destination == mojom::RequestDestination::kIframe;
+  return net::HttpCache::GenerateCacheKey(
+      resource_request.url, resource_request.load_flags, network_isolation_key,
+      /*upload_data_identifier=*/0, is_subframe_document_resource,
+      /*use_single_keyed_cache=*/false, /*single_key_checksum=*/"");
+}
+
+}  // namespace
+
+struct NetworkServiceMemoryCache::Entry {
+  Entry(mojom::URLResponseHeadPtr response_head,
+        scoped_refptr<base::RefCountedBytes> content)
+      : response_head(std::move(response_head)), content(std::move(content)) {}
+  ~Entry() = default;
+
+  // Movable.
+  Entry(Entry&&) = default;
+  Entry& operator=(Entry&&) = default;
+  Entry(const Entry&) = delete;
+  Entry& operator=(const Entry&) = delete;
+
+  mojom::URLResponseHeadPtr response_head;
+  scoped_refptr<base::RefCountedBytes> content;
+};
+
+NetworkServiceMemoryCache::NetworkServiceMemoryCache()
+    : entries_(CacheMap::NO_AUTO_EVICT),
+      max_total_bytes_(kNetworkServiceMemoryCacheMaxTotalSize.Get()) {}
+
+NetworkServiceMemoryCache::~NetworkServiceMemoryCache() = default;
+
+base::WeakPtr<NetworkServiceMemoryCache>
+NetworkServiceMemoryCache::GetWeakPtr() {
+  return weak_ptr_factory_.GetWeakPtr();
+}
+
+std::unique_ptr<NetworkServiceMemoryCacheWriter>
+NetworkServiceMemoryCache::MaybeCreateWriter(
+    net::URLRequest* url_request,
+    mojom::RequestDestination request_destination,
+    const mojom::URLResponseHeadPtr& response) {
+  DCHECK(url_request);
+
+  // TODO(https://crbug.com/1339708): Make `this` work with
+  // SplitCacheByIncludeCredentials. Currently some tests are failing when
+  // the feature is enabled.
+  if (base::FeatureList::IsEnabled(
+          net::features::kSplitCacheByIncludeCredentials)) {
+    return nullptr;
+  }
+
+  // TODO(https://crbug.com/1339708): Make `this` work for responses from
+  // private network. Currently some tests are failing.
+  if (response->response_address_space == mojom::IPAddressSpace::kPrivate)
+    return nullptr;
+
+  DCHECK(url_request->url().is_valid());
+  if (!url_request->url().SchemeIsHTTPOrHTTPS())
+    return nullptr;
+
+  if (url_request->method() != net::HttpRequestHeaders::kGetMethod)
+    return nullptr;
+
+  // See the comment in HttpCache::Transaction::ShouldPassThrough().
+  if (net::HttpCache::IsSplitCacheEnabled() &&
+      url_request->isolation_info().network_isolation_key().IsTransient()) {
+    return nullptr;
+  }
+
+  if (!response->headers || response->headers->response_code() != net::HTTP_OK)
+    return nullptr;
+
+  const int load_flags = url_request->load_flags();
+  if (load_flags & net::LOAD_BYPASS_CACHE ||
+      load_flags & net::LOAD_DISABLE_CACHE) {
+    return nullptr;
+  }
+
+  net::ValidationType validation_type = response->headers->RequiresValidation(
+      response->request_time, response->response_time, GetCurrentTime());
+  if (validation_type != net::VALIDATION_NONE)
+    return nullptr;
+
+  bool is_subframe_document_resource =
+      request_destination == mojom::RequestDestination::kIframe;
+  std::string cache_key = net::HttpCache::GenerateCacheKey(
+      url_request->url(), url_request->load_flags(),
+      url_request->isolation_info().network_isolation_key(),
+      /*upload_data_identifier=*/0, is_subframe_document_resource,
+      /*use_single_keyed_cache=*/false,
+      /*single_key_checksum=*/"");
+
+  return std::make_unique<NetworkServiceMemoryCacheWriter>(
+      weak_ptr_factory_.GetWeakPtr(), GetNextTraceId(), std::move(cache_key),
+      url_request, response);
+}
+
+void NetworkServiceMemoryCache::StoreResponse(
+    const std::string& cache_key,
+    const URLLoaderCompletionStatus& status,
+    mojom::URLResponseHeadPtr response_head,
+    std::vector<unsigned char> data) {
+  // TODO(https://crbug.com/1339708): Consider caching a response that doesn't
+  // have contents.
+  if (status.error_code != net::OK || data.size() == 0)
+    return;
+
+  // TODO(https://crbug.com/1339708): Consider not storing a large response to
+  // improve cache hit rate.
+  if (max_total_bytes_ < data.size())
+    return;
+
+  auto prev = entries_.Peek(cache_key);
+  if (prev != entries_.end()) {
+    DCHECK_GE(total_bytes_, prev->second->content->size());
+    total_bytes_ -= prev->second->content->size();
+    // The following Put() will remove `prev`.
+  }
+
+  DCHECK_GE(std::numeric_limits<size_t>::max() - total_bytes_, data.size());
+  total_bytes_ += data.size();
+
+  scoped_refptr<base::RefCountedBytes> content =
+      base::RefCountedBytes::TakeVector(&data);
+  auto entry =
+      std::make_unique<Entry>(std::move(response_head), std::move(content));
+  entries_.Put(cache_key, std::move(entry));
+
+  ShrinkToTotalBytes();
+}
+
+absl::optional<std::string> NetworkServiceMemoryCache::CanServe(
+    const ResourceRequest& resource_request,
+    const net::NetworkIsolationKey& network_isolation_key) {
+  // TODO(https://crbug.com/1339708): Support automatically assigned network
+  // isolation key for request from browsers. See comments in
+  // CorsURLLoaderFactory::CorsURLLoaderFactory.
+  DCHECK(network_isolation_key.IsFullyPopulated());
+
+  const GURL& url = resource_request.url;
+  if (!url.is_valid() || !url.SchemeIsHTTPOrHTTPS())
+    return absl::nullopt;
+
+  if (resource_request.method != net::HttpRequestHeaders::kGetMethod)
+    return absl::nullopt;
+
+  if (resource_request.load_flags & net::LOAD_BYPASS_CACHE ||
+      resource_request.load_flags & net::LOAD_DISABLE_CACHE ||
+      resource_request.load_flags & net::LOAD_VALIDATE_CACHE) {
+    return absl::nullopt;
+  }
+
+  // TODO(https://crbug.com/1339708): Perform CORP checks.
+
+  std::string cache_key = GenerateCacheKeyForResourceRequest(
+      resource_request, network_isolation_key);
+
+  auto it = entries_.Peek(cache_key);
+  if (it == entries_.end())
+    return absl::nullopt;
+
+  const mojom::URLResponseHeadPtr& response = it->second->response_head;
+  net::ValidationType validation_type = response->headers->RequiresValidation(
+      response->request_time, response->response_time, GetCurrentTime());
+  if (validation_type != net::VALIDATION_NONE) {
+    // The cached response is stale, erase it from the in-memory cache.
+    entries_.Erase(it);
+    return absl::nullopt;
+  }
+
+  return std::move(cache_key);
+}
+
+void NetworkServiceMemoryCache::SetCurrentTimeForTesting(
+    base::Time current_time) {
+  current_time_for_testing_ = current_time;
+}
+
+mojom::URLResponseHeadPtr NetworkServiceMemoryCache::GetResponseHeadForTesting(
+    const std::string& cache_key) {
+  auto it = entries_.Peek(cache_key);
+  if (it == entries_.end())
+    return nullptr;
+  return it->second->response_head.Clone();
+}
+
+base::Time NetworkServiceMemoryCache::GetCurrentTime() {
+  if (!current_time_for_testing_.is_null())
+    return current_time_for_testing_;
+  return base::Time::Now();
+}
+
+uint64_t NetworkServiceMemoryCache::GetNextTraceId() {
+  return (reinterpret_cast<uint64_t>(this) << 32) | next_trace_id_++;
+}
+
+void NetworkServiceMemoryCache::ShrinkToTotalBytes() {
+  while (!entries_.empty() && total_bytes_ > max_total_bytes_) {
+    auto it = entries_.rbegin();
+    DCHECK_GE(total_bytes_, it->second->content->size());
+    total_bytes_ -= it->second->content->size();
+    entries_.Erase(it);
+  }
+}
+
+}  // namespace network
diff --git a/services/network/network_service_memory_cache.h b/services/network/network_service_memory_cache.h
new file mode 100644
index 0000000..8f6856b
--- /dev/null
+++ b/services/network/network_service_memory_cache.h
@@ -0,0 +1,98 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_H_
+#define SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_H_
+
+#include <inttypes.h>
+#include <memory>
+#include <string>
+
+#include "base/component_export.h"
+#include "base/containers/lru_cache.h"
+#include "base/memory/raw_ptr.h"
+#include "base/memory/weak_ptr.h"
+#include "base/time/time.h"
+#include "services/network/public/mojom/url_loader_completion_status.mojom.h"
+#include "services/network/public/mojom/url_response_head.mojom.h"
+#include "third_party/abseil-cpp/absl/types/optional.h"
+
+namespace net {
+class NetworkIsolationKey;
+class URLRequest;
+}  // namespace net
+
+namespace network {
+
+class NetworkServiceMemoryCacheWriter;
+struct ResourceRequest;
+
+// An in-memory HTTP cache. NetworkContext owns the in-memory cache.
+// TODO(https://crbug.com/1339708): Add more descriptions once the network
+// service starts serving response from the in-memory cache.
+class COMPONENT_EXPORT(NETWORK_SERVICE) NetworkServiceMemoryCache {
+ public:
+  NetworkServiceMemoryCache();
+  ~NetworkServiceMemoryCache();
+
+  NetworkServiceMemoryCache(const NetworkServiceMemoryCache&) = delete;
+  NetworkServiceMemoryCache& operator=(const NetworkServiceMemoryCache&) =
+      delete;
+
+  base::WeakPtr<NetworkServiceMemoryCache> GetWeakPtr();
+
+  // Creates a NetworkServiceMemoryCacheWriter when the response is 200 and it
+  // can be cacheable.
+  std::unique_ptr<NetworkServiceMemoryCacheWriter> MaybeCreateWriter(
+      net::URLRequest* url_request,
+      mojom::RequestDestination request_destination,
+      const mojom::URLResponseHeadPtr& response);
+
+  // Stores an HTTP response into `this`. Called when a writer finished reading
+  // response body.
+  void StoreResponse(const std::string& cache_key,
+                     const URLLoaderCompletionStatus& status,
+                     mojom::URLResponseHeadPtr response_head,
+                     std::vector<unsigned char> data);
+
+  // Returns a cache key if `this` has a fresh response for `resource_request`.
+  // The returned cache key is valid only for the current call stack. It must be
+  // used synchronously.
+  absl::optional<std::string> CanServe(
+      const ResourceRequest& resource_request,
+      const net::NetworkIsolationKey& network_isolation_key);
+
+  void SetCurrentTimeForTesting(base::Time current_time);
+
+  mojom::URLResponseHeadPtr GetResponseHeadForTesting(
+      const std::string& cache_key);
+
+ private:
+  struct Entry;
+  using CacheMap = base::LRUCache<std::string, std::unique_ptr<Entry>>;
+
+  // Returns the current time for cache freshness checks.
+  base::Time GetCurrentTime();
+
+  // Used for tracing.
+  uint64_t GetNextTraceId();
+
+  // Erases least recently used entries from the in-memory cache until
+  // `total_bytes_` becomes less than `max_total_bytes_`.
+  void ShrinkToTotalBytes();
+
+  uint32_t next_trace_id_ = 0;
+
+  CacheMap entries_;
+  const size_t max_total_bytes_;
+  size_t total_bytes_ = 0;
+
+  base::Time current_time_for_testing_;
+
+  base::WeakPtrFactory<NetworkServiceMemoryCache> weak_ptr_factory_{this};
+};
+
+}  // namespace network
+
+#endif  // SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_H_
diff --git a/services/network/network_service_memory_cache_unittest.cc b/services/network/network_service_memory_cache_unittest.cc
new file mode 100644
index 0000000..a05b4b4d
--- /dev/null
+++ b/services/network/network_service_memory_cache_unittest.cc
@@ -0,0 +1,474 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include <memory>
+
+#include "base/run_loop.h"
+#include "base/strings/string_number_conversions.h"
+#include "base/strings/stringprintf.h"
+#include "base/test/bind.h"
+#include "base/test/scoped_feature_list.h"
+#include "base/test/task_environment.h"
+#include "mojo/public/cpp/bindings/remote.h"
+#include "net/base/features.h"
+#include "net/base/schemeful_site.h"
+#include "net/base/url_util.h"
+#include "net/test/embedded_test_server/embedded_test_server.h"
+#include "net/traffic_annotation/network_traffic_annotation_test_helper.h"
+#include "net/url_request/url_request_context.h"
+#include "net/url_request/url_request_context_builder.h"
+#include "services/network/cors/cors_url_loader_factory.h"
+#include "services/network/network_context.h"
+#include "services/network/network_service.h"
+#include "services/network/network_service_memory_cache_writer.h"
+#include "services/network/public/cpp/cors/origin_access_list.h"
+#include "services/network/public/cpp/features.h"
+#include "services/network/public/mojom/url_loader.mojom.h"
+#include "services/network/public/mojom/url_loader_factory.mojom.h"
+#include "services/network/resource_scheduler/resource_scheduler_client.h"
+#include "services/network/test/fake_test_cert_verifier_params_factory.h"
+#include "services/network/test/test_url_loader_client.h"
+#include "services/network/test/test_utils.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "url/gurl.h"
+#include "url/origin.h"
+
+namespace network {
+
+namespace {
+
+constexpr int kMaxTotalSize = 2 * 1024;
+
+struct LoaderPair {
+  LoaderPair() : client(std::make_unique<TestURLLoaderClient>()) {}
+  ~LoaderPair() = default;
+
+  LoaderPair(LoaderPair&&) = default;
+  LoaderPair& operator=(LoaderPair&&) = default;
+  LoaderPair(const LoaderPair&) = delete;
+  LoaderPair& operator=(const LoaderPair&) = delete;
+
+  mojo::Remote<mojom::URLLoader> loader_remote;
+  std::unique_ptr<TestURLLoaderClient> client;
+};
+
+mojom::URLResponseHeadPtr CreateCacheableURLResponseHead() {
+  mojom::URLResponseHeadPtr response_head = CreateURLResponseHead(net::HTTP_OK);
+  response_head->headers->AddHeader("Cache-Control", "max-age=60");
+  base::Time now = base::Time::Now();
+  response_head->request_time = now;
+  response_head->response_time = now;
+  return response_head;
+}
+
+// An EmbeddedTestServer request handler that returns a cacheable response of
+// which body size and max-age are specified by the query string.
+std::unique_ptr<net::test_server::HttpResponse> CacheableResponseHandler(
+    const net::test_server::HttpRequest& request) {
+  if (request.GetURL().path_piece() != "/cacheable")
+    return nullptr;
+
+  auto response = std::make_unique<net::test_server::BasicHttpResponse>();
+
+  uint64_t body_size = 64;
+  std::string query_body_size;
+  if (net::GetValueForKeyInQuery(request.GetURL(), "body-size",
+                                 &query_body_size)) {
+    EXPECT_TRUE(base::StringToUint64(query_body_size, &body_size));
+  }
+
+  uint64_t max_age = 60;
+  std::string query_max_age;
+  if (net::GetValueForKeyInQuery(request.GetURL(), "max-age", &query_max_age)) {
+    EXPECT_TRUE(base::StringToUint64(query_max_age, &max_age));
+  }
+
+  response->AddCustomHeader("cache-control",
+                            base::StringPrintf("max-age=%" PRId64, max_age));
+  response->set_content(std::string(body_size, 'a'));
+  return response;
+}
+
+}  // namespace
+
+class NetworkServiceMemoryCacheTest : public testing::Test {
+ public:
+  NetworkServiceMemoryCacheTest()
+      : task_environment_(base::test::TaskEnvironment::MainThreadType::IO) {
+    scoped_feature_list_.InitAndEnableFeatureWithParameters(
+        features::kNetworkServiceMemoryCache,
+        {{"max_total_size", base::NumberToString(kMaxTotalSize)}});
+  }
+
+  ~NetworkServiceMemoryCacheTest() override = default;
+
+  void SetUp() override {
+    // The following setup similar to CorsURLLoaderFactoryTest.
+
+    test_server_.AddDefaultHandlers();
+    test_server_.RegisterRequestHandler(
+        base::BindRepeating(&CacheableResponseHandler));
+    ASSERT_TRUE(test_server_.Start());
+
+    network_service_ = NetworkService::CreateForTesting();
+
+    auto context_params = mojom::NetworkContextParams::New();
+    context_params->cert_verifier_params =
+        FakeTestCertVerifierParamsFactory::GetCertVerifierParams();
+    context_params->initial_proxy_config =
+        net::ProxyConfigWithAnnotation::CreateDirect();
+    network_context_ = std::make_unique<NetworkContext>(
+        network_service_.get(),
+        network_context_remote_.BindNewPipeAndPassReceiver(),
+        std::move(context_params));
+
+    auto factory_params = network::mojom::URLLoaderFactoryParams::New();
+    constexpr int kProcessId = 123;
+    factory_params->process_id = kProcessId;
+    factory_params->request_initiator_origin_lock =
+        url::Origin::Create(test_server_.base_url());
+
+    url::Origin test_server_origin =
+        url::Origin::Create(test_server_.base_url());
+    factory_params->isolation_info =
+        net::IsolationInfo::CreateForInternalRequest(test_server_origin);
+
+    cors_url_loader_factory_ = std::make_unique<cors::CorsURLLoaderFactory>(
+        network_context_.get(), std::move(factory_params),
+        /*resource_scheduler_client=*/nullptr,
+        cors_url_loader_factory_remote_.BindNewPipeAndPassReceiver(),
+        &origin_access_list_);
+  }
+
+  net::test_server::EmbeddedTestServer& test_server() { return test_server_; }
+
+  net::URLRequestContext& url_request_context() {
+    return *network_context_->url_request_context();
+  }
+
+  NetworkServiceMemoryCache& memory_cache() {
+    return *network_context_->GetMemoryCache();
+  }
+
+  ResourceRequest CreateRequest(const std::string& relative_path) {
+    ResourceRequest request;
+    GURL url = test_server().GetURL(relative_path);
+    url::Origin origin = url::Origin::Create(url);
+    request.url = url;
+    request.request_initiator = origin;
+    return request;
+  }
+
+  std::unique_ptr<net::URLRequest> CreateURLRequest(const GURL& url) {
+    return url_request_context().CreateRequest(url, net::DEFAULT_PRIORITY,
+                                               /*delegate=*/nullptr,
+                                               TRAFFIC_ANNOTATION_FOR_TESTS);
+  }
+
+  LoaderPair CreateLoaderAndStart(const ResourceRequest& request) {
+    LoaderPair pair;
+    cors_url_loader_factory_->CreateLoaderAndStart(
+        pair.loader_remote.BindNewPipeAndPassReceiver(), /*request_id=*/1,
+        mojom::kURLLoadOptionNone, request, pair.client->CreateRemote(),
+        net::MutableNetworkTrafficAnnotationTag(TRAFFIC_ANNOTATION_FOR_TESTS));
+    return pair;
+  }
+
+  void StoreResponseToMemoryCache(const ResourceRequest& request) {
+    LoaderPair pair = CreateLoaderAndStart(request);
+    pair.client->RunUntilComplete();
+  }
+
+  bool WriterWillBeCreatedToStoreResponse(
+      net::URLRequest* url_request,
+      const mojom::URLResponseHeadPtr& response_head) {
+    std::unique_ptr<NetworkServiceMemoryCacheWriter> writer =
+        memory_cache().MaybeCreateWriter(
+            url_request, mojom::RequestDestination::kDocument, response_head);
+    return writer.get() != nullptr;
+  }
+
+  bool CanServeFromMemoryCache(const ResourceRequest& request) {
+    net::SchemefulSite site(request.url);
+    net::NetworkIsolationKey network_isolation_key(/*top_frame_site=*/site,
+                                                   /*frame_site=*/site);
+    return memory_cache().CanServe(request, network_isolation_key).has_value();
+  }
+
+  bool CanServeFromMemoryCache(
+      const ResourceRequest& request,
+      net::NetworkIsolationKey& network_isolation_key) {
+    return memory_cache().CanServe(request, network_isolation_key).has_value();
+  }
+
+ private:
+  base::test::ScopedFeatureList scoped_feature_list_;
+  base::test::TaskEnvironment task_environment_;
+  std::unique_ptr<net::URLRequestContext> url_request_context_;
+  std::unique_ptr<NetworkService> network_service_;
+  std::unique_ptr<NetworkContext> network_context_;
+  mojo::Remote<mojom::NetworkContext> network_context_remote_;
+
+  net::test_server::EmbeddedTestServer test_server_;
+
+  std::unique_ptr<mojom::URLLoaderFactory> cors_url_loader_factory_;
+  mojo::Remote<mojom::URLLoaderFactory> cors_url_loader_factory_remote_;
+
+  cors::OriginAccessList origin_access_list_;
+};
+
+TEST_F(NetworkServiceMemoryCacheTest,
+       CreateWriter_SchemeIsNeitherHTTPNorHTTPS) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(GURL("data:text/plain;foo"));
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_MethodIsNotGet) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+  url_request->set_method("POST");
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest,
+       CreateWriter_NetworkIsolationKeyIsTransient) {
+  base::test::ScopedFeatureList feature_list;
+  feature_list.InitAndEnableFeature(
+      net::features::kSplitCacheByNetworkIsolationKey);
+
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+  url_request->set_isolation_info(net::IsolationInfo::CreateTransient());
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_StatusCodeIsNotOK) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+
+  mojom::URLResponseHeadPtr response_head =
+      CreateURLResponseHead(net::HTTP_BAD_REQUEST);
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_EmptyResponse) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+
+  auto response_head = mojom::URLResponseHead::New();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_BypassCache) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+  url_request->SetLoadFlags(net::LOAD_BYPASS_CACHE);
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_DisableCache) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+  url_request->SetLoadFlags(net::LOAD_DISABLE_CACHE);
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CreateWriter_ResponseNotCacheable) {
+  std::unique_ptr<net::URLRequest> url_request =
+      CreateURLRequest(test_server().GetURL("/cacheable"));
+
+  mojom::URLResponseHeadPtr response_head = CreateCacheableURLResponseHead();
+  response_head->headers->RemoveHeader("cache-control");
+  response_head->headers->AddHeader("cache-control", "no-store");
+
+  ASSERT_FALSE(
+      WriterWillBeCreatedToStoreResponse(url_request.get(), response_head));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_Basic) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  StoreResponseToMemoryCache(request);
+
+  ASSERT_TRUE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_InvalidURL) {
+  ResourceRequest request;
+  request.url = GURL();
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_SchemeIsNeitherHTTPNorHTTPS) {
+  ResourceRequest request;
+  request.url = GURL("data:text/plain;foo");
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_MethodIsNotGet) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  request.method = net::HttpRequestHeaders::kPostMethod;
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_BypassCache) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  request.load_flags |= net::LOAD_BYPASS_CACHE;
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_DisableCache) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  request.load_flags |= net::LOAD_DISABLE_CACHE;
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_ValidateCache) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  request.load_flags |= net::LOAD_VALIDATE_CACHE;
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_Expired) {
+  const uint64_t kMaxAge = 60;
+  ResourceRequest request =
+      CreateRequest(base::StringPrintf("/cacheable?max-age=%" PRId64, kMaxAge));
+  StoreResponseToMemoryCache(request);
+
+  ASSERT_TRUE(CanServeFromMemoryCache(request));
+
+  // The response has `max-age=60`. Set the current time 61 seconds later to
+  // make the cached response stale.
+  memory_cache().SetCurrentTimeForTesting(base::Time::Now() +
+                                          base::Seconds(kMaxAge + 1));
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, CanServe_ResponseTooLarge) {
+  ResourceRequest request = CreateRequest(
+      base::StringPrintf("/cacheable?body-size=%d", kMaxTotalSize + 1));
+  StoreResponseToMemoryCache(request);
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest,
+       CanServe_SplitCacheByNetworkIsolationKeyEnabled) {
+  base::test::ScopedFeatureList feature_list;
+  feature_list.InitAndEnableFeature(
+      net::features::kSplitCacheByNetworkIsolationKey);
+
+  ResourceRequest request = CreateRequest("/cacheable");
+  StoreResponseToMemoryCache(request);
+
+  net::SchemefulSite same_site(request.url);
+  net::NetworkIsolationKey same_site_network_isolation_key(
+      /*top_frame_site=*/same_site, /*frame_site=*/same_site);
+  ASSERT_TRUE(
+      CanServeFromMemoryCache(request, same_site_network_isolation_key));
+
+  net::SchemefulSite other_site(GURL("https://example.test"));
+  net::NetworkIsolationKey other_site_network_isolation_key(
+      /*top_frame_site=*/same_site, /*frame_site=*/other_site);
+  ASSERT_FALSE(
+      CanServeFromMemoryCache(request, other_site_network_isolation_key));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, UpdateStoredCache) {
+  ResourceRequest request = CreateRequest("/cacheable");
+
+  StoreResponseToMemoryCache(request);
+
+  net::SchemefulSite site(request.url);
+  net::NetworkIsolationKey network_isolation_key(/*top_frame_site=*/site,
+                                                 /*frame_site=*/site);
+
+  absl::optional<std::string> cache_key =
+      memory_cache().CanServe(request, network_isolation_key);
+  ASSERT_TRUE(cache_key.has_value());
+  mojom::URLResponseHeadPtr response =
+      memory_cache().GetResponseHeadForTesting(*cache_key);
+  base::Time first_response_time = response->response_time;
+
+  // Store the same response again. Force validation to update the response.
+  request.load_flags |= net::LOAD_VALIDATE_CACHE;
+  StoreResponseToMemoryCache(request);
+  response = memory_cache().GetResponseHeadForTesting(*cache_key);
+  base::Time second_response_time = response->response_time;
+
+  // Compare response time to make sure the stored response is updated.
+  ASSERT_LT(first_response_time, second_response_time);
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, EvictLeastRecentlyUsed) {
+  const int kBodySize = kMaxTotalSize / 2;
+
+  // Stores two responses to consume the full budget of the in-memory cache.
+  ResourceRequest request1 = CreateRequest(
+      base::StringPrintf("/cacheable?id=1&body-size=%d", kBodySize));
+  StoreResponseToMemoryCache(request1);
+
+  ResourceRequest request2 = CreateRequest(
+      base::StringPrintf("/cacheable?id=2&body-size=%d", kBodySize));
+  StoreResponseToMemoryCache(request2);
+
+  ASSERT_TRUE(CanServeFromMemoryCache(request1));
+  ASSERT_TRUE(CanServeFromMemoryCache(request2));
+
+  // Stores the third response. It should evict the first stored response.
+  ResourceRequest request3 = CreateRequest(
+      base::StringPrintf("/cacheable?id=3&body-size=%d", kBodySize));
+  StoreResponseToMemoryCache(request3);
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request1));
+  ASSERT_TRUE(CanServeFromMemoryCache(request2));
+  ASSERT_TRUE(CanServeFromMemoryCache(request3));
+}
+
+TEST_F(NetworkServiceMemoryCacheTest, ClientDisconnectedWhileCaching) {
+  ResourceRequest request = CreateRequest("/cacheable");
+  LoaderPair pair = CreateLoaderAndStart(request);
+
+  pair.client->RunUntilResponseReceived();
+  pair.client->Unbind();
+
+  ASSERT_TRUE(pair.loader_remote.is_connected());
+  base::RunLoop loop;
+  pair.loader_remote.set_disconnect_handler(loop.QuitClosure());
+  loop.Run();
+
+  ASSERT_FALSE(CanServeFromMemoryCache(request));
+}
+
+}  // namespace network
diff --git a/services/network/network_service_memory_cache_writer.cc b/services/network/network_service_memory_cache_writer.cc
new file mode 100644
index 0000000..5dec092
--- /dev/null
+++ b/services/network/network_service_memory_cache_writer.cc
@@ -0,0 +1,60 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "services/network/network_service_memory_cache_writer.h"
+
+#include "base/trace_event/common/trace_event_common.h"
+#include "base/trace_event/trace_event.h"
+#include "base/trace_event/typed_macros.h"
+#include "services/network/network_service_memory_cache.h"
+
+namespace network {
+
+NetworkServiceMemoryCacheWriter::NetworkServiceMemoryCacheWriter(
+    base::WeakPtr<NetworkServiceMemoryCache> cache,
+    uint64_t trace_id,
+    std::string cache_key,
+    net::URLRequest* url_request,
+    const mojom::URLResponseHeadPtr& response_head)
+    : cache_(std::move(cache)),
+      trace_id_(trace_id),
+      cache_key_(std::move(cache_key)),
+      url_request_(url_request),
+      response_head_(response_head.Clone()) {
+  DCHECK(cache_);
+  DCHECK(url_request_);
+  TRACE_EVENT_NESTABLE_ASYNC_BEGIN1(
+      "loading", "NetworkServiceMemoryCacheWriter", TRACE_ID_LOCAL(trace_id_),
+      "key", cache_key_);
+}
+
+NetworkServiceMemoryCacheWriter::~NetworkServiceMemoryCacheWriter() {
+  TRACE_EVENT_NESTABLE_ASYNC_END0("loading", "NetworkServiceMemoryCacheWriter",
+                                  TRACE_ID_LOCAL(trace_id_));
+}
+
+void NetworkServiceMemoryCacheWriter::OnDataRead(const char* buf, int result) {
+  TRACE_EVENT_NESTABLE_ASYNC_INSTANT1(
+      "loading", "NetworkServiceMemoryCacheWriter::OnDataRead",
+      TRACE_ID_LOCAL(trace_id_), "result", result);
+
+  if (result > 0)
+    received_data_.insert(received_data_.end(), buf, buf + result);
+}
+
+void NetworkServiceMemoryCacheWriter::OnCompleted(
+    const URLLoaderCompletionStatus& status) {
+  TRACE_EVENT_NESTABLE_ASYNC_INSTANT2(
+      "loading", "NetworkServiceMemoryCacheWriter::OnCompleted",
+      TRACE_ID_LOCAL(trace_id_), "result", status.error_code, "total_size",
+      received_data_.size());
+
+  if (cache_) {
+    cache_->StoreResponse(cache_key_, status, std::move(response_head_),
+                          std::move(received_data_));
+  }
+  // `this` will be deleted by the owner.
+}
+
+}  // namespace network
diff --git a/services/network/network_service_memory_cache_writer.h b/services/network/network_service_memory_cache_writer.h
new file mode 100644
index 0000000..0a68c42
--- /dev/null
+++ b/services/network/network_service_memory_cache_writer.h
@@ -0,0 +1,64 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_WRITER_H_
+#define SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_WRITER_H_
+
+#include <string>
+#include <vector>
+
+#include "base/memory/raw_ptr.h"
+#include "base/memory/weak_ptr.h"
+#include "services/network/public/mojom/url_loader_completion_status.mojom.h"
+#include "services/network/public/mojom/url_response_head.mojom.h"
+
+namespace net {
+class URLRequest;
+}  // namespace net
+
+namespace network {
+
+class NetworkServiceMemoryCache;
+
+// Duplicates an HTTP response that comes from the underlying layer, i.e., a
+// URLLoader. The URLLoader owns an instance of this class.
+//
+// When the URLLoader completed successfully, the duplicated response is stored
+// into the in-memory cache so that it can be served without disk access until
+// it gets evicted.
+class COMPONENT_EXPORT(NETWORK_SERVICE) NetworkServiceMemoryCacheWriter {
+ public:
+  NetworkServiceMemoryCacheWriter(
+      base::WeakPtr<NetworkServiceMemoryCache> cache,
+      uint64_t trace_id,
+      std::string cache_key,
+      net::URLRequest* request,
+      const mojom::URLResponseHeadPtr& response_head);
+
+  ~NetworkServiceMemoryCacheWriter();
+
+  // Called when the owner received response content.
+  void OnDataRead(const char* buf, int result);
+
+  // Called when the owner completed.
+  void OnCompleted(const URLLoaderCompletionStatus& status);
+
+ private:
+  base::WeakPtr<NetworkServiceMemoryCache> cache_;
+
+  // Used for tracing.
+  const uint64_t trace_id_;
+
+  std::string cache_key_;
+
+  // `url_request_` must outlive `this`. The owner owns `url_request_`.
+  const raw_ptr<net::URLRequest> url_request_;
+
+  mojom::URLResponseHeadPtr response_head_;
+  std::vector<unsigned char> received_data_;
+};
+
+}  // namespace network
+
+#endif  // SERVICES_NETWORK_NETWORK_SERVICE_MEMORY_CACHE_WRITER_H_
diff --git a/services/network/public/cpp/features.cc b/services/network/public/cpp/features.cc
index 4be1c69..8912c7d6 100644
--- a/services/network/public/cpp/features.cc
+++ b/services/network/public/cpp/features.cc
@@ -266,6 +266,9 @@
 const base::Feature kBatchSimpleURLLoader{"BatchSimpleURLLoader",
                                           base::FEATURE_DISABLED_BY_DEFAULT};
 
+const base::Feature kNetworkServiceMemoryCache{
+    "NetworkServiceMemoryCache", base::FEATURE_DISABLED_BY_DEFAULT};
+
 // Do not send TLS client certificates in CORS preflight. Omit all client certs
 // and continue the handshake without sending one if requested.
 const base::Feature kOmitCorsClientCert{"OmitCorsClientCert",
diff --git a/services/network/public/cpp/features.h b/services/network/public/cpp/features.h
index b6c1e50..0bded2a 100644
--- a/services/network/public/cpp/features.h
+++ b/services/network/public/cpp/features.h
@@ -107,6 +107,9 @@
 extern const base::Feature kBatchSimpleURLLoader;
 
 COMPONENT_EXPORT(NETWORK_CPP)
+extern const base::Feature kNetworkServiceMemoryCache;
+
+COMPONENT_EXPORT(NETWORK_CPP)
 extern const base::Feature kOmitCorsClientCert;
 
 COMPONENT_EXPORT(NETWORK_CPP)
diff --git a/services/network/url_loader.cc b/services/network/url_loader.cc
index e70cf2a3..54f5037 100644
--- a/services/network/url_loader.cc
+++ b/services/network/url_loader.cc
@@ -63,6 +63,7 @@
 #include "net/url_request/url_request_context_getter.h"
 #include "services/network/chunked_data_pipe_upload_data_stream.h"
 #include "services/network/data_pipe_element_reader.h"
+#include "services/network/network_service_memory_cache_writer.h"
 #include "services/network/public/cpp/client_hints.h"
 #include "services/network/public/cpp/constants.h"
 #include "services/network/public/cpp/corb/orb_impl.h"
@@ -949,8 +950,8 @@
     // initializing before getting deleted.
     base::SequencedTaskRunnerHandle::Get()->PostTask(
         FROM_HERE,
-        base::BindOnce(&URLLoader::NotifyCompleted, base::Unretained(this),
-                       net::ERR_ACCESS_DENIED));
+        base::BindOnce(&URLLoader::NotifyCompleted,
+                       weak_ptr_factory_.GetWeakPtr(), net::ERR_ACCESS_DENIED));
     return;
   }
   url_request_->LogBlockedBy("Opening Files");
@@ -969,7 +970,7 @@
     // initializing before getting deleted.
     base::SequencedTaskRunnerHandle::Get()->PostTask(
         FROM_HERE, base::BindOnce(&URLLoader::NotifyCompleted,
-                                  base::Unretained(this), error_code));
+                                  weak_ptr_factory_.GetWeakPtr(), error_code));
     return;
   }
   scoped_refptr<base::SequencedTaskRunner> task_runner =
@@ -1119,6 +1120,8 @@
   // requests by the same client.
   private_network_access_checker_.ResetForRedirect();
 
+  memory_cache_writer_.reset();
+
   // Removing headers can't make the set of pre-existing headers unsafe, but
   // adding headers can.
   if (!AreRequestHeadersSafe(modified_headers) ||
@@ -1545,6 +1548,11 @@
     return;
   }
 
+  if (memory_cache_) {
+    memory_cache_writer_ = memory_cache_->MaybeCreateWriter(
+        url_request_.get(), request_destination_, response_);
+  }
+
   ContinueOnResponseStarted();
 }
 
@@ -1744,6 +1752,11 @@
   DCHECK(read_in_progress_);
   read_in_progress_ = false;
 
+  if (memory_cache_writer_ && pending_write_) {
+    memory_cache_writer_->OnDataRead(
+        pending_write_->buffer() + pending_write_buffer_offset_, num_bytes);
+  }
+
   size_t new_data_offset = pending_write_buffer_offset_;
   if (num_bytes > 0) {
     pending_write_buffer_offset_ += num_bytes;
@@ -2087,6 +2100,9 @@
 
     status.pervasive_payload_requested = pervasive_payload_requested_;
 
+    if (memory_cache_writer_)
+      memory_cache_writer_->OnCompleted(status);
+
     url_loader_client_.Get()->OnComplete(status);
   }
 
@@ -2378,11 +2394,15 @@
   status.decoded_body_length = 0;
   status.should_report_corb_blocking = should_report_corb_blocking;
   status.blocked_by_response_reason = reason;
+
+  if (memory_cache_writer_)
+    memory_cache_writer_->OnCompleted(status);
   url_loader_client_.Get()->OnComplete(status);
 
   // Reset the connection to the URLLoaderClient.  This helps ensure that we
   // won't accidentally leak any data to the renderer from this point on.
   url_loader_client_.Reset();
+  memory_cache_writer_.reset();
 }
 
 URLLoader::BlockResponseForCorbResult URLLoader::BlockResponseForCorb(
diff --git a/services/network/url_loader.h b/services/network/url_loader.h
index 63ee006c..158eaacb 100644
--- a/services/network/url_loader.h
+++ b/services/network/url_loader.h
@@ -29,6 +29,7 @@
 #include "net/url_request/url_request.h"
 #include "services/network/keepalive_statistics_recorder.h"
 #include "services/network/network_service.h"
+#include "services/network/network_service_memory_cache.h"
 #include "services/network/private_network_access_checker.h"
 #include "services/network/public/cpp/corb/corb_api.h"
 #include "services/network/public/cpp/cors/cors_error_status.h"
@@ -184,6 +185,10 @@
 
   ~URLLoader() override;
 
+  void SetMemoryCache(base::WeakPtr<NetworkServiceMemoryCache> memory_cache) {
+    memory_cache_ = std::move(memory_cache);
+  }
+
   // mojom::URLLoader implementation:
   void FollowRedirect(
       const std::vector<std::string>& removed_headers,
@@ -562,6 +567,9 @@
 
   base::WeakPtr<KeepaliveStatisticsRecorder> keepalive_statistics_recorder_;
 
+  base::WeakPtr<NetworkServiceMemoryCache> memory_cache_;
+  std::unique_ptr<NetworkServiceMemoryCacheWriter> memory_cache_writer_;
+
   bool first_auth_attempt_ = true;
 
   std::unique_ptr<ScopedThrottlingToken> throttling_token_;
diff --git a/services/network/url_loader_factory.cc b/services/network/url_loader_factory.cc
index ce3c509..286cd5df 100644
--- a/services/network/url_loader_factory.cc
+++ b/services/network/url_loader_factory.cc
@@ -348,6 +348,9 @@
       std::move(devtools_observer), std::move(accept_ch_frame_observer),
       third_party_cookies_enabled);
 
+  if (context_->GetMemoryCache())
+    loader->SetMemoryCache(context_->GetMemoryCache()->GetWeakPtr());
+
   cors_url_loader_factory_->OnURLLoaderCreated(std::move(loader));
 }
 
diff --git a/services/tracing/public/cpp/BUILD.gn b/services/tracing/public/cpp/BUILD.gn
index bdaafba..e15d33d 100644
--- a/services/tracing/public/cpp/BUILD.gn
+++ b/services/tracing/public/cpp/BUILD.gn
@@ -56,6 +56,8 @@
     sources += [
       "base_agent.cc",
       "base_agent.h",
+      "perfetto/custom_event_recorder.cc",
+      "perfetto/custom_event_recorder.h",
       "perfetto/dummy_producer.cc",
       "perfetto/dummy_producer.h",
       "perfetto/interning_index.h",
diff --git a/services/tracing/public/cpp/perfetto/custom_event_recorder.cc b/services/tracing/public/cpp/perfetto/custom_event_recorder.cc
new file mode 100644
index 0000000..86d7b52
--- /dev/null
+++ b/services/tracing/public/cpp/perfetto/custom_event_recorder.cc
@@ -0,0 +1,313 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "services/tracing/public/cpp/perfetto/custom_event_recorder.h"
+
+#include "base/base64.h"
+#include "base/callback_helpers.h"
+#include "base/metrics/histogram_samples.h"
+#include "base/metrics/metrics_hashes.h"
+#include "base/metrics/statistics_recorder.h"
+#include "base/metrics/user_metrics.h"
+#include "base/no_destructor.h"
+#include "base/pickle.h"
+#include "base/synchronization/lock.h"
+#include "base/time/time.h"
+#include "base/trace_event/trace_config.h"
+#include "base/trace_event/typed_macros.h"
+#include "build/build_config.h"
+#include "services/tracing/public/cpp/perfetto/perfetto_traced_process.h"
+#include "services/tracing/public/cpp/perfetto/trace_string_lookup.h"
+#include "third_party/perfetto/include/perfetto/tracing/internal/track_event_internal.h"
+#include "third_party/perfetto/include/perfetto/tracing/track_event_interned_data_index.h"
+#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_histogram_sample.pbzero.h"
+#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_process_descriptor.pbzero.h"
+#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_user_event.pbzero.h"
+
+#if BUILDFLAG(IS_ANDROID)
+#include "base/android/application_status_listener.h"
+#include "base/trace_event/application_state_proto_android.h"
+#endif
+
+using TraceConfig = base::trace_event::TraceConfig;
+using perfetto::protos::pbzero::ChromeProcessDescriptor;
+
+namespace tracing {
+namespace {
+
+base::SequencedTaskRunner* GetTaskRunner() {
+  return PerfettoTracedProcess::Get()
+      ->GetTaskRunner()
+      ->GetOrCreateTaskRunner()
+      .get();
+}
+
+struct InternedHistogramName
+    : public perfetto::TrackEventInternedDataIndex<
+          InternedHistogramName,
+          perfetto::protos::pbzero::InternedData::kHistogramNamesFieldNumber,
+          const char*> {
+  static void Add(perfetto::protos::pbzero::InternedData* interned_data,
+                  size_t iid,
+                  const char* histogram_name) {
+    auto* msg = interned_data->add_histogram_names();
+    msg->set_iid(iid);
+    msg->set_name(histogram_name);
+  }
+};
+
+}  // namespace
+
+CustomEventRecorder::CustomEventRecorder() {
+  DETACH_FROM_SEQUENCE(perfetto_sequence_checker_);
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  perfetto::TrackEvent::AddSessionObserver(this);
+#endif
+}
+
+CustomEventRecorder::~CustomEventRecorder()
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+{
+  perfetto::TrackEvent::RemoveSessionObserver(this);
+}
+#else
+    = default;
+#endif
+
+// static
+CustomEventRecorder* CustomEventRecorder::GetInstance() {
+  static base::NoDestructor<CustomEventRecorder> instance;
+  return instance.get();
+}
+
+// static
+void CustomEventRecorder::EmitRecurringUpdates() {
+#if BUILDFLAG(IS_ANDROID)
+  static const ChromeProcessDescriptor::ProcessType process_type =
+      GetProcessType(
+          base::trace_event::TraceLog::GetInstance()->process_name());
+  if (process_type == ChromeProcessDescriptor::PROCESS_BROWSER) {
+    auto state = base::android::ApplicationStatusListener::GetState();
+    TRACE_APPLICATION_STATE(state);
+  }
+#endif
+}
+
+void CustomEventRecorder::OnSetup(
+    const perfetto::DataSourceBase::SetupArgs& args) {
+  GetTaskRunner()->PostTask(
+      FROM_HERE, base::BindOnce(&CustomEventRecorder::OnTracingStarted,
+                                base::Unretained(this), *args.config));
+}
+
+void CustomEventRecorder::OnStop(
+    const perfetto::DataSourceBase::StopArgs& args) {
+  std::function<void()> finish_async_stop = args.HandleStopAsynchronously();
+  base::OnceClosure stop_callback = base::BindOnce(
+      [](std::function<void()> callback) { callback(); }, finish_async_stop);
+  GetTaskRunner()->PostTask(
+      FROM_HERE,
+      base::BindOnce(&CustomEventRecorder::OnTracingStopped,
+                     base::Unretained(this), std::move(stop_callback)));
+}
+
+void CustomEventRecorder::WillClearIncrementalState(
+    const perfetto::DataSourceBase::ClearIncrementalStateArgs&) {
+  EmitRecurringUpdates();
+}
+
+void CustomEventRecorder::OnStartupTracingStarted(
+    const TraceConfig& trace_config,
+    bool privacy_filtering_enabled) {
+  DCHECK(monitored_histograms_.empty());
+  if (trace_config.IsCategoryGroupEnabled(
+          TRACE_DISABLED_BY_DEFAULT("histogram_samples")) &&
+      trace_config.histogram_names().empty()) {
+    // The global callback can be added early at startup before main message
+    // loop is created. But histogram specific observers need task runner and
+    // are added when tracing service is setup in OnTracingStarted() instead.
+    base::StatisticsRecorder::SetGlobalSampleCallback(
+        &CustomEventRecorder::OnMetricsSampleCallback);
+  }
+  {
+    base::AutoLock lock(lock_);
+    privacy_filtering_enabled_ = privacy_filtering_enabled;
+  }
+}
+
+// TODO(b/237761718): Support multiple simultaneous tracing sessions.
+// * Read privacy_filtering_enabled from EventContext.
+// * Make monitored_histograms_ a map keyed on session ID.
+void CustomEventRecorder::OnTracingStarted(
+    const perfetto::DataSourceConfig& data_source_config) {
+  DCHECK_CALLED_ON_VALID_SEQUENCE(perfetto_sequence_checker_);
+
+  auto trace_config =
+      TraceConfig(data_source_config.chrome_config().trace_config());
+
+  bool privacy_filtering_enabled =
+      data_source_config.chrome_config().privacy_filtering_enabled();
+  {
+    base::AutoLock lock(lock_);
+    privacy_filtering_enabled_ = privacy_filtering_enabled;
+  }
+
+  EmitRecurringUpdates();
+  ResetHistograms(trace_config);
+
+  DCHECK(monitored_histograms_.empty());
+  if (trace_config.IsCategoryGroupEnabled(
+          TRACE_DISABLED_BY_DEFAULT("histogram_samples"))) {
+    if (trace_config.histogram_names().empty() &&
+        !base::StatisticsRecorder::global_sample_callback()) {
+      // Add the global callback if it wasn't already.
+      base::StatisticsRecorder::SetGlobalSampleCallback(
+          &CustomEventRecorder::OnMetricsSampleCallback);
+    }
+    for (const std::string& histogram_name : trace_config.histogram_names()) {
+      monitored_histograms_.emplace_back(
+          std::make_unique<
+              base::StatisticsRecorder::ScopedHistogramSampleObserver>(
+              histogram_name,
+              base::BindRepeating(
+                  &CustomEventRecorder::OnMetricsSampleCallback)));
+    }
+  }
+
+  if (trace_config.IsCategoryGroupEnabled(
+          TRACE_DISABLED_BY_DEFAULT("user_action_samples"))) {
+    auto task_runner = base::GetRecordActionTaskRunner();
+    if (task_runner) {
+      task_runner->PostTask(
+          FROM_HERE, base::BindOnce([]() {
+            base::AddActionCallback(
+                CustomEventRecorder::GetInstance()->user_action_callback_);
+          }));
+    }
+  }
+}
+
+void CustomEventRecorder::OnTracingStopped(
+    base::OnceClosure stop_complete_callback) {
+  DCHECK_CALLED_ON_VALID_SEQUENCE(perfetto_sequence_checker_);
+
+  // Write metadata events etc.
+  LogHistograms();
+
+  base::StatisticsRecorder::SetGlobalSampleCallback(nullptr);
+  monitored_histograms_.clear();
+
+  auto task_runner = base::GetRecordActionTaskRunner();
+  if (task_runner) {
+    task_runner->PostTask(
+        FROM_HERE, base::BindOnce([]() {
+          base::RemoveActionCallback(
+              CustomEventRecorder::GetInstance()->user_action_callback_);
+        }));
+  }
+
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  std::move(stop_complete_callback).Run();
+#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+}
+
+bool CustomEventRecorder::IsPrivacyFilteringEnabled() {
+  base::AutoLock lock(lock_);
+  return privacy_filtering_enabled_;
+}
+
+void CustomEventRecorder::OnUserActionSampleCallback(
+    const std::string& action,
+    base::TimeTicks action_time) {
+  constexpr uint64_t kGlobalInstantTrackId = 0;
+  TRACE_EVENT_INSTANT(
+      TRACE_DISABLED_BY_DEFAULT("user_action_samples"), "UserAction",
+      perfetto::Track::Global(kGlobalInstantTrackId),
+      [&](perfetto::EventContext ctx) {
+        bool privacy_filtering_enabled =
+            CustomEventRecorder::GetInstance()->IsPrivacyFilteringEnabled();
+        perfetto::protos::pbzero::ChromeUserEvent* new_sample =
+            ctx.event()->set_chrome_user_event();
+        if (!privacy_filtering_enabled) {
+          new_sample->set_action(action);
+        }
+        new_sample->set_action_hash(base::HashMetricName(action));
+      });
+}
+
+void CustomEventRecorder::LogHistogram(base::HistogramBase* histogram) {
+  if (!histogram) {
+    return;
+  }
+  // For the purpose of calculating metrics from histograms we only want the
+  // delta of the events.
+  auto samples = histogram->SnapshotSamples();
+
+  // If there were HistogramSamples recorded during startup, then those should
+  // be subtracted from the overall set. This way we only report the samples
+  // that occurred during the run.
+  auto it = startup_histogram_samples_.find(histogram->histogram_name());
+  if (it != startup_histogram_samples_.end()) {
+    samples->Subtract(*it->second.get());
+  }
+  base::Pickle pickle;
+  samples->Serialize(&pickle);
+  std::string buckets;
+  base::Base64Encode(
+      std::string(static_cast<const char*>(pickle.data()), pickle.size()),
+      &buckets);
+  TRACE_EVENT_INSTANT2("benchmark,uma", "UMAHistogramSamples",
+                       TRACE_EVENT_SCOPE_PROCESS, "name",
+                       histogram->histogram_name(), "buckets", buckets);
+}
+
+void CustomEventRecorder::ResetHistograms(const TraceConfig& trace_config) {
+  histograms_.clear();
+  startup_histogram_samples_.clear();
+  for (const std::string& histogram_name : trace_config.histogram_names()) {
+    histograms_.push_back(histogram_name);
+    auto* histogram = base::StatisticsRecorder::FindHistogram(histogram_name);
+    if (!histogram) {
+      continue;
+    }
+
+    // For the purpose of calculating metrics from histograms we only want the
+    // delta of the events. However we do not want to emit the results when
+    // resetting. This will allow LogHistogram to emit one UMAHistogramSamples
+    // which encompasses only the histograms recorded during the trace. We
+    // cache the initial HistogramSamples so that they can be subtracted from
+    // the full snapshot at the end.
+    startup_histogram_samples_.emplace(histogram_name,
+                                       histogram->SnapshotSamples());
+  }
+}
+
+void CustomEventRecorder::LogHistograms() {
+  for (const std::string& histogram_name : histograms_) {
+    LogHistogram(base::StatisticsRecorder::FindHistogram(histogram_name));
+  }
+}
+
+// static
+void CustomEventRecorder::OnMetricsSampleCallback(
+    const char* histogram_name,
+    uint64_t name_hash,
+    base::HistogramBase::Sample sample) {
+  TRACE_EVENT_INSTANT(
+      TRACE_DISABLED_BY_DEFAULT("histogram_samples"), "HistogramSample",
+      [&](perfetto::EventContext ctx) {
+        bool privacy_filtering_enabled =
+            CustomEventRecorder::GetInstance()->IsPrivacyFilteringEnabled();
+        perfetto::protos::pbzero::ChromeHistogramSample* new_sample =
+            ctx.event()->set_chrome_histogram_sample();
+        new_sample->set_name_hash(name_hash);
+        new_sample->set_sample(sample);
+        if (!privacy_filtering_enabled) {
+          size_t iid = InternedHistogramName::Get(&ctx, histogram_name);
+          new_sample->set_name_iid(iid);
+        }
+      });
+}
+
+}  // namespace tracing
diff --git a/services/tracing/public/cpp/perfetto/custom_event_recorder.h b/services/tracing/public/cpp/perfetto/custom_event_recorder.h
new file mode 100644
index 0000000..9136f5d
--- /dev/null
+++ b/services/tracing/public/cpp/perfetto/custom_event_recorder.h
@@ -0,0 +1,90 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef SERVICES_TRACING_PUBLIC_CPP_PERFETTO_CUSTOM_EVENT_RECORDER_H_
+#define SERVICES_TRACING_PUBLIC_CPP_PERFETTO_CUSTOM_EVENT_RECORDER_H_
+
+#include "base/component_export.h"
+#include "base/metrics/histogram_samples.h"
+#include "base/metrics/statistics_recorder.h"
+#include "base/metrics/user_metrics.h"
+#include "base/sequence_checker.h"
+#include "base/trace_event/trace_config.h"
+#include "base/trace_event/typed_macros.h"
+#include "third_party/perfetto/include/perfetto/tracing/internal/track_event_internal.h"
+
+namespace tracing {
+
+// A class that accompanies TraceEventDataSource to record some additional
+// events like UMA histogram samples or user action samples.
+class COMPONENT_EXPORT(TRACING_CPP) CustomEventRecorder
+    : public perfetto::TrackEventSessionObserver {
+ public:
+  static CustomEventRecorder* GetInstance();
+  static void EmitRecurringUpdates();
+
+  CustomEventRecorder(const CustomEventRecorder&) = delete;
+  CustomEventRecorder& operator=(const CustomEventRecorder&) = delete;
+
+  // perfetto::TrackEventSessionObserver implementation
+  void OnSetup(const perfetto::DataSourceBase::SetupArgs&) override;
+  void OnStop(const perfetto::DataSourceBase::StopArgs&) override;
+  void WillClearIncrementalState(
+      const perfetto::DataSourceBase::ClearIncrementalStateArgs&) override;
+
+  void OnStartupTracingStarted(
+      const base::trace_event::TraceConfig& trace_config,
+      bool privacy_filtering_enabled);
+  void OnTracingStarted(const perfetto::DataSourceConfig& data_source_config);
+  void OnTracingStopped(base::OnceClosure stop_complete_callback);
+
+  // Registered as a callback to receive every action recorded using
+  // base::RecordAction(), when tracing is enabled with a histogram category.
+  static void OnUserActionSampleCallback(const std::string& action,
+                                         base::TimeTicks action_time);
+  // Records trace event for a histogram sample. When histogram_samples category
+  // is enabled, it is registered with base::StatisticsRecorder to monitor the
+  // histograms listed in the trace config. If there are no histograms listed in
+  // the trace config, all the histograms will be monitored.
+  static void OnMetricsSampleCallback(const char* histogram_name,
+                                      uint64_t name_hash,
+                                      base::HistogramBase::Sample sample);
+  bool IsPrivacyFilteringEnabled();
+
+ private:
+  friend class base::NoDestructor<CustomEventRecorder>;
+
+  CustomEventRecorder();
+  ~CustomEventRecorder() override;
+
+  SEQUENCE_CHECKER(perfetto_sequence_checker_);
+  // Extracts UMA histogram names that should be logged in traces and logs their
+  // starting values.
+  void ResetHistograms(const base::trace_event::TraceConfig& trace_config);
+  // Logs selected UMA histogram.
+  void LogHistograms();
+  // Logs a given histogram in traces.
+  void LogHistogram(base::HistogramBase* histogram);
+
+  // For each of the Histogram that we are tracking, cache the snapshot of their
+  // HistogramSamples from before tracing began. So that we can calculate the
+  // delta when we go to LogHistograms.
+  std::map<std::string, std::unique_ptr<base::HistogramSamples>>
+      startup_histogram_samples_;
+  std::vector<std::string> histograms_;
+  // Stores the registered histogram callbacks for which OnMetricsSampleCallback
+  // was set individually.
+  std::vector<
+      std::unique_ptr<base::StatisticsRecorder::ScopedHistogramSampleObserver>>
+      monitored_histograms_;
+  base::ActionCallback user_action_callback_ =
+      base::BindRepeating(&CustomEventRecorder::OnUserActionSampleCallback);
+
+  base::Lock lock_;
+  bool privacy_filtering_enabled_ GUARDED_BY(lock_) = false;
+};
+
+}  // namespace tracing
+
+#endif  // SERVICES_TRACING_PUBLIC_CPP_PERFETTO_CUSTOM_EVENT_RECORDER_H_
diff --git a/services/tracing/public/cpp/perfetto/perfetto_traced_process.cc b/services/tracing/public/cpp/perfetto/perfetto_traced_process.cc
index f7eebd67..b0f11f78 100644
--- a/services/tracing/public/cpp/perfetto/perfetto_traced_process.cc
+++ b/services/tracing/public/cpp/perfetto/perfetto_traced_process.cc
@@ -14,6 +14,7 @@
 #include "base/trace_event/trace_log.h"
 #include "base/tracing/perfetto_platform.h"
 #include "build/build_config.h"
+#include "services/tracing/public/cpp/perfetto/custom_event_recorder.h"
 #include "services/tracing/public/cpp/perfetto/dummy_producer.h"
 #include "services/tracing/public/cpp/perfetto/perfetto_tracing_backend.h"
 #include "services/tracing/public/cpp/perfetto/producer_client.h"
@@ -411,6 +412,7 @@
 #if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
   perfetto::TrackEvent::Register();
   SetTrackDescriptors();
+  CustomEventRecorder::GetInstance();
 #endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
 }
 
diff --git a/services/tracing/public/cpp/perfetto/trace_event_data_source.cc b/services/tracing/public/cpp/perfetto/trace_event_data_source.cc
index 5aa48af8..02e0fb6 100644
--- a/services/tracing/public/cpp/perfetto/trace_event_data_source.cc
+++ b/services/tracing/public/cpp/perfetto/trace_event_data_source.cc
@@ -10,7 +10,6 @@
 #include <utility>
 #include <vector>
 
-#include "base/base64.h"
 #include "base/bind.h"
 #include "base/callback_helpers.h"
 #include "base/command_line.h"
@@ -19,12 +18,7 @@
 #include "base/json/json_writer.h"
 #include "base/memory/ptr_util.h"
 #include "base/memory/ref_counted_memory.h"
-#include "base/metrics/histogram_samples.h"
-#include "base/metrics/metrics_hashes.h"
-#include "base/metrics/statistics_recorder.h"
-#include "base/metrics/user_metrics.h"
 #include "base/no_destructor.h"
-#include "base/pickle.h"
 #include "base/rand_util.h"
 #include "base/sequence_checker.h"
 #include "base/strings/pattern.h"
@@ -40,6 +34,7 @@
 #include "base/tracing/tracing_tls.h"
 #include "build/build_config.h"
 #include "components/tracing/common/tracing_switches.h"
+#include "services/tracing/public/cpp/perfetto/custom_event_recorder.h"
 #include "services/tracing/public/cpp/perfetto/macros.h"
 #include "services/tracing/public/cpp/perfetto/perfetto_producer.h"
 #include "services/tracing/public/cpp/perfetto/perfetto_traced_process.h"
@@ -55,20 +50,14 @@
 #include "third_party/perfetto/include/perfetto/ext/tracing/core/trace_writer.h"
 #include "third_party/perfetto/include/perfetto/protozero/message.h"
 #include "third_party/perfetto/include/perfetto/tracing/track.h"
-#include "third_party/perfetto/include/perfetto/tracing/track_event_interned_data_index.h"
 #include "third_party/perfetto/protos/perfetto/trace/chrome/chrome_metadata.pbzero.h"
 #include "third_party/perfetto/protos/perfetto/trace/chrome/chrome_trace_event.pbzero.h"
 #include "third_party/perfetto/protos/perfetto/trace/trace_packet.pbzero.h"
-#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_histogram_sample.pbzero.h"
-#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_process_descriptor.pbzero.h"
-#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_user_event.pbzero.h"
 #include "third_party/perfetto/protos/perfetto/trace/track_event/process_descriptor.pbzero.h"
 #include "third_party/perfetto/protos/perfetto/trace/track_event/track_descriptor.pbzero.h"
 
 #if BUILDFLAG(IS_ANDROID)
-#include "base/android/application_status_listener.h"
 #include "base/android/build_info.h"
-#include "base/trace_event/application_state_proto_android.h"
 #endif
 
 using TraceLog = base::trace_event::TraceLog;
@@ -86,18 +75,6 @@
 
 TraceEventMetadataSource* g_trace_event_metadata_source_for_testing = nullptr;
 
-void EmitRecurringUpdates() {
-#if BUILDFLAG(IS_ANDROID)
-  static const ChromeProcessDescriptor::ProcessType process_type =
-      GetProcessType(
-          base::trace_event::TraceLog::GetInstance()->process_name());
-  if (process_type == ChromeProcessDescriptor::PROCESS_BROWSER) {
-    auto state = base::android::ApplicationStatusListener::GetState();
-    TRACE_APPLICATION_STATE(state);
-  }
-#endif
-}
-
 static_assert(
     sizeof(TraceEventDataSource::SessionFlags) <= sizeof(uint64_t),
     "SessionFlags should remain small to ensure lock-free atomic operations");
@@ -660,20 +637,9 @@
       << "SessionFlags are not atomic! We rely on efficient lock-free look-up "
          "of the session flags when emitting a trace event.";
   g_trace_event_data_source_for_testing = this;
-
-#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-  perfetto::TrackEvent::AddSessionObserver(this);
-#endif
 }
 
-TraceEventDataSource::~TraceEventDataSource()
-#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-{
-  perfetto::TrackEvent::RemoveSessionObserver(this);
-}
-#else   // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-    = default;
-#endif  // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+TraceEventDataSource::~TraceEventDataSource() = default;
 
 void TraceEventDataSource::RegisterStartupHooks() {
 #if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
@@ -687,24 +653,10 @@
 
 void TraceEventDataSource::RegisterWithTraceLog(
     const base::trace_event::TraceConfig& trace_config) {
-#if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
   TraceLog::GetInstance()->SetAddTraceEventOverrides(
       &TraceEventDataSource::OnAddLegacyTraceEvent,
       &TraceEventDataSource::FlushCurrentThread,
       &TraceEventDataSource::OnUpdateDuration);
-#endif  // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-
-  DCHECK(monitored_histograms_.empty());
-  if (trace_config.IsCategoryGroupEnabled(
-          TRACE_DISABLED_BY_DEFAULT("histogram_samples")) &&
-      trace_config.histogram_names().empty()) {
-    // The global callback can be added early at startup before main message
-    // loop is created. But histogram specific observers need task runner and
-    // are added when tracing service is setup in StartTracingInternal()
-    // instead.
-    base::StatisticsRecorder::SetGlobalSampleCallback(
-        &TraceEventDataSource::OnMetricsSampleCallback);
-  }
 
   base::AutoLock l(lock_);
   is_enabled_ = true;
@@ -794,6 +746,10 @@
     PerfettoProducer* producer,
     const base::trace_event::TraceConfig& trace_config,
     bool privacy_filtering_enabled) {
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  NOTREACHED() << "This is not expected to run in SDK build.";
+#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+
   {
     AutoLockWithDeferredTaskPosting lock(lock_);
     // Do not enable startup tracing if trace log is being flushed. The
@@ -827,6 +783,8 @@
   config_for_trace_log.SetTraceBufferSizeInEvents(0);
 
   RegisterWithTraceLog(config_for_trace_log);
+  CustomEventRecorder::GetInstance()->OnStartupTracingStarted(
+      trace_config, privacy_filtering_enabled);
 
 #if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
   uint8_t modes = base::trace_event::TraceLog::RECORDING_MODE;
@@ -928,26 +886,6 @@
   }
 }
 
-#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-void TraceEventDataSource::OnSetup(
-    const perfetto::DataSourceBase::SetupArgs& args) {
-  GetTaskRunner()->PostTask(
-      FROM_HERE, base::BindOnce(&TraceEventDataSource::StartTracingImpl,
-                                base::Unretained(this), nullptr, *args.config));
-}
-
-void TraceEventDataSource::OnStop(
-    const perfetto::DataSourceBase::StopArgs& args) {
-  std::function<void()> finish_async_stop = args.HandleStopAsynchronously();
-  base::OnceClosure stop_callback = base::BindOnce(
-      [](std::function<void()> callback) { callback(); }, finish_async_stop);
-  GetTaskRunner()->PostTask(
-      FROM_HERE,
-      base::BindOnce(&TraceEventDataSource::StopTracingImpl,
-                     base::Unretained(this), std::move(stop_callback)));
-}
-#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-
 void TraceEventDataSource::StartTracingImpl(
     PerfettoProducer* producer,
     const perfetto::DataSourceConfig& data_source_config) {
@@ -978,6 +916,10 @@
 void TraceEventDataSource::StartTracingInternal(
     PerfettoProducer* producer,
     const perfetto::DataSourceConfig& data_source_config) {
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  NOTREACHED() << "This is not expected to run in SDK build.";
+#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+
   DCHECK_CALLED_ON_VALID_SEQUENCE(perfetto_sequence_checker_);
   auto trace_config =
       TraceConfig(data_source_config.chrome_config().trace_config());
@@ -1029,55 +971,24 @@
   // previously startup tracing, because the process name may have changed.
   EmitTrackDescriptor();
 
-#if !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
   TraceLog::GetInstance()->SetEnabled(trace_config, TraceLog::RECORDING_MODE);
-#endif
 
-  EmitRecurringUpdates();
-  ResetHistograms(trace_config);
-
-  DCHECK(monitored_histograms_.empty());
-  if (trace_config.IsCategoryGroupEnabled(
-          TRACE_DISABLED_BY_DEFAULT("histogram_samples"))) {
-    // Note that global callback is setup in RegisterWithTraceLog() since it can
-    // be done in early startup and this observer needs message loop.
-    for (const std::string& histogram_name : trace_config.histogram_names()) {
-      monitored_histograms_.emplace_back(
-          std::make_unique<
-              base::StatisticsRecorder::ScopedHistogramSampleObserver>(
-              histogram_name,
-              base::BindRepeating(
-                  &TraceEventDataSource::OnMetricsSampleCallback)));
-    }
-  }
-
-  if (trace_config.IsCategoryGroupEnabled(
-          TRACE_DISABLED_BY_DEFAULT("user_action_samples"))) {
-    auto task_runner = base::GetRecordActionTaskRunner();
-    if (task_runner) {
-      task_runner->PostTask(
-          FROM_HERE, base::BindOnce([]() {
-            base::AddActionCallback(
-                TraceEventDataSource::GetInstance()->user_action_callback_);
-          }));
-    }
-  }
+  CustomEventRecorder::GetInstance()->OnTracingStarted(data_source_config);
 }
 
 void TraceEventDataSource::StopTracingImpl(
     base::OnceClosure stop_complete_callback) {
   DCHECK_CALLED_ON_VALID_SEQUENCE(perfetto_sequence_checker_);
 #if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-  // Write metadata events etc.
-  LogHistograms();
-  std::move(stop_complete_callback).Run();
-#else   // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  NOTREACHED() << "This is not expected to run in SDK build.";
+#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+
+  CustomEventRecorder::GetInstance()->OnTracingStopped(base::OnceClosure());
+
   stop_complete_callback_ = std::move(stop_complete_callback);
 
   bool was_enabled = TraceLog::GetInstance()->IsEnabled();
   if (was_enabled) {
-    // Write metadata events etc.
-    LogHistograms();
     TraceLog::GetInstance()->SetDisabled();
   }
 
@@ -1143,72 +1054,6 @@
     on_tracing_stopped_callback(this, trace_writer_raw,
                                 scoped_refptr<base::RefCountedString>(), false);
   }
-#endif  // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-
-  base::StatisticsRecorder::SetGlobalSampleCallback(nullptr);
-  monitored_histograms_.clear();
-
-  auto task_runner = base::GetRecordActionTaskRunner();
-  if (task_runner) {
-    task_runner->PostTask(
-        FROM_HERE, base::BindOnce([]() {
-          base::RemoveActionCallback(
-              TraceEventDataSource::GetInstance()->user_action_callback_);
-        }));
-  }
-}
-
-void TraceEventDataSource::LogHistogram(base::HistogramBase* histogram) {
-  if (!histogram) {
-    return;
-  }
-  // For the purpose of calculating metrics from histograms we only want the
-  // delta of the events.
-  auto samples = histogram->SnapshotSamples();
-
-  // If there were HistogramSamples recorded during startup, then those should
-  // be subtracted from the overall set. This way we only report the samples
-  // that occured during the run.
-  auto it = startup_histogram_samples_.find(histogram->histogram_name());
-  if (it != startup_histogram_samples_.end()) {
-    samples->Subtract(*it->second.get());
-  }
-  base::Pickle pickle;
-  samples->Serialize(&pickle);
-  std::string buckets;
-  base::Base64Encode(
-      std::string(static_cast<const char*>(pickle.data()), pickle.size()),
-      &buckets);
-  TRACE_EVENT_INSTANT2("benchmark,uma", "UMAHistogramSamples",
-                       TRACE_EVENT_SCOPE_PROCESS, "name",
-                       histogram->histogram_name(), "buckets", buckets);
-}
-
-void TraceEventDataSource::ResetHistograms(const TraceConfig& trace_config) {
-  histograms_.clear();
-  startup_histogram_samples_.clear();
-  for (const std::string& histogram_name : trace_config.histogram_names()) {
-    histograms_.push_back(histogram_name);
-    auto* histogram = base::StatisticsRecorder::FindHistogram(histogram_name);
-    if (!histogram) {
-      continue;
-    }
-
-    // For the purpose of calculating metrics from histograms we only want the
-    // delta of the events. However we do not want to emit the results when
-    // resetting. This will allow LogHistogram to emit one UMAHistogramSamples
-    // which encompasses only the histograms recorded during the trace. We
-    // cache the initial HistogramSamples so that they can be subtracted from
-    // the full snapshot at the end.
-    startup_histogram_samples_.emplace(histogram_name,
-                                       histogram->SnapshotSamples());
-  }
-}
-
-void TraceEventDataSource::LogHistograms() {
-  for (const std::string& histogram_name : histograms_) {
-    LogHistogram(base::StatisticsRecorder::FindHistogram(histogram_name));
-  }
 }
 
 void TraceEventDataSource::Flush(
@@ -1228,6 +1073,10 @@
 }
 
 void TraceEventDataSource::ClearIncrementalState() {
+#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+  NOTREACHED() << "This is not expected to run in SDK build.";
+#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
+
   TrackEventThreadLocalEventSink::ClearIncrementalState();
   EmitTrackDescriptor();
   base::trace_event::TraceLog::GetInstance()->OnIncrementalStateCleared();
@@ -1355,64 +1204,6 @@
   }
 }
 
-namespace {
-
-struct InternedHistogramName
-    : public perfetto::TrackEventInternedDataIndex<
-          InternedHistogramName,
-          perfetto::protos::pbzero::InternedData::kHistogramNamesFieldNumber,
-          std::string> {
-  static void Add(perfetto::protos::pbzero::InternedData* interned_data,
-                  size_t iid,
-                  const std::string& histogram_name) {
-    auto* msg = interned_data->add_histogram_names();
-    msg->set_iid(iid);
-    msg->set_name(histogram_name);
-  }
-};
-
-}  // namespace
-
-// static
-void TraceEventDataSource::OnMetricsSampleCallback(
-    const char* histogram_name,
-    uint64_t name_hash,
-    base::HistogramBase::Sample sample) {
-  TRACE_EVENT_INSTANT(
-      TRACE_DISABLED_BY_DEFAULT("histogram_samples"), "HistogramSample",
-      [&](perfetto::EventContext ctx) {
-        bool privacy_filtering_enabled =
-            TraceEventDataSource::GetInstance()->IsPrivacyFilteringEnabled();
-        perfetto::protos::pbzero::ChromeHistogramSample* new_sample =
-            ctx.event()->set_chrome_histogram_sample();
-        new_sample->set_name_hash(name_hash);
-        new_sample->set_sample(sample);
-        if (!privacy_filtering_enabled) {
-          size_t iid = InternedHistogramName::Get(&ctx, histogram_name);
-          new_sample->set_name_iid(iid);
-        }
-      });
-}
-
-void TraceEventDataSource::OnUserActionSampleCallback(
-    const std::string& action,
-    base::TimeTicks action_time) {
-  constexpr uint64_t kGlobalInstantTrackId = 0;
-  TRACE_EVENT_INSTANT(
-      TRACE_DISABLED_BY_DEFAULT("user_action_samples"), "UserAction",
-      perfetto::Track::Global(kGlobalInstantTrackId),
-      [&](perfetto::EventContext ctx) {
-        bool privacy_filtering_enabled =
-            TraceEventDataSource::GetInstance()->IsPrivacyFilteringEnabled();
-        perfetto::protos::pbzero::ChromeUserEvent* new_sample =
-            ctx.event()->set_chrome_user_event();
-        if (!privacy_filtering_enabled) {
-          new_sample->set_action(action);
-        }
-        new_sample->set_action_hash(base::HashMetricName(action));
-      });
-}
-
 void TraceEventDataSource::ReturnTraceWriter(
     std::unique_ptr<perfetto::TraceWriter> trace_writer) {
   {
@@ -1562,7 +1353,7 @@
   trace_packet = TracePacketHandle();
   writer->NewTracePacket();
 
-  EmitRecurringUpdates();
+  CustomEventRecorder::EmitRecurringUpdates();
 
   // Flush the current chunk right after writing the packet when in discard
   // buffering mode. Otherwise there's a risk that the chunk will miss the
diff --git a/services/tracing/public/cpp/perfetto/trace_event_data_source.h b/services/tracing/public/cpp/perfetto/trace_event_data_source.h
index 88329a6e..99b92d7 100644
--- a/services/tracing/public/cpp/perfetto/trace_event_data_source.h
+++ b/services/tracing/public/cpp/perfetto/trace_event_data_source.h
@@ -32,8 +32,6 @@
 
 namespace base {
 
-class HistogramSamples;
-
 namespace trace_event {
 class TraceEvent;
 struct TraceEventHandle;
@@ -150,11 +148,8 @@
 // the PerfettoProducer. It converts incoming
 // trace events to ChromeTraceEvent protos and writes
 // them into the Perfetto shared memory.
-class COMPONENT_EXPORT(TRACING_CPP) TraceEventDataSource :
-#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-    public perfetto::TrackEventSessionObserver,
-#endif
-    public PerfettoTracedProcess::DataSourceBase {
+class COMPONENT_EXPORT(TRACING_CPP) TraceEventDataSource
+    : public PerfettoTracedProcess::DataSourceBase {
  public:
   struct SessionFlags {
     // True if startup tracing is enabled for the current tracing session.
@@ -198,25 +193,6 @@
   bool IsEnabled();
   bool IsPrivacyFilteringEnabled();
 
-  // Records trace event for a histogram sample. When histogram_samples category
-  // is enabled, it is registered with base::StatisticsRecorder to monitor the
-  // histograms listed in the trace config. If there are no histograms listed in
-  // the trace config, all the histograms will be monitored.
-  static void OnMetricsSampleCallback(const char* histogram_name,
-                                      uint64_t name_hash,
-                                      base::HistogramBase::Sample sample);
-
-  // Registered as a callback to receive every action recorded using
-  // base::RecordAction(), when tracing is enabled with a histogram category.
-  static void OnUserActionSampleCallback(const std::string& action,
-                                         base::TimeTicks action_time);
-
-#if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-  // perfetto::TrackEventSessionObserver:
-  void OnSetup(const perfetto::DataSourceBase::SetupArgs&) override;
-  void OnStop(const perfetto::DataSourceBase::StopArgs&) override;
-#endif  // BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
-
  private:
   friend class base::NoDestructor<TraceEventDataSource>;
 
@@ -256,13 +232,6 @@
   static base::trace_event::TracePacketHandle OnAddTracePacket();
   static void OnAddEmptyPacket();
 
-  // Extracts UMA histogram names that should be logged in traces and logs their
-  // starting values.
-  void ResetHistograms(const base::trace_event::TraceConfig& trace_config);
-  // Logs selected UMA histogram.
-  void LogHistograms();
-  // Logs a given histogram in traces.
-  void LogHistogram(base::HistogramBase* histogram);
   void EmitTrackDescriptor();
 
   uint32_t IncrementSessionIdOrClearStartupFlagWhileLocked();
@@ -291,24 +260,11 @@
   bool is_enabled_ = false;
   bool flushing_trace_log_ = false;
   base::OnceClosure flush_complete_task_;
-  std::vector<std::string> histograms_;
-  // For each of the Histogram that we are tracking, cache the snapshot of their
-  // HistogramSamples from before tracing began. So that we can calculate the
-  // delta when we go to LogHistograms.
-  std::map<std::string, std::unique_ptr<base::HistogramSamples>>
-      startup_histogram_samples_;
-  // Stores the registered histogram callbacks for which OnMetricsSampleCallback
-  // was set individually.
-  std::vector<
-      std::unique_ptr<base::StatisticsRecorder::ScopedHistogramSampleObserver>>
-      monitored_histograms_;
   bool privacy_filtering_enabled_ = false;
   base::trace_event::TraceRecordMode record_mode_ =
       base::trace_event::RECORD_UNTIL_FULL;
   std::string process_name_;
   int process_id_ = base::kNullProcessId;
-  base::ActionCallback user_action_callback_ =
-      base::BindRepeating(&TraceEventDataSource::OnUserActionSampleCallback);
 };
 
 }  // namespace tracing
diff --git a/services/tracing/public/cpp/perfetto/trace_event_data_source_unittest.cc b/services/tracing/public/cpp/perfetto/trace_event_data_source_unittest.cc
index 2923bcf..b5b5fc8 100644
--- a/services/tracing/public/cpp/perfetto/trace_event_data_source_unittest.cc
+++ b/services/tracing/public/cpp/perfetto/trace_event_data_source_unittest.cc
@@ -34,6 +34,7 @@
 #include "build/build_config.h"
 #include "components/tracing/common/tracing_switches.h"
 #include "services/tracing/perfetto/test_utils.h"
+#include "services/tracing/public/cpp/perfetto/custom_event_recorder.h"
 #include "services/tracing/public/cpp/perfetto/macros.h"
 #include "services/tracing/public/cpp/perfetto/perfetto_config.h"
 #include "services/tracing/public/cpp/perfetto/producer_test_utils.h"
@@ -108,7 +109,7 @@
 #if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
     PerfettoTracedProcess::GetTaskRunner()->ResetTaskRunnerForTesting(
         base::ThreadTaskRunnerHandle::Get());
-    TraceEventDataSource::GetInstance()->ResetForTesting();
+    CustomEventRecorder::GetInstance();  //->ResetForTesting();
     TraceEventMetadataSource::GetInstance()->ResetForTesting();
 #else   // !BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
     PerfettoTracedProcess::GetTaskRunner()->GetOrCreateTaskRunner();
@@ -1905,15 +1906,15 @@
     ExpectInternedEventNames(e_packet3, {{2u, "e2"}});
     ExpectInternedDebugAnnotationNames(e_packet3, {{2u, "arg2"}});
 
-    // Resetting the interning state causes ThreadDescriptor and interning
-    // entries to be emitted again, with the same interning IDs.
-    TraceEventDataSource::GetInstance()->ClearIncrementalState();
-
 #if BUILDFLAG(USE_PERFETTO_CLIENT_LIBRARY)
     // TODO(skyostil): Perfetto doesn't let us clear the interning state
     // explicitly, so not testing that here for now.
     if (!i)
       break;
+#else
+    // Resetting the interning state causes ThreadDescriptor and interning
+    // entries to be emitted again, with the same interning IDs.
+    TraceEventDataSource::GetInstance()->ClearIncrementalState();
 #endif
   }
 }
diff --git a/testing/buildbot/chromium.android.fyi.json b/testing/buildbot/chromium.android.fyi.json
index f995ad0..3b2adcd 100644
--- a/testing/buildbot/chromium.android.fyi.json
+++ b/testing/buildbot/chromium.android.fyi.json
@@ -8365,7 +8365,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -8450,7 +8450,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -8875,7 +8875,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -8960,7 +8960,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
diff --git a/testing/buildbot/chromium.android.json b/testing/buildbot/chromium.android.json
index d21bca2..716c7b7 100644
--- a/testing/buildbot/chromium.android.json
+++ b/testing/buildbot/chromium.android.json
@@ -46542,7 +46542,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -46627,7 +46627,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -47052,7 +47052,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -47137,7 +47137,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -47566,7 +47566,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -47651,7 +47651,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -48076,7 +48076,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -48161,7 +48161,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -48658,7 +48658,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -48743,7 +48743,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -49168,7 +49168,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -49253,7 +49253,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -49750,7 +49750,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -49835,7 +49835,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -50260,7 +50260,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M103",
-              "revision": "version:103.0.5060.115"
+              "revision": "version:103.0.5060.116"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
@@ -50345,7 +50345,7 @@
             {
               "cipd_package": "chromium/testing/weblayer-x86",
               "location": "weblayer_instrumentation_test_M104",
-              "revision": "version:104.0.5112.33"
+              "revision": "version:104.0.5112.34"
             },
             {
               "cipd_package": "infra/tools/luci/logdog/butler/${platform}",
diff --git a/testing/buildbot/chromium.chromiumos.json b/testing/buildbot/chromium.chromiumos.json
index d476b59..eeec9c7 100644
--- a/testing/buildbot/chromium.chromiumos.json
+++ b/testing/buildbot/chromium.chromiumos.json
@@ -5688,21 +5688,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -5715,7 +5715,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
@@ -5853,21 +5853,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -5879,7 +5879,7 @@
         },
         "test": "lacros_chrome_browsertests",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "args": [
@@ -5999,21 +5999,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -6025,7 +6025,7 @@
         },
         "test": "lacros_chrome_browsertests_run_in_series",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests_run_in_series/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
diff --git a/testing/buildbot/chromium.fyi.json b/testing/buildbot/chromium.fyi.json
index 245e8f8..f57b2304 100644
--- a/testing/buildbot/chromium.fyi.json
+++ b/testing/buildbot/chromium.fyi.json
@@ -92974,21 +92974,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com",
@@ -92996,7 +92996,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
@@ -93109,28 +93109,28 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
         },
         "test": "lacros_chrome_browsertests",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "args": [
@@ -93230,28 +93230,28 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "service_account": "chromium-tester@chops-service-accounts.iam.gserviceaccount.com"
         },
         "test": "lacros_chrome_browsertests_run_in_series",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests_run_in_series/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
@@ -94589,20 +94589,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -94616,7 +94616,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "merge": {
@@ -94754,20 +94754,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -94780,7 +94780,7 @@
         },
         "test": "lacros_chrome_browsertests",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "args": [
@@ -94900,20 +94900,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -94926,7 +94926,7 @@
         },
         "test": "lacros_chrome_browsertests_run_in_series",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests_run_in_series/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "merge": {
@@ -96422,20 +96422,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -96449,7 +96449,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "merge": {
@@ -96587,20 +96587,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -96613,7 +96613,7 @@
         },
         "test": "lacros_chrome_browsertests",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "args": [
@@ -96733,20 +96733,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -96759,7 +96759,7 @@
         },
         "test": "lacros_chrome_browsertests_run_in_series",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests_run_in_series/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "merge": {
@@ -97494,20 +97494,20 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -97520,7 +97520,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       }
     ]
   },
diff --git a/testing/buildbot/chromium.memory.json b/testing/buildbot/chromium.memory.json
index db48f70..bf1977d03 100644
--- a/testing/buildbot/chromium.memory.json
+++ b/testing/buildbot/chromium.memory.json
@@ -20874,21 +20874,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.filter;../../testing/buildbot/filters/linux-lacros.interactive_ui_tests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5158.0",
+        "name": "interactive_ui_tests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -20901,7 +20901,7 @@
         },
         "test": "interactive_ui_tests",
         "test_id_prefix": "ninja://chrome/test:interactive_ui_tests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
@@ -21039,21 +21039,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -21065,7 +21065,7 @@
         },
         "test": "lacros_chrome_browsertests",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "args": [
@@ -21185,21 +21185,21 @@
       {
         "args": [
           "--test-launcher-filter-file=../../testing/buildbot/filters/linux-lacros.lacros_chrome_browsertests.skew.filter",
-          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome"
+          "--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome"
         ],
         "isolate_profile_data": true,
         "merge": {
           "args": [],
           "script": "//testing/merge_scripts/standard_gtest_merge.py"
         },
-        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5158.0",
+        "name": "lacros_chrome_browsertests_run_in_series Lacros version skew testing ash 105.0.5159.0",
         "swarming": {
           "can_use_on_swarming_builders": true,
           "cipd_packages": [
             {
               "cipd_package": "chromium/testing/linux-ash-chromium/x86_64/ash.zip",
-              "location": "lacros_version_skew_tests_v105.0.5158.0",
-              "revision": "version:105.0.5158.0"
+              "location": "lacros_version_skew_tests_v105.0.5159.0",
+              "revision": "version:105.0.5159.0"
             }
           ],
           "dimension_sets": [
@@ -21211,7 +21211,7 @@
         },
         "test": "lacros_chrome_browsertests_run_in_series",
         "test_id_prefix": "ninja://chrome/test:lacros_chrome_browsertests_run_in_series/",
-        "variant_id": "Lacros version skew testing ash 105.0.5158.0"
+        "variant_id": "Lacros version skew testing ash 105.0.5159.0"
       },
       {
         "isolate_profile_data": true,
diff --git a/testing/buildbot/variants.pyl b/testing/buildbot/variants.pyl
index 211b997..254b59d3 100644
--- a/testing/buildbot/variants.pyl
+++ b/testing/buildbot/variants.pyl
@@ -22,15 +22,15 @@
   },
   'LACROS_VERSION_SKEW_CANARY': {
     'args': [
-      '--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5158.0/test_ash_chrome',
+      '--ash-chrome-path-override=../../lacros_version_skew_tests_v105.0.5159.0/test_ash_chrome',
     ],
-    'identifier': 'Lacros version skew testing ash 105.0.5158.0',
+    'identifier': 'Lacros version skew testing ash 105.0.5159.0',
     'swarming': {
       'cipd_packages': [
         {
           'cipd_package': 'chromium/testing/linux-ash-chromium/x86_64/ash.zip',
-          'location': 'lacros_version_skew_tests_v105.0.5158.0',
-          'revision': 'version:105.0.5158.0',
+          'location': 'lacros_version_skew_tests_v105.0.5159.0',
+          'revision': 'version:105.0.5159.0',
         },
       ],
     },
@@ -546,7 +546,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M104',
-          'revision': 'version:104.0.5112.33'
+          'revision': 'version:104.0.5112.34'
         }
       ]
     }
@@ -570,7 +570,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M103',
-          'revision': 'version:103.0.5060.115'
+          'revision': 'version:103.0.5060.116'
         }
       ]
     }
@@ -690,7 +690,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M104',
-          'revision': 'version:104.0.5112.33'
+          'revision': 'version:104.0.5112.34'
         }
       ]
     }
@@ -714,7 +714,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M103',
-          'revision': 'version:103.0.5060.115'
+          'revision': 'version:103.0.5060.116'
         }
       ]
     }
@@ -834,7 +834,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M104',
-          'revision': 'version:104.0.5112.33'
+          'revision': 'version:104.0.5112.34'
         }
       ]
     }
@@ -858,7 +858,7 @@
         {
           'cipd_package': 'chromium/testing/weblayer-x86',
           'location': 'weblayer_instrumentation_test_M103',
-          'revision': 'version:103.0.5060.115'
+          'revision': 'version:103.0.5060.116'
         }
       ]
     }
diff --git a/third_party/blink/renderer/core/dom/node.cc b/third_party/blink/renderer/core/dom/node.cc
index 1028f4da..ffa2fac 100644
--- a/third_party/blink/renderer/core/dom/node.cc
+++ b/third_party/blink/renderer/core/dom/node.cc
@@ -372,10 +372,6 @@
   // By default, setting nodeValue has no effect.
 }
 
-ContainerNode* Node::parentNode() const {
-  return IsShadowRoot() ? nullptr : ParentOrShadowHostNode();
-}
-
 NodeList* Node::childNodes() {
   auto* this_node = DynamicTo<ContainerNode>(this);
   if (this_node)
diff --git a/third_party/blink/renderer/core/dom/node.h b/third_party/blink/renderer/core/dom/node.h
index ff5dda028..edca080 100644
--- a/third_party/blink/renderer/core/dom/node.h
+++ b/third_party/blink/renderer/core/dom/node.h
@@ -216,7 +216,10 @@
   virtual void setNodeValue(const String&,
                             ExceptionState& = ASSERT_NO_EXCEPTION);
   virtual NodeType getNodeType() const = 0;
-  ContainerNode* parentNode() const;
+  ContainerNode* parentNode() const {
+    return IsShadowRoot() ? nullptr : ParentOrShadowHostNode();
+  }
+
   Element* parentElement() const;
   ContainerNode* ParentElementOrShadowRoot() const;
   ContainerNode* ParentElementOrDocumentFragment() const;
diff --git a/third_party/blink/renderer/core/layout/layout_inline.cc b/third_party/blink/renderer/core/layout/layout_inline.cc
index 905cbf4..09bf0313 100644
--- a/third_party/blink/renderer/core/layout/layout_inline.cc
+++ b/third_party/blink/renderer/core/layout/layout_inline.cc
@@ -410,6 +410,9 @@
       style.MayHaveMargin())
     return true;
 
+  if (!style.AnchorName().IsNull())
+    return true;
+
   return ComputeIsAbsoluteContainer(&style) ||
          NGOutlineUtils::HasPaintedOutline(style, GetNode()) ||
          CanBeHitTestTargetPseudoNodeStyle(style);
diff --git a/third_party/blink/renderer/core/layout/ng/ng_anchor_query_test.cc b/third_party/blink/renderer/core/layout/ng/ng_anchor_query_test.cc
index e8818ee..e60567fe 100644
--- a/third_party/blink/renderer/core/layout/ng/ng_anchor_query_test.cc
+++ b/third_party/blink/renderer/core/layout/ng/ng_anchor_query_test.cc
@@ -105,6 +105,65 @@
                   AnchorTestData{"--div3", PhysicalRect(0, 70, 800, 0)}));
 }
 
+TEST_F(NGAnchorQueryTest, Inline) {
+  LoadAhem();
+  SetBodyInnerHTML(R"HTML(
+    <style>
+    html, body {
+      margin: 0;
+      width: 800px;
+      font-family: Ahem;
+      font-size: 10px;
+      line-height: 1;
+    }
+    img {
+      width: 10px;
+      height: 8px;
+    }
+    .after .add {
+      anchor-name: --add;
+    }
+    </style>
+    <div id="container">
+      0
+      <!-- culled and non-culled inline boxes. -->
+      <span style="anchor-name: --culled">23</span>
+      <span style="anchor-name: --non-culled; background: yellow">56</span>
+
+      <!-- Adding `anchor-name` dynamically should uncull. -->
+      <span class="add">89</span>
+
+      <!-- Atomic inlines: replaced elements and inline blocks. -->
+      <img style="anchor-name: --img" src="">
+      <span style="anchor-name: --inline-block; display: inline-block">X</span>
+    </div>
+  )HTML");
+  Element* container = GetElementById("container");
+  const NGPhysicalAnchorQuery* anchor_query = AnchorQuery(*container);
+  ASSERT_NE(anchor_query, nullptr);
+  EXPECT_THAT(
+      AnchorTestData::ToList(*anchor_query),
+      testing::ElementsAre(
+          AnchorTestData{"--culled", PhysicalRect(20, 0, 20, 10)},
+          AnchorTestData{"--img", PhysicalRect(110, 0, 10, 8)},
+          AnchorTestData{"--inline-block", PhysicalRect(130, 0, 10, 10)},
+          AnchorTestData{"--non-culled", PhysicalRect(50, 0, 20, 10)}));
+
+  // Add the "after" class and test anchors are updated accordingly.
+  container->classList().Add("after");
+  UpdateAllLifecyclePhasesForTest();
+  anchor_query = AnchorQuery(*container);
+  ASSERT_NE(anchor_query, nullptr);
+  EXPECT_THAT(
+      AnchorTestData::ToList(*anchor_query),
+      testing::ElementsAre(
+          AnchorTestData{"--add", PhysicalRect(80, 0, 20, 10)},
+          AnchorTestData{"--culled", PhysicalRect(20, 0, 20, 10)},
+          AnchorTestData{"--img", PhysicalRect(110, 0, 10, 8)},
+          AnchorTestData{"--inline-block", PhysicalRect(130, 0, 10, 10)},
+          AnchorTestData{"--non-culled", PhysicalRect(50, 0, 20, 10)}));
+}
+
 TEST_F(NGAnchorQueryTest, OutOfFlow) {
   SetBodyInnerHTML(R"HTML(
     <style>
diff --git a/third_party/blink/web_tests/TestExpectations b/third_party/blink/web_tests/TestExpectations
index 70504b78..fdba8e1a 100644
--- a/third_party/blink/web_tests/TestExpectations
+++ b/third_party/blink/web_tests/TestExpectations
@@ -7146,3 +7146,8 @@
 # Sheriff 2022-06-30
 crbug.com/1340781 virtual/android/fullscreen/full-screen-table-section.html [ Skip ]
 crbug.com/1327867 http/tests/inspector-protocol/network/initiator-minified.js [ Failure Pass ]
+
+# Temporarily disable the tests during the rollout of V8 that fixes the
+# behaviors that the test cases excersise.
+crbug.com/1305302 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value-cross-realm.html [ Skip ]
+crbug.com/1305302 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value.any.html [ Skip ]
diff --git a/third_party/blink/web_tests/android/WebLayerWPTOverrideExpectations b/third_party/blink/web_tests/android/WebLayerWPTOverrideExpectations
index 417c578..ecdce06e 100644
--- a/third_party/blink/web_tests/android/WebLayerWPTOverrideExpectations
+++ b/third_party/blink/web_tests/android/WebLayerWPTOverrideExpectations
@@ -375,7 +375,6 @@
 crbug.com/1050754 external/wpt/IndexedDB/transaction-abort-generator-revert.html [ Failure Pass ]
 crbug.com/1050754 external/wpt/WebCryptoAPI/historical.any.sharedworker.html [ Failure ]
 crbug.com/1050754 external/wpt/WebIDL/ecmascript-binding/global-immutable-prototype.any.sharedworker.html [ Failure ]
-crbug.com/1050754 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value.any.html [ Failure ]
 crbug.com/1050754 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value.any.serviceworker.html [ Failure ]
 crbug.com/1050754 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value.any.sharedworker.html [ Failure ]
 crbug.com/1050754 external/wpt/WebIDL/ecmascript-binding/global-object-implicit-this-value.any.worker.html [ Failure ]
diff --git a/third_party/blink/web_tests/external/wpt/html/browsers/history/the-location-interface/cross-origin-access-is-restricted.html b/third_party/blink/web_tests/external/wpt/html/browsers/history/the-location-interface/cross-origin-access-is-restricted.html
new file mode 100644
index 0000000..1d1c113
--- /dev/null
+++ b/third_party/blink/web_tests/external/wpt/html/browsers/history/the-location-interface/cross-origin-access-is-restricted.html
@@ -0,0 +1,65 @@
+<!DOCTYPE html>
+<meta charset="utf-8">
+<title>
+  Verify that certain location interface properties are protected cross-origin.
+</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+<script src="/common/dispatcher/dispatcher.js"></script>
+<script src="/common/get-host-info.sub.js"></script>
+<script src="/common/utils.js"></script>
+
+<body></body> <!-- Needed to append the iframe -->
+
+<script>
+
+const iframeToken = token();
+const responseToken = token();
+const iframeUrl =
+  get_host_info().REMOTE_ORIGIN +
+  "/common/dispatcher/executor.html?uuid=" +
+  iframeToken;
+
+const iframe = document.createElement("iframe");
+iframe.src = iframeUrl;
+document.body.appendChild(iframe);
+
+[
+  "assign",
+  "customproperty",
+  "hash",
+  "host",
+  "hostname",
+  "pathname",
+  "port",
+  "protocol",
+  "reload",
+  "search",
+  "toString",
+  "valueOf",
+].forEach(property => {
+  promise_test(async t => {
+    // Make sure the cross-origin document is loaded in the iframe.
+    send(iframeToken, `send("${responseToken}", "Responsive");`);
+    assert_equals(await receive(responseToken), "Responsive");
+
+    assert_throws_dom("SecurityError", () => {
+      const unused = iframe.contentWindow.location[property];
+    }, "Cross origin get of a location property should throw a security error");
+
+    assert_throws_dom("SecurityError", () => {
+      iframe.contentWindow.location[property] = "Random string";
+    }, "Cross origin set of a location property should throw a security error");
+
+    // Verify that the property was indeed not modified.
+    send(iframeToken, `send("${responseToken}", location["${property}"])`);
+    assert_true(await receive(responseToken) != "Random string");
+
+    assert_throws_dom("SecurityError", () => {
+      const unused = Object.getOwnPropertyDescriptor(
+        iframe.contentWindow.location, property);
+    }, "Cross origin get of descriptors should throw a security error");
+  }, `Verifying that cross-origin access of '${property}' is restricted`);
+});
+
+</script>
diff --git a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.js b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.js
index 82d42230..83344e5 100644
--- a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.js
+++ b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.js
@@ -1 +1,2 @@
+// META: global=window,dedicatedworker,sharedworker,serviceworker
 test(t => assert_equals(crossOriginEmbedderPolicy, "credentialless"));
diff --git a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.js b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.js
index c96b8f3..ed668d8 100644
--- a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.js
+++ b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.js
@@ -1 +1,2 @@
+// META: global=window,dedicatedworker,sharedworker,serviceworker
 test(t => assert_equals(crossOriginEmbedderPolicy, "require-corp"));
diff --git a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-unsafe-none.tentative.https.any.js b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-unsafe-none.tentative.https.any.js
index 4694f91..0746d73 100644
--- a/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-unsafe-none.tentative.https.any.js
+++ b/third_party/blink/web_tests/external/wpt/html/cross-origin-embedder-policy/reflection-unsafe-none.tentative.https.any.js
@@ -1 +1,2 @@
+// META: global=window,dedicatedworker,sharedworker,serviceworker
 test(t => assert_equals(crossOriginEmbedderPolicy, "unsafe-none"));
diff --git a/third_party/blink/web_tests/http/tests/security/cross-frame-access-getOwnPropertyDescriptor.html b/third_party/blink/web_tests/http/tests/security/cross-frame-access-getOwnPropertyDescriptor.html
index 555c5182..deeba613 100644
--- a/third_party/blink/web_tests/http/tests/security/cross-frame-access-getOwnPropertyDescriptor.html
+++ b/third_party/blink/web_tests/http/tests/security/cross-frame-access-getOwnPropertyDescriptor.html
@@ -1,3 +1,4 @@
+<!DOCTYPE html>
 <html>
 <head>
     <script src="resources/cross-frame-access.js"></script>
@@ -250,19 +251,6 @@
                 var property = windowAttributesPropertiesAllowed[i];
                 shouldBeTrue("canGetDescriptor(targetWindow, '" + property + "')");
             }
-            log("----- tests access to cross domain location object -----");
-            window.targetLocation = targetWindow.location;
-            var locationProperties = [
-                "protocol", "host", "hostname", "port", "pathname", "search", "hash", "toString", "valueOf", "customProperty", "assign", "reload"
-            ];
-            for (var i = 0; i < locationProperties.length; i++)
-                shouldBeFalse("canGetDescriptor(targetLocation, '" + locationProperties[i] + "')");
-            var locationPropertiesAllowed = [
-                "replace"
-            ];
-            for (var i = 0; i < locationPropertiesAllowed.length; i++)
-                shouldBeTrue("canGetDescriptor(targetLocation, '" + locationPropertiesAllowed[i] + "')");
-
             log("----- tests access to cross domain history object -----");
             shouldThrowException("targetWindow.history");
 
diff --git a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-get-override.html b/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-get-override.html
deleted file mode 100644
index 1749c0e..0000000
--- a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-get-override.html
+++ /dev/null
@@ -1,38 +0,0 @@
-<html>
-<head>
-    <script src="resources/cross-frame-access.js"></script>
-    <script>
-        window.onload = function()
-        {
-            if (window.testRunner) {
-                testRunner.dumpAsText();
-                testRunner.waitUntilDone();
-            }
-
-            window.targetWindow = frames[0];
-
-            log("----- tests for getting a targetWindow's location object's functions which have custom overrides.  The" +
-                " desired behavior is for the targetWindow to return the builtin function, not the override -----\n");
-
-            // We should test overriding using window.location.__proto__ once the Location object has a proper prototype.
-
-            // Overriden using window.location.assign = function() { return "new assign" }
-            shouldBeFalse("canGet('targetWindow.location.assign')");
-
-            // Overriden using window.location.reload = "new reload"
-            shouldBeFalse("canGet('targetWindow.location.reload')");
-
-            // Overriden using window.location.replace = "new replace"
-            shouldBeTrue("canGet('targetWindow.location.replace')");
-            shouldBe("targetWindow.location.replace.name", "''");
-
-            if (window.testRunner)
-                testRunner.notifyDone();
-        }
-    </script>
-</head>
-<body>
-<iframe src="http://localhost:8000/security/resources/cross-frame-iframe-for-location-get-override-test.html"></iframe>
-<pre id="console"></pre>
-</body>
-</html>
diff --git a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-prototype.html b/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-prototype.html
deleted file mode 100644
index 1750e67..0000000
--- a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-prototype.html
+++ /dev/null
@@ -1,28 +0,0 @@
-<script>
-    if (window.testRunner) {
-        testRunner.dumpAsText();
-        testRunner.waitUntilDone();
-    }
-
-    function log(msg)
-    {
-        document.getElementById("console").appendChild(document.createTextNode(msg + "\n"));
-    }
-
-    addEventListener("message", function()
-    {
-        if (window.location.fail) {
-            log("FAIL: Location object prototype tainted.");
-        } else {
-            log("PASS: Location object prototype not tainted.");
-        }
-
-        if (window.testRunner)
-            testRunner.notifyDone();
-    }, false);
-</script>
-<body>
-    <pre id="console"></pre>
-    <iframe src="http://localhost:8000/security/resources/cross-frame-location-prototype-iframe.html"></iframe>
-</body>
-</html>
diff --git a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-put.html b/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-put.html
deleted file mode 100644
index bb4253c..0000000
--- a/third_party/blink/web_tests/http/tests/security/cross-frame-access-location-put.html
+++ /dev/null
@@ -1,57 +0,0 @@
-<html>
-<head>
-    <script src="resources/cross-frame-access.js"></script>
-    <script>
-        if (window.testRunner) {
-            testRunner.dumpAsText();
-            testRunner.dumpChildFrames();
-            testRunner.waitUntilDone();
-        }
-
-        onload = function()
-        {
-            // Add manual run buttons if the browser does not support window.postMessage
-            if (!window.postMessage) {
-                log("YOUR BROWSER DOES NOT SUPPORT window.postMessage");
-                log("To run this test manually, first click the button titled 'Step 1 - Set Test' in this frame.");
-                log("Then click the button in the sub frame titled 'Step 2 - Set Check' to finish the test.\n");
-
-                var button = document.createElement("button");
-                button.appendChild(document.createTextNode("Step 1 - Set Test"));
-                button.onclick = setTest;
-                document.body.appendChild(button);
-            }
-        }
-
-        receiver = function(e)
-        {
-            if (e.data == "storedOldValuesComplete")
-                setTest();
-        }
-        addEventListener('message', receiver, false);
-
-        setTest = function()
-        {
-            window.targetWindow = frames[0];
-
-            // Put testing for the many og standard attibutes of the location object is handeled in stand alone test
-            // cases because they may produce side effects.
-            try { targetWindow.location.assign = "FAIL!! CUSTOM assign"; } catch(e) { log(e); }
-            try { targetWindow.location.replace = "FAIL!! CUSTOM replace"; } catch(e) { log(e); }
-            try { targetWindow.location.reload = "FAIL!! CUSTOM reload"; } catch(e) { log(e); }
-            try { targetWindow.location.toString = "FAIL!! CUSTOM toString"; } catch(e) { log(e); }
-
-            try { targetWindow.location.customAttribute = "FAIL!! CUSTOM customAttribute"; } catch(e) { log(e); }
-
-            if (window.postMessage)
-                targetWindow.postMessage("settingValuesComplete", "*");
-            else
-                log("\nSet Test complete!  Click button entitled 'Step 2 - Set Check' to finish the test.");
-        }
-    </script>
-</head>
-<body>
-    <iframe src="http://localhost:8000/security/resources/cross-frame-iframe-for-location-put-test.html"></iframe>
-    <pre id="console"></pre>
-</body>
-</html>
diff --git a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-get-override-test.html b/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-get-override-test.html
deleted file mode 100644
index adc1690..0000000
--- a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-get-override-test.html
+++ /dev/null
@@ -1,11 +0,0 @@
-<html>
-<head>
-    <script>
-        window.location.assign = function() { return "new assign"; }
-        window.location.reload = "new reload";
-        window.location.replace = "new replace";
-    </script>
-</head>
-<body>
-</body>
-</html>
diff --git a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-put-test.html b/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-put-test.html
deleted file mode 100644
index be276849..0000000
--- a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-iframe-for-location-put-test.html
+++ /dev/null
@@ -1,58 +0,0 @@
-<html>
-<head>
-    <script src="cross-frame-access.js"></script>
-    <script>
-        var assignOld;
-        var replaceOld;
-        var reloadOld;
-        var toStringOld;
-        var customAttributeOld;
-
-        receiver = function(e)
-        {
-            if (e.data == "settingValuesComplete")
-                setCheck();
-        }
-        addEventListener('message', receiver, false);
-
-        window.onload = function()
-        {
-            // Add manuel run buttons if the browser does not support window.postMessage
-            if (!window.postMessage) {
-                var button = document.createElement("button");
-                button.appendChild(document.createTextNode("Step 2 - Set Check"));
-                button.onclick = setCheck;
-                document.body.appendChild(button);
-            }
-
-            window.location.customAttribute = "customAttribute";
-
-            assignOld = window.location.assign;
-            replaceOld = window.location.replace;
-            reloadOld = window.location.reload;
-            toStringOld = window.location.toString;
-            customAttributeOld = window.location.customAttribute;
-
-            if (window.postMessage)
-                window.parent.postMessage("storedOldValuesComplete", "*");
-        }
-
-        setCheck = function()
-        {
-            log("\n----- tests for putting window.history and its properties -----\n");
-
-            shouldBe("window.location.assign", "assignOld");
-            shouldBe("window.location.replace", "replaceOld");
-            shouldBe("window.location.reload", "reloadOld");
-            shouldBe("window.location.toString", "toStringOld");
-            shouldBe("window.location.customAttribute", "customAttributeOld");
-
-            if (window.testRunner)
-                testRunner.notifyDone();
-        }
-    </script>
-</head>
-<body>
-    <pre id="console"></pre>
-</body>
-</html>
diff --git a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-location-prototype-iframe.html b/third_party/blink/web_tests/http/tests/security/resources/cross-frame-location-prototype-iframe.html
deleted file mode 100644
index 1f90ecc..0000000
--- a/third_party/blink/web_tests/http/tests/security/resources/cross-frame-location-prototype-iframe.html
+++ /dev/null
@@ -1,5 +0,0 @@
-<script>
-parent.location;
-Object.prototype.fail = "fail";
-parent.postMessage("done", "*");
-</script>
diff --git a/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.serviceworker-expected.txt b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.serviceworker-expected.txt
new file mode 100644
index 0000000..cbc0240c
--- /dev/null
+++ b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.serviceworker-expected.txt
@@ -0,0 +1,4 @@
+This is a testharness.js-based test.
+FAIL reflection-credentialless assert_equals: expected "credentialless" but got "unsafe-none"
+Harness: the test ran to completion.
+
diff --git a/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.sharedworker-expected.txt b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.sharedworker-expected.txt
new file mode 100644
index 0000000..cbc0240c
--- /dev/null
+++ b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-credentialless.tentative.https.any.sharedworker-expected.txt
@@ -0,0 +1,4 @@
+This is a testharness.js-based test.
+FAIL reflection-credentialless assert_equals: expected "credentialless" but got "unsafe-none"
+Harness: the test ran to completion.
+
diff --git a/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.serviceworker-expected.txt b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.serviceworker-expected.txt
new file mode 100644
index 0000000..0e8a176
--- /dev/null
+++ b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.serviceworker-expected.txt
@@ -0,0 +1,4 @@
+This is a testharness.js-based test.
+FAIL reflection-require-corp assert_equals: expected "require-corp" but got "unsafe-none"
+Harness: the test ran to completion.
+
diff --git a/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.sharedworker-expected.txt b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.sharedworker-expected.txt
new file mode 100644
index 0000000..0e8a176
--- /dev/null
+++ b/third_party/blink/web_tests/platform/generic/external/wpt/html/cross-origin-embedder-policy/reflection-require-corp.tentative.https.any.sharedworker-expected.txt
@@ -0,0 +1,4 @@
+This is a testharness.js-based test.
+FAIL reflection-require-corp assert_equals: expected "require-corp" but got "unsafe-none"
+Harness: the test ran to completion.
+
diff --git a/third_party/blink/web_tests/platform/generic/http/tests/security/cross-frame-access-getOwnPropertyDescriptor-expected.txt b/third_party/blink/web_tests/platform/generic/http/tests/security/cross-frame-access-getOwnPropertyDescriptor-expected.txt
index 3010a8184..9531474 100644
--- a/third_party/blink/web_tests/platform/generic/http/tests/security/cross-frame-access-getOwnPropertyDescriptor-expected.txt
+++ b/third_party/blink/web_tests/platform/generic/http/tests/security/cross-frame-access-getOwnPropertyDescriptor-expected.txt
@@ -208,20 +208,6 @@
 PASS: canGetDescriptor(targetWindow, 'self') should be 'true' and is.
 PASS: canGetDescriptor(targetWindow, 'top') should be 'true' and is.
 PASS: canGetDescriptor(targetWindow, 'window') should be 'true' and is.
------ tests access to cross domain location object -----
-PASS: canGetDescriptor(targetLocation, 'protocol') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'host') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'hostname') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'port') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'pathname') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'search') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'hash') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'toString') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'valueOf') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'customProperty') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'assign') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'reload') should be 'false' and is.
-PASS: canGetDescriptor(targetLocation, 'replace') should be 'true' and is.
 ----- tests access to cross domain history object -----
 PASS: targetWindow.history should have thrown an exception, and did: SecurityError: Blocked a frame with origin "http://127.0.0.1:8000" from accessing a cross-origin frame.
 
diff --git a/tools/mb/mb_config.pyl b/tools/mb/mb_config.pyl
index 7641e55e..e5163d1 100644
--- a/tools/mb/mb_config.pyl
+++ b/tools/mb/mb_config.pyl
@@ -311,6 +311,8 @@
 
     'chromium.fyi': {
       'Afl Upload Linux ASan': 'afl_asan_shared_release_bot',
+      # Keep in sync with linux-rel, but with reclient.
+      'Build Perf Linux': 'gpu_tests_release_trybot_no_symbols_use_dummy_lastchange_code_coverage_do_typecheck_reclient',
       'CFI Linux CF (reclient shadow)': 'cfi_full_cfi_icall_cfi_diag_recover_release_static_reclient',
       'Comparison Android (reclient)': {
         'goma': 'android_webview_google_debug_static_bot_arm64',
@@ -2742,6 +2744,10 @@
       'gpu_tests', 'release_trybot', 'no_symbols', 'use_dummy_lastchange',
       'use_clang_coverage', 'partial_code_coverage_instrumentation', 'devtools_do_typecheck',
     ],
+    'gpu_tests_release_trybot_no_symbols_use_dummy_lastchange_code_coverage_do_typecheck_reclient': [
+      'gpu_tests', 'release_trybot_reclient', 'no_symbols', 'use_dummy_lastchange',
+      'use_clang_coverage', 'partial_code_coverage_instrumentation', 'devtools_do_typecheck',
+    ],
 
     'gpu_tests_release_trybot_no_symbols_use_dummy_lastchange_invert_fieldtrials': [
       'gpu_tests', 'release_trybot', 'no_symbols', 'use_dummy_lastchange',
diff --git a/tools/mb/mb_config_expectations/chromium.fyi.json b/tools/mb/mb_config_expectations/chromium.fyi.json
index 292f3f5..2bfe417 100644
--- a/tools/mb/mb_config_expectations/chromium.fyi.json
+++ b/tools/mb/mb_config_expectations/chromium.fyi.json
@@ -15,6 +15,21 @@
       "use_goma": true
     }
   },
+  "Build Perf Linux": {
+    "gn_args": {
+      "coverage_instrumentation_input_file": "//.code-coverage/files_to_instrument.txt",
+      "dcheck_always_on": true,
+      "devtools_skip_typecheck": false,
+      "ffmpeg_branding": "Chrome",
+      "is_component_build": false,
+      "is_debug": false,
+      "proprietary_codecs": true,
+      "symbol_level": 0,
+      "use_clang_coverage": true,
+      "use_dummy_lastchange": true,
+      "use_remoteexec": true
+    }
+  },
   "CFI Linux CF (reclient shadow)": {
     "gn_args": {
       "dcheck_always_on": false,
diff --git a/tools/metrics/histograms/enums.xml b/tools/metrics/histograms/enums.xml
index af6ef1d..9b2e8033 100644
--- a/tools/metrics/histograms/enums.xml
+++ b/tools/metrics/histograms/enums.xml
@@ -1688,9 +1688,14 @@
 <enum name="AlternateProtocolUsage">
   <int value="0" label="ALTERNATE_PROTOCOL_USAGE_NO_RACE"/>
   <int value="1" label="ALTERNATE_PROTOCOL_USAGE_WON_RACE"/>
-  <int value="2" label="ALTERNATE_PROTOCOL_USAGE_LOST_RACE"/>
+  <int value="2" label="ALTERNATE_PROTOCOL_USAGE_MAIN_JOB_WON_RACE"/>
   <int value="3" label="ALTERNATE_PROTOCOL_USAGE_MAPPING_MISSING"/>
-  <int value="4" label="ALTERNATE_PROTOCOL_USAGE_BROKEN"/>
+  <int value="4"
+      label="ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE"/>
+  <int value="5" label="ALTERNATE_PROTOCOL_USAGE_BROKEN"/>
+  <int value="6"
+      label="ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_WITOUT_RACE"/>
+  <int value="7" label="ALTERNATE_PROTOCOL_USAGE_DNS_ALPN_H3_JOB_WON_RACE"/>
 </enum>
 
 <enum name="AlternativeServiceType">
@@ -35487,7 +35492,7 @@
   <int value="210" label="kEnterpriseReportingPrivate"/>
   <int value="211" label="kCecPrivate"/>
   <int value="212" label="kSafeBrowsingPrivate"/>
-  <int value="213" label="kFileSystemRequestDownloads"/>
+  <int value="213" label="kDeleted_FileSystemRequestDownloads"/>
   <int value="214" label="kDeleted_SystemPowerSource"/>
   <int value="215" label="kArcAppsPrivate"/>
   <int value="216" label="kEnterpriseHardwarePlatform"/>
@@ -42242,6 +42247,7 @@
   <int value="1" label="Audio"/>
   <int value="2" label="Images"/>
   <int value="3" label="Videos"/>
+  <int value="4" label="Documents"/>
 </enum>
 
 <enum name="FileManagerRootType">
@@ -55507,6 +55513,7 @@
   <int value="-1861278695" label="BulkTabRestore:enabled"/>
   <int value="-1860481724" label="ChromeHomeExpandButton:enabled"/>
   <int value="-1860477300" label="DefaultStyleSheetsEarlyInit:disabled"/>
+  <int value="-1860342103" label="UseDnsHttpsSvcbAlpn:disabled"/>
   <int value="-1859437916"
       label="enable-experimental-accessibility-dictation-offline"/>
   <int value="-1859421131" label="BackForwardCache:disabled"/>
@@ -60253,6 +60260,7 @@
   <int value="1205849612" label="enable-sync-synced-notifications"/>
   <int value="1205929554" label="SendTabToSelfOmniboxSendingAnimation:enabled"/>
   <int value="1206140820" label="RelatedSearchesInBar:disabled"/>
+  <int value="1206486242" label="UseDnsHttpsSvcbAlpn:enabled"/>
   <int value="1210298193" label="FontAccessPersistent:enabled"/>
   <int value="1210343926" label="enable-drop-sync-credential"/>
   <int value="1211284676" label="V8NoTurbo:enabled"/>
diff --git a/tools/metrics/histograms/metadata/arc/histograms.xml b/tools/metrics/histograms/metadata/arc/histograms.xml
index 98477cf..e6e1d2f8 100644
--- a/tools/metrics/histograms/metadata/arc/histograms.xml
+++ b/tools/metrics/histograms/metadata/arc/histograms.xml
@@ -263,6 +263,7 @@
     Number of ARC Apps killed by {ArcAppKillType} in each interval of 10
     minutes.
   </summary>
+  <token key="ArcAppKillType" variants="ArcAppKillType"/>
 </histogram>
 
 <histogram
@@ -274,6 +275,8 @@
     Number of ARC Apps killed by {ArcAppKillType} in each interval of 10 minutes
     when {ArcBackgroundVms}.
   </summary>
+  <token key="ArcAppKillType" variants="ArcAppKillType"/>
+  <token key="ArcBackgroundVms" variants="ArcBackgroundVms"/>
 </histogram>
 
 <histogram name="Arc.App.PrimaryAbi" enum="AppPrimaryAbi"
diff --git a/tools/perf/core/perfetto_binary_roller/binary_deps.json b/tools/perf/core/perfetto_binary_roller/binary_deps.json
index 0ab8288..d8987eb 100644
--- a/tools/perf/core/perfetto_binary_roller/binary_deps.json
+++ b/tools/perf/core/perfetto_binary_roller/binary_deps.json
@@ -14,7 +14,7 @@
         },
         "mac": {
             "hash": "86145908aed91663341ff82850a62108e55baac2",
-            "full_remote_path": "chromium-telemetry/perfetto_binaries/trace_processor_shell/mac/d86457ab539f83842f0e6c891c459bd764267b8d/trace_processor_shell"
+            "full_remote_path": "chromium-telemetry/perfetto_binaries/trace_processor_shell/mac/bb4e6b261ffdcda41c15bf830e594f9c9fe0ce3e/trace_processor_shell"
         },
         "mac_arm64": {
             "hash": "e1ad4861384b06d911a65f035317914b8cc975c6",
@@ -22,7 +22,7 @@
         },
         "linux": {
             "hash": "3963de6f2c1864244db56893a436bf609dcda8a3",
-            "full_remote_path": "chromium-telemetry/perfetto_binaries/trace_processor_shell/linux/d86457ab539f83842f0e6c891c459bd764267b8d/trace_processor_shell"
+            "full_remote_path": "chromium-telemetry/perfetto_binaries/trace_processor_shell/linux/bb4e6b261ffdcda41c15bf830e594f9c9fe0ce3e/trace_processor_shell"
         }
     },
     "power_profile.sql": {
diff --git a/ui/accessibility/test_ax_tree_update_json_reader.cc b/ui/accessibility/test_ax_tree_update_json_reader.cc
index 8f28331..794edd3 100644
--- a/ui/accessibility/test_ax_tree_update_json_reader.cc
+++ b/ui/accessibility/test_ax_tree_update_json_reader.cc
@@ -124,13 +124,15 @@
 }
 
 // In a few cases, role values in JSON file are different from the ones used in
-// AxEnumUtils::ToString and need preprocessing.
-// TODO(https://crbug.com/1278249): Investigate why and if this can be fixed
-// upstream.
+// AxEnumUtils::ToString and need preprocessing. This function and the entire
+// class will be removed after Screen2X starts using Chrome for training data
+// proto generation.
 ax::mojom::Role RoleFromString(std::string role) {
+  // TODO(https://crbug.com/1278249): Consider using
+  // GetScreen2xRoleFromChromeRole in proto_convertor.cc or add test to ensure
+  // the conversions match.
   if (role == "combobox")
-    // TODO(https://crbug.com/1278249): Find a replacement.
-    return ax::mojom::Role::kUnknown;
+    role = "comboBoxGrouping";
   else if (role == "contentinfo")
     role = "contentInfo";
   else if (role == "DescriptionList")
diff --git a/ui/chromeos/strings/network_element_localized_strings_provider.cc b/ui/chromeos/strings/network_element_localized_strings_provider.cc
index ba8d2c0..58cd14de 100644
--- a/ui/chromeos/strings/network_element_localized_strings_provider.cc
+++ b/ui/chromeos/strings/network_element_localized_strings_provider.cc
@@ -8,8 +8,8 @@
 #include "base/feature_list.h"
 #include "base/strings/utf_string_conversions.h"
 #include "build/build_config.h"
+#include "chromeos/ash/components/network/network_connection_handler.h"
 #include "chromeos/login/login_state/login_state.h"
-#include "chromeos/network/network_connection_handler.h"
 #include "chromeos/strings/grit/chromeos_strings.h"
 #include "components/login/localized_values_builder.h"
 #include "components/strings/grit/components_strings.h"
diff --git a/ui/chromeos/translations/ui_chromeos_strings_it.xtb b/ui/chromeos/translations/ui_chromeos_strings_it.xtb
index 11184af..1d0dedf 100644
--- a/ui/chromeos/translations/ui_chromeos_strings_it.xtb
+++ b/ui/chromeos/translations/ui_chromeos_strings_it.xtb
@@ -229,7 +229,7 @@
 <translation id="3003633581067744647">Passa alla visualizzazione miniatura</translation>
 <translation id="3016566519832145558">Attenzione: questi file sono temporanei e potrebbero essere eliminati automaticamente per liberare spazio su disco.</translation>
 <translation id="3029114385395636667">Attiva Documenti Google offline per rendere disponibili offline documenti, fogli e presentazioni.</translation>
-<translation id="303198083543495566">Area geografica</translation>
+<translation id="303198083543495566">Regione</translation>
 <translation id="3047197340186497470">Cinese Dayi</translation>
 <translation id="3057861065630527966">Effettua il backup di foto e video</translation>
 <translation id="3067790092342515856">File di Windows</translation>
diff --git a/ui/chromeos/translations/ui_chromeos_strings_km.xtb b/ui/chromeos/translations/ui_chromeos_strings_km.xtb
index ed45d2f1..a4d0d112 100644
--- a/ui/chromeos/translations/ui_chromeos_strings_km.xtb
+++ b/ui/chromeos/translations/ui_chromeos_strings_km.xtb
@@ -11,6 +11,7 @@
 <translation id="1120073797882051782">រ៉ូម៉ាចាហានគុល</translation>
 <translation id="112387589102719461">ភាសា​អង់គ្លេស (សហរដ្ឋអាមេរិក) ដែលប្រើ​ក្ដារចុច Dvorak សម្រាប់អ្នកសរសេរកម្មវិធី</translation>
 <translation id="1134697384939541955">ភាសា​អង់គ្លេស (សហរដ្ឋ​អាមេរិក) ដែលប្រើ​ក្ដារចុចបន្ថែម</translation>
+<translation id="1138691154716715755">ដើម​ខែ​នេះ</translation>
 <translation id="1148097584170732637">បានរកឃើញ <ph name="FILE_COUNT" /> ។
     <ph name="LINE_BREAK1" />
     មិនមាន​ទំហំផ្ទុក​ទំនេរ​គ្រប់គ្រាន់​នៅក្នុង​ទំហំផ្ទុក​មូលដ្ឋានទេ។ ត្រូវការ​ទំហំ​បន្ថែម <ph name="FILE_SIZE" /> ។
@@ -378,6 +379,7 @@
 <translation id="4380245540200674032">បណ្ដាញ <ph name="NETWORK_INDEX" /> នៃ <ph name="NETWORK_COUNT" />, <ph name="NETWORK_NAME" />, <ph name="NETWORK_PROVIDER_NAME" />, <ph name="CONNECTION_STATUS" />, កម្លាំងរលកសញ្ញា <ph name="SIGNAL_STRENGTH" />%, គ្រប់គ្រងដោយ​អ្នកគ្រប់គ្រង​របស់អ្នក, ព័ត៌មាន​លម្អិត</translation>
 <translation id="4387004326333427325">វិញ្ញាបនប័ត្រសម្គាល់អត្តសញ្ញាណបានបដិសេធពីចម្ងាយ</translation>
 <translation id="4394214039309501350">តំណ​ខាង​ក្រៅ</translation>
+<translation id="4394980935660306080">ដើម​សប្ដាហ៍​នេះ</translation>
 <translation id="4401287888955153199">ដកទាំងអស់</translation>
 <translation id="4410695710508688828">ការស្រង់​ប្រតិបត្តិការ​មិនបានសម្រេចទេ។ <ph name="ERROR_MESSAGE" /></translation>
 <translation id="4418686080762064601">បង្កើត​ផ្លូវកាត់​សម្រាប់​ឯកសារ​របស់អ្នក</translation>
@@ -421,6 +423,7 @@
 <translation id="4712283082407695269">កំពុងបើក "<ph name="PATH" />"</translation>
 <translation id="4720185134442950733">បណ្ដាញ​ទិន្នន័យ​ទូរសព្ទចល័ត</translation>
 <translation id="4724850507808590449">រូបថតចំនួន<ph name="FILE_COUNT" /> ត្រូវបានបម្រុងទុក</translation>
+<translation id="4725096204469550614">ដើម​ឆ្នាំ​នេះ</translation>
 <translation id="4725511304875193254">ឆ្កែ​ខកហ្គី</translation>
 <translation id="4737050008115666127">ផ្លូវចុះចត</translation>
 <translation id="4747271164117300400">ម៉ាសេដូនី</translation>
diff --git a/ui/chromeos/translations/ui_chromeos_strings_uz.xtb b/ui/chromeos/translations/ui_chromeos_strings_uz.xtb
index 3584d5f..2b817d3 100644
--- a/ui/chromeos/translations/ui_chromeos_strings_uz.xtb
+++ b/ui/chromeos/translations/ui_chromeos_strings_uz.xtb
@@ -11,6 +11,7 @@
 <translation id="1120073797882051782">Koreys kiritish usuli (Romaja)</translation>
 <translation id="112387589102719461">Ingliz (AQSH) va Dvorak dasturchilar klaviaturasi</translation>
 <translation id="1134697384939541955">Ingliz (AQSH) va Kengaytirilgan klaviatura</translation>
+<translation id="1138691154716715755">Shu oy boshi</translation>
 <translation id="1148097584170732637"><ph name="FILE_COUNT" /> ta fayl topildi.
     <ph name="LINE_BREAK1" />
     Xotirada bo‘sh joy yetishmaydi. Yana <ph name="FILE_SIZE" /> kerak.
@@ -378,6 +379,7 @@
 <translation id="4380245540200674032">Tarmoq: <ph name="NETWORK_INDEX" />/<ph name="NETWORK_COUNT" />, Nomi: <ph name="NETWORK_NAME" />, Himoyasi: <ph name="NETWORK_PROVIDER_NAME" />, Ulanish: <ph name="CONNECTION_STATUS" />, Signal darajasi: <ph name="SIGNAL_STRENGTH" />%, Administrator boshqaruvida, Batafsil</translation>
 <translation id="4387004326333427325">Haqiqiylikni tekshirish sertifikati masofadan turib rad etildi</translation>
 <translation id="4394214039309501350">Tashqi havola</translation>
+<translation id="4394980935660306080">Shu hafta boshi</translation>
 <translation id="4401287888955153199">Barchasini ajratish</translation>
 <translation id="4410695710508688828">Arxivdan chiqarish amali bajarilmadi. <ph name="ERROR_MESSAGE" /></translation>
 <translation id="4418686080762064601">Fayllaringiz uchun yorliq yarating</translation>
@@ -421,6 +423,7 @@
 <translation id="4712283082407695269">“<ph name="PATH" />” ochilmoqda</translation>
 <translation id="4720185134442950733">Mobil internet tarmog‘i</translation>
 <translation id="4724850507808590449"><ph name="FILE_COUNT" /> ta rasm saqlab qolindi</translation>
+<translation id="4725096204469550614">Shu yil boshi</translation>
 <translation id="4725511304875193254">Korgi</translation>
 <translation id="4737050008115666127">Lending</translation>
 <translation id="4747271164117300400">Makedon</translation>
diff --git a/ui/compositor/test/test_layer_animation_observer.h b/ui/compositor/test/test_layer_animation_observer.h
index 65c86e4..4b08bac 100644
--- a/ui/compositor/test/test_layer_animation_observer.h
+++ b/ui/compositor/test/test_layer_animation_observer.h
@@ -115,25 +115,33 @@
  private:
   int next_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_attached_sequence_;
+  // TODO(crbug.com/1298696): Breaks compositor_unittests.
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_attached_sequence_;
   int last_attached_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_scheduled_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_scheduled_sequence_;
   int last_scheduled_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_started_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_started_sequence_;
   int last_started_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_aborted_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_aborted_sequence_;
   int last_aborted_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_ended_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_ended_sequence_;
   int last_ended_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_repetition_ended_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_repetition_ended_sequence_;
   int last_repetition_ended_sequence_epoch_;
 
-  raw_ptr<const LayerAnimationSequence> last_detached_sequence_;
+  raw_ptr<const LayerAnimationSequence, DegradeToNoOpWhenMTE>
+      last_detached_sequence_;
   int last_detached_sequence_epoch_;
 
   bool requires_notification_when_animator_destroyed_;
diff --git a/ui/file_manager/BUILD.gn b/ui/file_manager/BUILD.gn
index b236dc8e..46dfcaa 100644
--- a/ui/file_manager/BUILD.gn
+++ b/ui/file_manager/BUILD.gn
@@ -141,6 +141,7 @@
   root_dir = preprocess_folder
   out_dir = "$target_gen_dir/tsc"
   tsconfig_base = "tsconfig_base.json"
+  composite = true
 
   extra_deps = [
     ":copy_ts",
@@ -281,6 +282,24 @@
   in_files = ts_templates
 }
 
+ts_library("test_build_ts") {
+  testonly = true
+  root_dir = "."
+  out_dir = "$target_gen_dir/tsc_test"
+  tsconfig_base = "tsconfig_base.json"
+
+  in_files = [ "file_manager/widgets/xf_breadcrumbs_unittest.ts" ]
+
+  path_mappings = [
+    # for chai_assert.js.
+    "chrome://webui-test/*|" +
+        rebase_path("$root_gen_dir/chrome/test/data/webui/tsc/*",
+                    target_gen_dir),
+  ]
+
+  deps = [ ":build_ts" ]
+}
+
 # GRD for test files.
 generate_grd("build_tests_grdp") {
   testonly = true
@@ -298,7 +317,11 @@
   out_grd = "$target_gen_dir/tests_gen_resources.grdp"
 
   manifest_files =
-      filter_include(get_target_outputs(":build_ts"), [ "*.manifest" ])
+      filter_include(get_target_outputs(":build_ts"), [ "*.manifest" ]) +
+      filter_include(get_target_outputs(":test_build_ts"), [ "*.manifest" ])
 
-  deps = [ ":build_ts" ]
+  deps = [
+    ":build_ts",
+    ":test_build_ts",
+  ]
 }
diff --git a/ui/file_manager/file_manager/foreground/css/file_manager.css b/ui/file_manager/file_manager/foreground/css/file_manager.css
index f9efe6d..a093442 100644
--- a/ui/file_manager/file_manager/foreground/css/file_manager.css
+++ b/ui/file_manager/file_manager/foreground/css/file_manager.css
@@ -1787,8 +1787,8 @@
   border: 1px solid var(--cros-focus-ring-color-inactive);
 }
 
-#list-container.nohover grid > .accepts {
-  background-color: transparent;
+#list-container grid > .accepts {
+  background-color: var(--cros-highlight-color-hover)
 }
 
 #directory-tree .tree-item.accepts > .tree-row,
diff --git a/ui/file_manager/file_manager/foreground/js/file_manager.js b/ui/file_manager/file_manager/foreground/js/file_manager.js
index d73216f..1809b7f 100644
--- a/ui/file_manager/file_manager/foreground/js/file_manager.js
+++ b/ui/file_manager/file_manager/foreground/js/file_manager.js
@@ -838,10 +838,6 @@
     this.setContextMenuForInput_(this.ui_.listContainer.renameInput);
     this.setContextMenuForInput_(
         this.directoryTreeNamingController_.getInputElement());
-
-    this.document_.addEventListener(
-        'command',
-        this.ui_.listContainer.clearHover.bind(this.ui_.listContainer));
     CommandHandler.registerUndoDeleteToast(this);
   }
 
diff --git a/ui/file_manager/file_manager/foreground/js/ui/list_container.js b/ui/file_manager/file_manager/foreground/js/ui/list_container.js
index 3d14363..2b338f7 100644
--- a/ui/file_manager/file_manager/foreground/js/ui/list_container.js
+++ b/ui/file_manager/file_manager/foreground/js/ui/list_container.js
@@ -133,7 +133,6 @@
     this.grid.id = 'file-list';
     this.element.addEventListener('keydown', this.onKeyDown_.bind(this));
     this.element.addEventListener('keypress', this.onKeyPress_.bind(this));
-    this.element.addEventListener('mousemove', this.onMouseMove_.bind(this));
     this.element.addEventListener(
         'contextmenu', this.onContextMenu_.bind(this), /* useCapture */ true);
 
@@ -264,13 +263,6 @@
   }
 
   /**
-   * Clears hover highlighting in the list container until next mouse move.
-   */
-  clearHover() {
-    this.element.classList.add('nohover');
-  }
-
-  /**
    * Finds list item element from the ancestor node.
    * @param {!HTMLElement} node
    * @return {ListItem}
@@ -341,19 +333,6 @@
       event.stopImmediatePropagation();
       return;
     }
-
-    switch (event.key) {
-      case 'Home':
-      case 'End':
-      case 'ArrowUp':
-      case 'ArrowDown':
-      case 'ArrowLeft':
-      case 'ArrowRight':
-        // When navigating with keyboard we hide the distracting mouse hover
-        // highlighting until the user moves the mouse again.
-        this.clearHover();
-        break;
-    }
   }
 
   /**
@@ -380,16 +359,6 @@
       dispatchSimpleEvent(this.element, ListContainer.EventType.TEXT_SEARCH);
     }
   }
-
-  /**
-   * Mousemove event handler for the div#list-container element.
-   * @param {Event} event Mouse event.
-   * @private
-   */
-  onMouseMove_(event) {
-    // The user grabbed the mouse, restore the hover highlighting.
-    this.element.classList.remove('nohover');
-  }
 }
 
 /**
diff --git a/ui/file_manager/file_manager/foreground/js/ui/splitter.js b/ui/file_manager/file_manager/foreground/js/ui/splitter.js
index bb6f3a5..7776535 100644
--- a/ui/file_manager/file_manager/foreground/js/ui/splitter.js
+++ b/ui/file_manager/file_manager/foreground/js/ui/splitter.js
@@ -148,7 +148,9 @@
     e = /** @type {!TouchEvent} */ (e);
     if (e.touches.length === 1) {
       this.startDrag(e.touches[0].clientX, true);
-      e.preventDefault();
+      if (e.cancelable) {
+        e.preventDefault();
+      }
     }
   },
 
diff --git a/ui/file_manager/file_manager/widgets/xf_breadcrumbs_unittest.ts b/ui/file_manager/file_manager/widgets/xf_breadcrumbs_unittest.ts
new file mode 100644
index 0000000..4ee631e
--- /dev/null
+++ b/ui/file_manager/file_manager/widgets/xf_breadcrumbs_unittest.ts
@@ -0,0 +1,10 @@
+// Copyright 2022 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+import {assertEquals} from 'chrome://webui-test/chai_assert.js';
+
+export function testBla() {
+  console.log('ITs time!');
+  assertEquals(1, 1);
+}
diff --git a/ui/webui/resources/cr_elements/shared_vars_css.html b/ui/webui/resources/cr_elements/shared_vars_css.html
index 6a571847..74a6cbb2 100644
--- a/ui/webui/resources/cr_elements/shared_vars_css.html
+++ b/ui/webui/resources/cr_elements/shared_vars_css.html
@@ -202,7 +202,7 @@
     --cr-form-field-bottom-spacing: 16px;
     --cr-form-field-label-font-size: .625rem;
     --cr-form-field-label-height: 1em;
-    --cr-form-field-label-line-height: 1em;
+    --cr-form-field-label-line-height: 1;
   }
 </style>
 </custom-style>