Chromium Code Reviews| 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", |
|
pfeldman
2014/05/20 18:57:29
Note that you are using undocumented API that is a
dgozman
2014/05/20 19:01:40
Yes, I want to do this to emphasize it's not only
srawlins
2014/05/20 19:36:15
@pfeldman, @dgozman: SGTM. We can update chromedri
|
| + 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); |
| +} |