diff options
author | Evan Martin <martine@danga.com> | 2011-05-06 21:20:34 (GMT) |
---|---|---|
committer | Evan Martin <martine@danga.com> | 2011-05-08 20:52:51 (GMT) |
commit | 70931062b988d8df44656e7b0555821181bc8315 (patch) | |
tree | 5f384e658793a547b61163640e6dd41ca691becf /src/subprocess_test.cc | |
parent | a0fef96444b11f48b6350969c50c21ab7ef37ddd (diff) | |
download | Ninja-70931062b988d8df44656e7b0555821181bc8315.zip Ninja-70931062b988d8df44656e7b0555821181bc8315.tar.gz Ninja-70931062b988d8df44656e7b0555821181bc8315.tar.bz2 |
windows: pass subprocess tests
Diffstat (limited to 'src/subprocess_test.cc')
-rw-r--r-- | src/subprocess_test.cc | 79 |
1 files changed, 51 insertions, 28 deletions
diff --git a/src/subprocess_test.cc b/src/subprocess_test.cc index c158810..b446e13 100644 --- a/src/subprocess_test.cc +++ b/src/subprocess_test.cc @@ -16,59 +16,82 @@ #include "test.h" -TEST(Subprocess, Ls) { +namespace { + +#ifdef _WIN32 +const char* kSimpleCommand = "dir \\"; +#else +const char* kSimpleCommand = "ls /"; +#endif + +struct SubprocessTest : public testing::Test { + SubprocessSet subprocs_; +}; + +} // anonymous namespace + +// Run a command that succeeds and emits to stdout. +TEST_F(SubprocessTest, GoodCommandStdout) { Subprocess ls; - EXPECT_TRUE(ls.Start(NULL, "ls /")); + EXPECT_TRUE(ls.Start(&subprocs_, kSimpleCommand)); - // Pretend we discovered that stdout was ready for writing. - ls.OnPipeReady(); + while (!ls.Done()) { + // Pretend we discovered that stdout was ready for writing. + ls.OnPipeReady(); + } EXPECT_TRUE(ls.Finish()); EXPECT_NE("", ls.GetOutput()); } -TEST(Subprocess, BadCommand) { +// Run a command that fails and emits to stderr. +TEST_F(SubprocessTest, BadCommandStderr) { Subprocess subproc; - EXPECT_TRUE(subproc.Start(NULL, "ninja_no_such_command")); + EXPECT_TRUE(subproc.Start(&subprocs_, "ninja_no_such_command")); - // Pretend we discovered that stderr was ready for writing. - subproc.OnPipeReady(); + while (!subproc.Done()) { + // Pretend we discovered that stderr was ready for writing. + subproc.OnPipeReady(); + } EXPECT_FALSE(subproc.Finish()); EXPECT_NE("", subproc.GetOutput()); } -TEST(SubprocessSet, Single) { - SubprocessSet subprocs; - Subprocess* ls = new Subprocess; - EXPECT_TRUE(ls->Start(NULL, "ls /")); - subprocs.Add(ls); +TEST_F(SubprocessTest, SetWithSingle) { + Subprocess* subproc = new Subprocess; + EXPECT_TRUE(subproc->Start(&subprocs_, kSimpleCommand)); + subprocs_.Add(subproc); - while (!ls->Done()) { - subprocs.DoWork(); + while (!subproc->Done()) { + subprocs_.DoWork(); } - ASSERT_TRUE(ls->Finish()); - ASSERT_NE("", ls->GetOutput()); + ASSERT_TRUE(subproc->Finish()); + ASSERT_NE("", subproc->GetOutput()); - ASSERT_EQ(1u, subprocs.finished_.size()); + ASSERT_EQ(1u, subprocs_.finished_.size()); } -TEST(SubprocessSet, Multi) { - SubprocessSet subprocs; +TEST_F(SubprocessTest, SetWithMulti) { Subprocess* processes[3]; const char* kCommands[3] = { - "ls /", + kSimpleCommand, +#ifdef _WIN32 + "echo hi", + "time /t", +#else "whoami", "pwd", +#endif }; for (int i = 0; i < 3; ++i) { processes[i] = new Subprocess; - EXPECT_TRUE(processes[i]->Start(NULL, kCommands[i])); - subprocs.Add(processes[i]); + EXPECT_TRUE(processes[i]->Start(&subprocs_, kCommands[i])); + subprocs_.Add(processes[i]); } - ASSERT_EQ(3u, subprocs.running_.size()); + ASSERT_EQ(3u, subprocs_.running_.size()); for (int i = 0; i < 3; ++i) { ASSERT_FALSE(processes[i]->Done()); ASSERT_EQ("", processes[i]->GetOutput()); @@ -76,12 +99,12 @@ TEST(SubprocessSet, Multi) { while (!processes[0]->Done() || !processes[1]->Done() || !processes[2]->Done()) { - ASSERT_GT(subprocs.running_.size(), 0u); - subprocs.DoWork(); + ASSERT_GT(subprocs_.running_.size(), 0u); + subprocs_.DoWork(); } - ASSERT_EQ(0u, subprocs.running_.size()); - ASSERT_EQ(3u, subprocs.finished_.size()); + ASSERT_EQ(0u, subprocs_.running_.size()); + ASSERT_EQ(3u, subprocs_.finished_.size()); for (int i = 0; i < 3; ++i) { ASSERT_TRUE(processes[i]->Finish()); |