summaryrefslogtreecommitdiffstats
path: root/chrome/browser/gtk/go_button_gtk_unittest.cc
diff options
context:
space:
mode:
authorwillchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-04-09 06:40:57 +0000
committerwillchan@chromium.org <willchan@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-04-09 06:40:57 +0000
commit64f001a8a74f5d861d9948155c92419f53928e50 (patch)
tree4f215495257c68c34f8f1bbc4724e35a73be1788 /chrome/browser/gtk/go_button_gtk_unittest.cc
parent253071feeaf010115a8fbe498d1ebd634c2d1626 (diff)
downloadchromium_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.cc130
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