summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/browser/browser_theme_provider_unittest.cc49
-rw-r--r--chrome/chrome.gyp1
-rw-r--r--chrome/test/unit/unittests.vcproj4
3 files changed, 54 insertions, 0 deletions
diff --git a/chrome/browser/browser_theme_provider_unittest.cc b/chrome/browser/browser_theme_provider_unittest.cc
new file mode 100644
index 0000000..21afdd3
--- /dev/null
+++ b/chrome/browser/browser_theme_provider_unittest.cc
@@ -0,0 +1,49 @@
+// 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/browser_theme_provider.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+TEST(BrowserThemeProviderTest, AlignmentConversion) {
+ // Verify that we get out what we put in.
+ std::string top_left = "top left";
+ int alignment = BrowserThemeProvider::StringToAlignment(top_left);
+ EXPECT_EQ(BrowserThemeProvider::ALIGN_TOP | BrowserThemeProvider::ALIGN_LEFT,
+ alignment);
+ EXPECT_EQ(top_left, BrowserThemeProvider::AlignmentToString(alignment));
+
+ alignment = BrowserThemeProvider::StringToAlignment("top");
+ EXPECT_EQ(BrowserThemeProvider::ALIGN_TOP, alignment);
+ EXPECT_EQ("top", BrowserThemeProvider::AlignmentToString(alignment));
+
+ alignment = BrowserThemeProvider::StringToAlignment("left");
+ EXPECT_EQ(BrowserThemeProvider::ALIGN_LEFT, alignment);
+ EXPECT_EQ("left", BrowserThemeProvider::AlignmentToString(alignment));
+
+ alignment = BrowserThemeProvider::StringToAlignment("right");
+ EXPECT_EQ(BrowserThemeProvider::ALIGN_RIGHT, alignment);
+ EXPECT_EQ("right", BrowserThemeProvider::AlignmentToString(alignment));
+
+ alignment = BrowserThemeProvider::StringToAlignment("righttopbottom");
+ EXPECT_EQ(BrowserThemeProvider::ALIGN_CENTER, alignment);
+ EXPECT_EQ("", BrowserThemeProvider::AlignmentToString(alignment));
+}
+
+TEST(BrowserThemeProviderTest, AlignmentConversionInput) {
+ // Verify that we output in an expected format.
+ int alignment = BrowserThemeProvider::StringToAlignment("right bottom");
+ EXPECT_EQ("bottom right", BrowserThemeProvider::AlignmentToString(alignment));
+
+ // Verify that bad strings don't cause explosions.
+ alignment = BrowserThemeProvider::StringToAlignment("new zealand");
+ EXPECT_EQ("", BrowserThemeProvider::AlignmentToString(alignment));
+
+ // Verify that bad strings don't cause explosions.
+ alignment = BrowserThemeProvider::StringToAlignment("new zealand top");
+ EXPECT_EQ("top", BrowserThemeProvider::AlignmentToString(alignment));
+
+ // Verify that bad strings don't cause explosions.
+ alignment = BrowserThemeProvider::StringToAlignment("new zealandtop");
+ EXPECT_EQ("", BrowserThemeProvider::AlignmentToString(alignment));
+}
diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp
index 0fc4a1d..58a49f7 100644
--- a/chrome/chrome.gyp
+++ b/chrome/chrome.gyp
@@ -3070,6 +3070,7 @@
'browser/autocomplete/keyword_provider_unittest.cc',
'browser/autocomplete/search_provider_unittest.cc',
'browser/back_forward_menu_model_unittest.cc',
+ 'browser/base/browser_theme_provider_unittest.cc',
'browser/bookmarks/bookmark_codec_unittest.cc',
'browser/bookmarks/bookmark_context_menu_test.cc',
'browser/bookmarks/bookmark_drag_data_unittest.cc',
diff --git a/chrome/test/unit/unittests.vcproj b/chrome/test/unit/unittests.vcproj
index ad678b9..dc8360f 100644
--- a/chrome/test/unit/unittests.vcproj
+++ b/chrome/test/unit/unittests.vcproj
@@ -462,6 +462,10 @@
>
</File>
<File
+ RelativePath="..\..\browser\browser_theme_provider_unittest.cc"
+ >
+ </File>
+ <File
RelativePath="..\..\browser\browser_unittest.cc"
>
</File>