diff options
author | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-04-09 06:40:57 +0000 |
---|---|---|
committer | willchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-04-09 06:40:57 +0000 |
commit | 64f001a8a74f5d861d9948155c92419f53928e50 (patch) | |
tree | 4f215495257c68c34f8f1bbc4724e35a73be1788 /chrome/browser/gtk/go_button_gtk_unittest.cc | |
parent | 253071feeaf010115a8fbe498d1ebd634c2d1626 (diff) | |
download | chromium_src-64f001a8a74f5d861d9948155c92419f53928e50.zip chromium_src-64f001a8a74f5d861d9948155c92419f53928e50.tar.gz chromium_src-64f001a8a74f5d861d9948155c92419f53928e50.tar.bz2 |
Implement stop/go button for Linux.
Refactored code out of CustomDrawButton into CustomDrawButtonBase to be shared with GoButtonGtk.
Replaced the existing non-togglable go button with GoButtonGtk.
Note that tooltip support isn't done yet, as it changes based on the state of the location bar and the go/stop state.
Add a simple test.
Fix some minor lint errors.
BUG=9381
Review URL: http://codereview.chromium.org/62154
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@13409 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/gtk/go_button_gtk_unittest.cc')
-rw-r--r-- | chrome/browser/gtk/go_button_gtk_unittest.cc | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/chrome/browser/gtk/go_button_gtk_unittest.cc b/chrome/browser/gtk/go_button_gtk_unittest.cc new file mode 100644 index 0000000..723f587 --- /dev/null +++ b/chrome/browser/gtk/go_button_gtk_unittest.cc @@ -0,0 +1,130 @@ +// Copyright (c) 2009 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 "chrome/browser/gtk/go_button_gtk.h" +#include "base/task.h" +#include "testing/gtest/include/gtest/gtest.h" + +class GoButtonGtkPeer { + public: + explicit GoButtonGtkPeer(GoButtonGtk* go) : go_(go) { } + + // const accessors for internal state + GoButtonGtk::Mode intended_mode() const { return go_->intended_mode_; } + GoButtonGtk::Mode visible_mode() const { return go_->visible_mode_; } + + // mutable accessors for internal state + ScopedRunnableMethodFactory<GoButtonGtk>* stop_timer() { + return &go_->stop_timer_; + } + + // mutators for internal state + void set_state(GoButtonGtk::ButtonState state) { go_->state_ = state; } + void set_intended_mode(GoButtonGtk::Mode mode) { go_->intended_mode_ = mode; } + void set_visible_mode(GoButtonGtk::Mode mode) { go_->visible_mode_ = mode; } + + // forwarders to private methods + Task* CreateButtonTimerTask() { return go_->CreateButtonTimerTask(); } + gboolean OnLeave() { + return GoButtonGtk::OnLeave(GTK_BUTTON(go_->widget()), go_); + } + + gboolean OnClicked() { + return GoButtonGtk::OnClicked(GTK_BUTTON(go_->widget()), go_); + } + + private: + GoButtonGtk* const go_; +}; + +namespace { + +class GoButtonGtkTest : public testing::Test { + protected: + GoButtonGtkTest() : go_(NULL), peer_(&go_) { } + + protected: + GoButtonGtk go_; + GoButtonGtkPeer peer_; +}; + +TEST_F(GoButtonGtkTest, ChangeModeGo) { + go_.ChangeMode(GoButtonGtk::MODE_GO); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ChangeModeStop) { + go_.ChangeMode(GoButtonGtk::MODE_GO); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ScheduleChangeModeNormalGo) { + peer_.set_visible_mode(GoButtonGtk::MODE_STOP); + peer_.set_state(GoButtonGtk::BS_NORMAL); + go_.ScheduleChangeMode(GoButtonGtk::MODE_GO); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ScheduleChangeModeHotGo) { + peer_.set_visible_mode(GoButtonGtk::MODE_STOP); + peer_.set_state(GoButtonGtk::BS_HOT); + go_.ScheduleChangeMode(GoButtonGtk::MODE_GO); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ScheduleChangeModeNormalStop) { + peer_.set_visible_mode(GoButtonGtk::MODE_GO); + peer_.set_state(GoButtonGtk::BS_NORMAL); + go_.ScheduleChangeMode(GoButtonGtk::MODE_STOP); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ScheduleChangeModeHotStop) { + peer_.set_visible_mode(GoButtonGtk::MODE_GO); + peer_.set_state(GoButtonGtk::BS_HOT); + go_.ScheduleChangeMode(GoButtonGtk::MODE_STOP); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, ScheduleChangeModeTimerHotStop) { + peer_.set_visible_mode(GoButtonGtk::MODE_GO); + peer_.set_state(GoButtonGtk::BS_HOT); + scoped_ptr<Task> task(peer_.CreateButtonTimerTask()); + go_.ScheduleChangeMode(GoButtonGtk::MODE_STOP); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.intended_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); +} + +TEST_F(GoButtonGtkTest, OnLeaveIntendedStop) { + peer_.set_state(GoButtonGtk::BS_HOT); + peer_.set_visible_mode(GoButtonGtk::MODE_GO); + peer_.set_intended_mode(GoButtonGtk::MODE_STOP); + EXPECT_TRUE(peer_.OnLeave()); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.visible_mode()); + EXPECT_EQ(GoButtonGtk::MODE_STOP, peer_.intended_mode()); +} + +TEST_F(GoButtonGtkTest, OnLeaveIntendedGo) { + peer_.set_state(GoButtonGtk::BS_HOT); + peer_.set_visible_mode(GoButtonGtk::MODE_STOP); + peer_.set_intended_mode(GoButtonGtk::MODE_GO); + EXPECT_TRUE(peer_.OnLeave()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); +} + +TEST_F(GoButtonGtkTest, OnClickedStop) { + peer_.set_visible_mode(GoButtonGtk::MODE_STOP); + EXPECT_TRUE(peer_.OnClicked()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.visible_mode()); + EXPECT_EQ(GoButtonGtk::MODE_GO, peer_.intended_mode()); +} + +} // namespace |