Index: chrome/browser/ui/views/status_icons/status_tray_chromeos_unittest.cc |
diff --git a/chrome/browser/ui/views/status_icons/status_tray_chromeos_unittest.cc b/chrome/browser/ui/views/status_icons/status_tray_chromeos_unittest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..059679c7fb9cae36454d53200d09812afc1e3010 |
--- /dev/null |
+++ b/chrome/browser/ui/views/status_icons/status_tray_chromeos_unittest.cc |
@@ -0,0 +1,54 @@ |
+// Copyright (c) 2011 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/string_util.h" |
+#include "base/utf_string_conversions.h" |
+#include "chrome/browser/ui/views/status_icons/status_icon_chromeos.h" |
+#include "chrome/browser/ui/views/status_icons/status_tray_chromeos.h" |
+#include "grit/theme_resources.h" |
+#include "testing/gmock/include/gmock/gmock.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+#include "ui/base/models/simple_menu_model.h" |
+#include "ui/base/resource/resource_bundle.h" |
+ |
+class SkBitmap; |
+ |
+class MockStatusIconObserver : public StatusIcon::Observer { |
+ public: |
+ MOCK_METHOD0(OnClicked, void()); |
+}; |
+ |
+TEST(StatusTrayChromeOSTest, CreateTray) { |
+ // Just tests creation/destruction. |
+ StatusTrayChromeOS tray; |
+} |
+ |
+TEST(StatusTrayChromeOSTest, CreateIconAndMenu) { |
+ // Create an icon, set the images, tooltip, and context menu, then shut it |
+ // down. |
+ StatusTrayChromeOS tray; |
+ StatusIcon* icon = tray.CreateStatusIcon(); |
+ SkBitmap* bitmap = ResourceBundle::GetSharedInstance().GetBitmapNamed( |
+ IDR_STATUS_TRAY_ICON); |
+ icon->SetImage(*bitmap); |
+ icon->SetPressedImage(*bitmap); |
+ icon->SetToolTip(ASCIIToUTF16("tool tip")); |
+ ui::SimpleMenuModel* menu = new ui::SimpleMenuModel(NULL); |
+ menu->AddItem(0, ASCIIToUTF16("foo")); |
+ icon->SetContextMenu(menu); |
+} |
Andrew T Wilson (Slow)
2011/11/14 23:46:03
Is there any way for us to test that the appropria
Leandro GraciĆ” Gil
2011/11/15 22:23:31
Good point. I guess we need to make this a browser
|
+ |
+TEST(StatusTrayChromeOSTest, ClickOnIcon) { |
+ // Create an icon, send a fake click event, make sure observer is called. |
+ StatusTrayChromeOS tray; |
+ StatusIconChromeOS* icon = |
+ static_cast<StatusIconChromeOS*>(tray.CreateStatusIcon()); |
+ MockStatusIconObserver observer; |
+ icon->AddObserver(&observer); |
+ EXPECT_CALL(observer, OnClicked()); |
+ // Mimic a click. |
+ icon->Clicked(); |
+ icon->RemoveObserver(&observer); |
+} |
+ |