diff options
-rw-r--r-- | chrome/browser/browser_theme_provider_unittest.cc | 49 | ||||
-rw-r--r-- | chrome/chrome.gyp | 1 | ||||
-rw-r--r-- | chrome/test/unit/unittests.vcproj | 4 |
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> |