diff options
author | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-22 02:21:45 +0000 |
---|---|---|
committer | thestig@chromium.org <thestig@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-07-22 02:21:45 +0000 |
commit | 603c389aba55c3a03729b15242c738b665d91b3e (patch) | |
tree | 48d7382bd8c6e6743fa5653f0b8aab9500dd9821 /chrome/common/process_watcher_unittest.cc | |
parent | 66a473cde2368c63baa1e1e5d76431b57684aca9 (diff) | |
download | chromium_src-603c389aba55c3a03729b15242c738b665d91b3e.zip chromium_src-603c389aba55c3a03729b15242c738b665d91b3e.tar.gz chromium_src-603c389aba55c3a03729b15242c738b665d91b3e.tar.bz2 |
Add a unit test for ProcessWatcher::EnsureProcessTerminated().
Review URL: http://codereview.chromium.org/155799
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@21259 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/process_watcher_unittest.cc')
-rw-r--r-- | chrome/common/process_watcher_unittest.cc | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/chrome/common/process_watcher_unittest.cc b/chrome/common/process_watcher_unittest.cc new file mode 100644 index 0000000..d794d60 --- /dev/null +++ b/chrome/common/process_watcher_unittest.cc @@ -0,0 +1,58 @@ +// Copyright (c) 2009 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "base/platform_thread.h" +#include "base/multiprocess_test.h" +#include "chrome/common/process_watcher.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace { + +class ProcessWatcherTest : public MultiProcessTest { +}; + +MULTIPROCESS_TEST_MAIN(Sleep1ChildProcess) { + PlatformThread::Sleep(1000); + exit(0); + return 0; +} + +MULTIPROCESS_TEST_MAIN(Sleep3ChildProcess) { + PlatformThread::Sleep(3000); + exit(0); + return 0; +} + +TEST_F(ProcessWatcherTest, DiesBeforeTermination) { + base::ProcessHandle handle = this->SpawnChild(L"Sleep1ChildProcess"); + ASSERT_NE(static_cast<base::ProcessHandle>(NULL), handle); + + ProcessWatcher::EnsureProcessTerminated(handle); + + PlatformThread::Sleep(2500); + // Normally we don't touch |handle| after calling EnsureProcessTerminated, + // but we know the EnsureProcessTerminated process finishes in 2000 ms, so + // it's safe to do so now. Same for Terminated test case below. + EXPECT_FALSE(base::CrashAwareSleep(handle, 0)); +} + +TEST_F(ProcessWatcherTest, Terminated) { + base::ProcessHandle handle = this->SpawnChild(L"Sleep3ChildProcess"); + ASSERT_NE(static_cast<base::ProcessHandle>(NULL), handle); + + ProcessWatcher::EnsureProcessTerminated(handle); + + PlatformThread::Sleep(2500); + EXPECT_FALSE(base::CrashAwareSleep(handle, 0)); +} + +TEST_F(ProcessWatcherTest, NotTerminated) { + base::ProcessHandle handle = this->SpawnChild(L"Sleep3ChildProcess"); + ASSERT_NE(static_cast<base::ProcessHandle>(NULL), handle); + + EXPECT_TRUE(base::CrashAwareSleep(handle, 2500)); + EXPECT_FALSE(base::CrashAwareSleep(handle, 1000)); +} + +} // namespace |