add tests for Process::isRunning

This commit is contained in:
Yuval Kashtan 2014-08-12 11:03:54 +03:00
parent af44951e77
commit 04116d6593
2 changed files with 31 additions and 0 deletions

View File

@ -92,6 +92,35 @@ void ProcessTest::testLaunchRedirectIn()
#endif // !defined(_WIN32_WCE) #endif // !defined(_WIN32_WCE)
} }
void ProcessTest::testIsRunning()
{
std::string name("TestApp");
std::string cmd;
#if defined(_DEBUG)
name += "d";
#endif
#if defined(POCO_OS_FAMILY_UNIX)
cmd = "./";
cmd += name;
#else
cmd = name;
#endif
std::vector<std::string> args;
args.push_back("-count");
Pipe inPipe;
ProcessHandle ph = Process::launch(cmd, args, &inPipe, 0, 0);
Process::PID id = ph.id();
assert (Process::isRunning(ph));
assert (Process::isRunning(id));
PipeOutputStream ostr(inPipe);
ostr << std::string(100, 'x');
ostr.close();
int rc = ph.wait();
assert (!Process::isRunning(ph));
assert (!Process::isRunning(id));
}
void ProcessTest::testLaunchRedirectOut() void ProcessTest::testLaunchRedirectOut()
{ {
@ -175,6 +204,7 @@ CppUnit::Test* ProcessTest::suite()
CppUnit_addTest(pSuite, ProcessTest, testLaunchRedirectIn); CppUnit_addTest(pSuite, ProcessTest, testLaunchRedirectIn);
CppUnit_addTest(pSuite, ProcessTest, testLaunchRedirectOut); CppUnit_addTest(pSuite, ProcessTest, testLaunchRedirectOut);
CppUnit_addTest(pSuite, ProcessTest, testLaunchEnv); CppUnit_addTest(pSuite, ProcessTest, testLaunchEnv);
CppUnit_addTest(pSuite, ProcessTest, testIsRunning);
return pSuite; return pSuite;
} }

View File

@ -30,6 +30,7 @@ public:
void testLaunchRedirectIn(); void testLaunchRedirectIn();
void testLaunchRedirectOut(); void testLaunchRedirectOut();
void testLaunchEnv(); void testLaunchEnv();
void testIsRunning();
void setUp(); void setUp();
void tearDown(); void tearDown();