diff options
author | tommi@chromium.org <tommi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-14 23:50:39 +0000 |
---|---|---|
committer | tommi@chromium.org <tommi@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-11-14 23:50:39 +0000 |
commit | 12c0b1823a10d2b0cf63144bcd32b556c73177af (patch) | |
tree | 82eed146adb70c8dc8c0ab6272e6a15a28547497 /base/command_line_unittest.cc | |
parent | 6d34dbe21bbb05a52ea2d5614d518632d7ebc7bc (diff) | |
download | chromium_src-12c0b1823a10d2b0cf63144bcd32b556c73177af.zip chromium_src-12c0b1823a10d2b0cf63144bcd32b556c73177af.tar.gz chromium_src-12c0b1823a10d2b0cf63144bcd32b556c73177af.tar.bz2 |
Changing the installer switches from wchar_t[] to char[].
Because of this I'm also refactoring some code that before
was using wstring to build command lines by hand instead of
using the CommandLine class. Now we use CommandLine.
To get this to work correctly, I also needed to fix CommandLine::AppendArguments so I added a little test for it.
TEST=There should be no changes in functionality. Run all installer tests.
BUG=61609
Review URL: http://codereview.chromium.org/4928002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@66088 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/command_line_unittest.cc')
-rw-r--r-- | base/command_line_unittest.cc | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/base/command_line_unittest.cc b/base/command_line_unittest.cc index 9184aa3..5c525ae 100644 --- a/base/command_line_unittest.cc +++ b/base/command_line_unittest.cc @@ -5,8 +5,8 @@ #include <string> #include <vector> -#include "base/command_line.h" #include "base/basictypes.h" +#include "base/command_line.h" #include "base/file_path.h" #include "base/utf_string_conversions.h" #include "testing/gtest/include/gtest/gtest.h" @@ -154,3 +154,28 @@ TEST(CommandLineTest, AppendSwitches) { cl.command_line_string()); #endif } + +// Tests that when AppendArguments is called that the program is set correctly +// on the target CommandLine object and the switches from the source +// CommandLine are added to the target. +TEST(CommandLineTest, AppendArguments) { + CommandLine cl1(FilePath(FILE_PATH_LITERAL("Program"))); + cl1.AppendSwitch("switch1"); + cl1.AppendSwitchASCII("switch2", "foo"); + + CommandLine cl2(CommandLine::NO_PROGRAM); + cl2.AppendArguments(cl1, true); + EXPECT_EQ(cl1.GetProgram().value(), cl2.GetProgram().value()); + EXPECT_EQ(cl1.command_line_string(), cl2.command_line_string()); + + CommandLine c1(FilePath(FILE_PATH_LITERAL("Program1"))); + c1.AppendSwitch("switch1"); + CommandLine c2(FilePath(FILE_PATH_LITERAL("Program2"))); + c2.AppendSwitch("switch2"); + + c1.AppendArguments(c2, true); + EXPECT_EQ(c1.GetProgram().value(), c2.GetProgram().value()); + EXPECT_TRUE(c1.HasSwitch("switch1")); + EXPECT_TRUE(c1.HasSwitch("switch2")); +} + |