Index: chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc |
diff --git a/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc b/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..aa6caf3a1ccc05060173e1557af7730cb6c14f73 |
--- /dev/null |
+++ b/chrome/test/chromedriver/chrome/mobile_emulation_override_manager.cc |
@@ -0,0 +1,55 @@ |
+// Copyright (c) 2014 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 "base/values.h" |
+#include "chrome/test/chromedriver/chrome/device_metrics.h" |
+#include "chrome/test/chromedriver/chrome/devtools_client.h" |
+#include "chrome/test/chromedriver/chrome/mobile_emulation_override_manager.h" |
+#include "chrome/test/chromedriver/chrome/status.h" |
+ |
+MobileEmulationOverrideManager::MobileEmulationOverrideManager( |
+ DevToolsClient* client, |
+ const DeviceMetrics* device_metrics) |
+ : client_(client), overridden_device_metrics_(device_metrics) { |
+ if (overridden_device_metrics_) |
+ client_->AddListener(this); |
+} |
+ |
+MobileEmulationOverrideManager::~MobileEmulationOverrideManager() { |
+} |
+ |
+Status MobileEmulationOverrideManager::OnConnected(DevToolsClient* client) { |
+ return ApplyOverrideIfNeeded(); |
+} |
+ |
+Status MobileEmulationOverrideManager::OnEvent( |
+ DevToolsClient* client, |
+ const std::string& method, |
+ const base::DictionaryValue& params) { |
+ if (method == "Page.frameNavigated") { |
+ const base::Value* unused_value; |
+ if (!params.Get("frame.parentId", &unused_value)) |
+ return ApplyOverrideIfNeeded(); |
+ } |
+ return Status(kOk); |
+} |
+ |
+Status MobileEmulationOverrideManager::ApplyOverrideIfNeeded() { |
+ if (overridden_device_metrics_ == NULL) |
+ return Status(kOk); |
+ |
+ base::DictionaryValue params; |
+ params.SetInteger("width", overridden_device_metrics_->width); |
+ params.SetInteger("height", overridden_device_metrics_->height); |
+ params.SetDouble("deviceScaleFactor", |
+ overridden_device_metrics_->device_scale_factor); |
+ params.SetBoolean("emulateViewport", |
+ overridden_device_metrics_->emulate_viewport); |
+ params.SetBoolean("fitWindow", overridden_device_metrics_->fit_window); |
+ params.SetBoolean("textAutosizing", |
+ overridden_device_metrics_->text_autosizing); |
+ params.SetDouble("fontScaleFactor", |
+ overridden_device_metrics_->font_scale_factor); |
+ return client_->SendCommand("Page.setDeviceMetricsOverride", params); |
+} |