summaryrefslogtreecommitdiffstats
path: root/chrome_frame/chrome_launcher_unittest.cc
diff options
context:
space:
mode:
authorrobertshield@chromium.org <robertshield@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-28 17:27:17 +0000
committerrobertshield@chromium.org <robertshield@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-05-28 17:27:17 +0000
commit79b663c6e6ddf89e85cdc566b5d4f368465bb858 (patch)
tree868c35191ee02c8bd7da15b69edc7114007e211a /chrome_frame/chrome_launcher_unittest.cc
parent84b5647e4a43a55b9b0e8b211684f48222569218 (diff)
downloadchromium_src-79b663c6e6ddf89e85cdc566b5d4f368465bb858.zip
chromium_src-79b663c6e6ddf89e85cdc566b5d4f368465bb858.tar.gz
chromium_src-79b663c6e6ddf89e85cdc566b5d4f368465bb858.tar.bz2
Rewrite of chrome_launcher.exe. ETW-based perf tests suggest that this is on average about 50% faster than the previous version.
Review URL: http://codereview.chromium.org/2278003 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@48500 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome_frame/chrome_launcher_unittest.cc')
-rw-r--r--chrome_frame/chrome_launcher_unittest.cc83
1 files changed, 54 insertions, 29 deletions
diff --git a/chrome_frame/chrome_launcher_unittest.cc b/chrome_frame/chrome_launcher_unittest.cc
index fa6efd8..c577d1e 100644
--- a/chrome_frame/chrome_launcher_unittest.cc
+++ b/chrome_frame/chrome_launcher_unittest.cc
@@ -8,41 +8,66 @@
#include "chrome_frame/chrome_launcher.h"
#include "testing/gtest/include/gtest/gtest.h"
-namespace {
+TEST(ChromeLauncher, IsValidCommandLine) {
+ CommandLine bad(FilePath(L"dummy.exe"));
+ bad.AppendSwitch(switches::kNoFirstRun); // in whitelist
+ bad.AppendSwitch("no-such-switch"); // does not exist
+ bad.AppendSwitch(switches::kHomePage); // exists but not in whitelist
-// Utility class to disable logging. Required to disable DCHECKs that some
-// of our tests would otherwise trigger.
-class LogDisabler {
- public:
- LogDisabler() {
- initial_log_level_ = logging::GetMinLogLevel();
- logging::SetMinLogLevel(logging::LOG_FATAL + 1);
- }
+ EXPECT_FALSE(chrome_launcher::IsValidCommandLine(
+ bad.command_line_string().c_str()));
- ~LogDisabler() {
- logging::SetMinLogLevel(initial_log_level_);
- }
+ CommandLine good(FilePath(L"dummy.exe"));
+ good.AppendSwitch(switches::kNoFirstRun); // in whitelist
+ good.AppendSwitchWithValue(switches::kUserDataDir, L"foo"); // in whitelist
- private:
- int initial_log_level_;
-};
+ EXPECT_TRUE(chrome_launcher::IsValidCommandLine(
+ good.command_line_string().c_str()));
-} // namespace
+ CommandLine no_params(FilePath(L"dummy.exe"));
+ EXPECT_TRUE(chrome_launcher::IsValidCommandLine(
+ no_params.command_line_string().c_str()));
-TEST(ChromeLauncher, SanitizeCommandLine) {
- CommandLine bad(FilePath(L"dummy.exe"));
- bad.AppendSwitch(switches::kNoFirstRun); // in whitelist
- bad.AppendSwitchWithValue(switches::kLoadExtension, L"foo"); // in whitelist
- bad.AppendSwitch("no-such-switch"); // does not exist
- bad.AppendSwitch(switches::kHomePage); // exists but not in whitelist
+ CommandLine empty(FilePath(L""));
+ EXPECT_TRUE(chrome_launcher::IsValidCommandLine(
+ empty.command_line_string().c_str()));
+}
+
+TEST(ChromeLauncher, TrimWhiteSpace) {
+ std::wstring trimmed(chrome_launcher::TrimWhiteSpace(L" \t some text \n\t"));
+ EXPECT_STREQ(L"some text", trimmed.c_str());
+
+ std::wstring now_empty(chrome_launcher::TrimWhiteSpace(L"\t\t \n\t"));
+ EXPECT_STREQ(L"", now_empty.c_str());
+
+ std::wstring empty(chrome_launcher::TrimWhiteSpace(L""));
+ EXPECT_STREQ(L"", empty.c_str());
- LogDisabler no_dchecks;
+ std::wstring not_trimmed(chrome_launcher::TrimWhiteSpace(L"foo bar"));
+ EXPECT_STREQ(L"foo bar", not_trimmed.c_str());
- CommandLine sanitized(FilePath(L"dumbo.exe"));
- chrome_launcher::SanitizeCommandLine(bad, &sanitized);
- EXPECT_TRUE(sanitized.HasSwitch(switches::kNoFirstRun));
- EXPECT_FALSE(sanitized.HasSwitch(switches::kLoadExtension));
- EXPECT_FALSE(sanitized.HasSwitch("no-such-switch"));
- EXPECT_FALSE(sanitized.HasSwitch(switches::kHomePage));
+ std::wstring trimmed_right(chrome_launcher::TrimWhiteSpace(L"foo bar\t"));
+ EXPECT_STREQ(L"foo bar", trimmed_right.c_str());
+
+ std::wstring trimmed_left(chrome_launcher::TrimWhiteSpace(L"\nfoo bar"));
+ EXPECT_STREQ(L"foo bar", trimmed_right.c_str());
}
+TEST(ChromeLauncher, IsValidArgument) {
+ EXPECT_TRUE(chrome_launcher::IsValidArgument(L"--chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"--invalid-arg"));
+
+ EXPECT_TRUE(chrome_launcher::IsValidArgument(L"--chrome-frame="));
+ EXPECT_TRUE(chrome_launcher::IsValidArgument(L"--chrome-frame=foo"));
+ EXPECT_TRUE(chrome_launcher::IsValidArgument(L"--chrome-frame=foo=foo"));
+
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"-chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"---chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L" --chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"--chrome-framefoobar"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"foobar--chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"--chrome-frames"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L"--Chrome-frame"));
+ EXPECT_FALSE(chrome_launcher::IsValidArgument(L""));
+}