Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(620)

Side by Side Diff: chrome/test/chromedriver/chrome/device_metrics_override_manager.cc

Issue 251933005: [ChromeDriver] Support mobile emulation on desktop Chrome. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright (c) 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "base/values.h"
6 #include "chrome/test/chromedriver/chrome/device_metrics.h"
7 #include "chrome/test/chromedriver/chrome/device_metrics_override_manager.h"
8 #include "chrome/test/chromedriver/chrome/devtools_client.h"
9 #include "chrome/test/chromedriver/chrome/status.h"
10
11 DeviceMetricsOverrideManager::DeviceMetricsOverrideManager(DevToolsClient* clien t)
12 : client_(client) {
13 client_->AddListener(this);
14 }
15
16 DeviceMetricsOverrideManager::~DeviceMetricsOverrideManager() {
17 }
18
19 Status DeviceMetricsOverrideManager::OverrideDeviceMetrics(
20 const DeviceMetrics& device_metrics) {
21 overridden_device_metrics_.reset(new DeviceMetrics(device_metrics));
22 return ApplyOverrideIfNeeded();
23 }
24
25 Status DeviceMetricsOverrideManager::OnConnected(DevToolsClient* client) {
26 return ApplyOverrideIfNeeded();
27 }
28
29 Status DeviceMetricsOverrideManager::OnEvent(
30 DevToolsClient* client,
31 const std::string& method,
32 const base::DictionaryValue& params) {
33 if (method == "Page.frameNavigated") {
34 const base::Value* unused_value;
35 if (!params.Get("frame.parentId", &unused_value))
36 return ApplyOverrideIfNeeded();
37 }
38 return Status(kOk);
39 }
40
41 Status DeviceMetricsOverrideManager::ApplyOverrideIfNeeded() {
42 if (!overridden_device_metrics_)
43 return Status(kOk);
44
45 base::DictionaryValue params;
46 params.SetInteger("width", overridden_device_metrics_->width);
47 params.SetInteger("height", overridden_device_metrics_->height);
48 params.SetDouble("deviceScaleFactor", overridden_device_metrics_->device_scale _factor);
49 params.SetBoolean("emulateViewport", overridden_device_metrics_->emulate_viewp ort);
50 params.SetBoolean("fitWindow", overridden_device_metrics_->fit_window);
51 params.SetBoolean("textAutosizing", overridden_device_metrics_->text_autosizin g);
52 params.SetDouble("fontScaleFactor", overridden_device_metrics_->font_scale_fac tor);
53 return client_->SendCommand("Page.setDeviceMetricsOverride", params);
54 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698