Chromium Code Reviews| Index: chrome/browser/ui/zoom/zoom_controller_browsertest.cc |
| diff --git a/chrome/browser/ui/zoom/zoom_controller_browsertest.cc b/chrome/browser/ui/zoom/zoom_controller_browsertest.cc |
| index 1d44bcc9e476756b6710d261274b2bd8ac0b69e5..8d49d33f266432314d8ec479db9294c268be0d6b 100644 |
| --- a/chrome/browser/ui/zoom/zoom_controller_browsertest.cc |
| +++ b/chrome/browser/ui/zoom/zoom_controller_browsertest.cc |
| @@ -4,16 +4,65 @@ |
| #include "chrome/browser/ui/zoom/zoom_controller.h" |
| +#include "base/prefs/pref_service.h" |
| #include "base/process/kill.h" |
| +#include "chrome/browser/profiles/profile.h" |
| #include "chrome/browser/ui/browser.h" |
| #include "chrome/browser/ui/tabs/tab_strip_model.h" |
| +#include "chrome/common/pref_names.h" |
| #include "chrome/test/base/in_process_browser_test.h" |
| #include "chrome/test/base/ui_test_utils.h" |
| #include "content/public/browser/render_process_host.h" |
| #include "content/public/browser/web_contents.h" |
| #include "content/public/test/browser_test_utils.h" |
| +#include "testing/gmock/include/gmock/gmock.h" |
| -typedef InProcessBrowserTest ZoomControllerBrowserTest; |
| +bool operator==(const ZoomController::ZoomChangedEventData& lhs, |
| + const ZoomController::ZoomChangedEventData& rhs) { |
| + return lhs.web_contents == rhs.web_contents && |
| + lhs.old_zoom_level == rhs.old_zoom_level && |
| + lhs.new_zoom_level == rhs.new_zoom_level && |
| + lhs.zoom_mode == rhs.zoom_mode && |
| + lhs.can_show_bubble == rhs.can_show_bubble; |
| +} |
| + |
| +class ZoomChangedWatcher : public ZoomObserver { |
| + public: |
| + ZoomChangedWatcher( |
| + content::WebContents* web_contents, |
| + const ZoomController::ZoomChangedEventData& expected_event_data) |
| + : web_contents_(web_contents), |
| + expected_event_data_(expected_event_data), |
| + message_loop_runner_(new content::MessageLoopRunner) { |
| + ZoomController::FromWebContents(web_contents)->AddObserver(this); |
| + } |
| + virtual ~ZoomChangedWatcher() {} |
| + |
| + void Wait() { message_loop_runner_->Run(); } |
|
Dan Beam
2014/08/27 22:46:09
nit: \n
wjmaclean
2014/09/02 13:05:13
Done.
|
| + virtual void OnZoomChanged( |
| + const ZoomController::ZoomChangedEventData& event_data) OVERRIDE { |
| + if (event_data == expected_event_data_) |
| + message_loop_runner_->Quit(); |
| + } |
| + |
| + private: |
| + content::WebContents* web_contents_; |
| + ZoomController::ZoomChangedEventData expected_event_data_; |
| + scoped_refptr<content::MessageLoopRunner> message_loop_runner_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(ZoomChangedWatcher); |
| +}; |
| + |
| +class TestZoomObserver : public ZoomObserver { |
| + public: |
| + MOCK_METHOD1(OnZoomChanged, |
| + void(const ZoomController::ZoomChangedEventData&)); |
| +}; |
| + |
| +class ZoomControllerBrowserTest : public InProcessBrowserTest { |
| + protected: |
|
Dan Beam
2014/08/27 22:46:09
nit: i'd say make public accessors with private me
wjmaclean
2014/09/02 13:05:12
Just realized we aren't using this anyway, so remo
|
| + TestZoomObserver zoom_observer_; |
| +}; |
| // TODO(wjmaclean): Enable this on Android when we can kill the process there. |
| #if defined(OS_ANDROID) |
| @@ -47,3 +96,25 @@ IN_PROC_BROWSER_TEST_F(ZoomControllerBrowserTest, |
| zoom_controller->SetZoomLevel(new_zoom_level); |
| EXPECT_FLOAT_EQ(old_zoom_level, zoom_controller->GetZoomLevel()); |
| } |
| + |
| +IN_PROC_BROWSER_TEST_F(ZoomControllerBrowserTest, OnPreferenceChanged) { |
| + content::WebContents* web_contents = |
| + browser()->tab_strip_model()->GetActiveWebContents(); |
| + double new_default_zoom_level = 1.0; |
| + // Since this page uses the default zoom level, the changes to the default |
| + // zoom level will change the zoom level for this web_contents. |
| + ZoomController::ZoomChangedEventData zoom_change_data( |
| + web_contents, |
| + new_default_zoom_level, |
| + new_default_zoom_level, |
| + ZoomController::ZOOM_MODE_DEFAULT, |
| + true); |
| + ZoomChangedWatcher zoom_change_watcher(web_contents, zoom_change_data); |
| + // TODO(wjmaclean) Convert this to call partition-specific zoom level prefs |
|
Dan Beam
2014/08/27 22:46:09
add colon, e.g., TODO(wjmaclean): Convert
wjmaclean
2014/09/02 13:05:13
Done.
|
| + // when they become available. |
| + browser()->profile()->GetPrefs()->SetDouble(prefs::kDefaultZoomLevel, |
| + new_default_zoom_level); |
| + // Because this test relies on a round-trip IPC to/from the renderer process, |
| + // we need to wait for it to propagate. |
| + zoom_change_watcher.Wait(); |
| +} |