diff options
author | robertshield@chromium.org <robertshield@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-28 17:27:17 +0000 |
---|---|---|
committer | robertshield@chromium.org <robertshield@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-05-28 17:27:17 +0000 |
commit | 79b663c6e6ddf89e85cdc566b5d4f368465bb858 (patch) | |
tree | 868c35191ee02c8bd7da15b69edc7114007e211a /chrome_frame/chrome_launcher_unittest.cc | |
parent | 84b5647e4a43a55b9b0e8b211684f48222569218 (diff) | |
download | chromium_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.cc | 83 |
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"")); +} |