Index: base/win/scoped_process_information_unittest.cc |
diff --git a/base/win/scoped_process_information_unittest.cc b/base/win/scoped_process_information_unittest.cc |
deleted file mode 100644 |
index 614504d414efa87b33bad5d78c17f715cbbe12da..0000000000000000000000000000000000000000 |
--- a/base/win/scoped_process_information_unittest.cc |
+++ /dev/null |
@@ -1,166 +0,0 @@ |
-// Copyright (c) 2012 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 <windows.h> |
- |
-#include <string> |
- |
-#include "base/command_line.h" |
-#include "base/process/kill.h" |
-#include "base/process/process.h" |
-#include "base/test/multiprocess_test.h" |
-#include "base/win/scoped_process_information.h" |
-#include "testing/multiprocess_func_list.h" |
- |
-namespace { |
- |
-const DWORD kProcessId = 4321; |
-const DWORD kThreadId = 1234; |
-const HANDLE kProcessHandle = reinterpret_cast<HANDLE>(7651); |
-const HANDLE kThreadHandle = reinterpret_cast<HANDLE>(1567); |
- |
-void MockCreateProcess(base::win::ScopedProcessInformation* process_info) { |
- PROCESS_INFORMATION process_information = {}; |
- process_information.dwProcessId = kProcessId; |
- process_information.dwThreadId = kThreadId; |
- process_information.hProcess = kProcessHandle; |
- process_information.hThread = kThreadHandle; |
- process_info->Set(process_information); |
-} |
- |
-} // namespace |
- |
-class ScopedProcessInformationTest : public base::MultiProcessTest { |
- protected: |
- void DoCreateProcess(const std::string& main_id, |
- PROCESS_INFORMATION* process_handle); |
-}; |
- |
-MULTIPROCESS_TEST_MAIN(ReturnSeven) { |
- return 7; |
-} |
- |
-MULTIPROCESS_TEST_MAIN(ReturnNine) { |
- return 9; |
-} |
- |
-void ScopedProcessInformationTest::DoCreateProcess( |
- const std::string& main_id, PROCESS_INFORMATION* process_handle) { |
- std::wstring cmd_line = MakeCmdLine(main_id).GetCommandLineString(); |
- STARTUPINFO startup_info = {}; |
- startup_info.cb = sizeof(startup_info); |
- |
- EXPECT_TRUE(::CreateProcess(NULL, &cmd_line[0], |
- NULL, NULL, false, 0, NULL, NULL, |
- &startup_info, process_handle)); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, InitiallyInvalid) { |
- base::win::ScopedProcessInformation process_info; |
- ASSERT_FALSE(process_info.IsValid()); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, Receive) { |
- base::win::ScopedProcessInformation process_info; |
- MockCreateProcess(&process_info); |
- |
- EXPECT_TRUE(process_info.IsValid()); |
- EXPECT_EQ(kProcessId, process_info.process_id()); |
- EXPECT_EQ(kThreadId, process_info.thread_id()); |
- EXPECT_EQ(kProcessHandle, process_info.process_handle()); |
- EXPECT_EQ(kThreadHandle, process_info.thread_handle()); |
- process_info.Take(); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, TakeProcess) { |
- base::win::ScopedProcessInformation process_info; |
- MockCreateProcess(&process_info); |
- |
- HANDLE process = process_info.TakeProcessHandle(); |
- EXPECT_EQ(kProcessHandle, process); |
- EXPECT_EQ(NULL, process_info.process_handle()); |
- EXPECT_EQ(0, process_info.process_id()); |
- EXPECT_TRUE(process_info.IsValid()); |
- process_info.Take(); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, TakeThread) { |
- base::win::ScopedProcessInformation process_info; |
- MockCreateProcess(&process_info); |
- |
- HANDLE thread = process_info.TakeThreadHandle(); |
- EXPECT_EQ(kThreadHandle, thread); |
- EXPECT_EQ(NULL, process_info.thread_handle()); |
- EXPECT_EQ(0, process_info.thread_id()); |
- EXPECT_TRUE(process_info.IsValid()); |
- process_info.Take(); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, TakeBoth) { |
- base::win::ScopedProcessInformation process_info; |
- MockCreateProcess(&process_info); |
- |
- process_info.TakeProcessHandle(); |
- process_info.TakeThreadHandle(); |
- EXPECT_FALSE(process_info.IsValid()); |
- process_info.Take(); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, TakeWholeStruct) { |
- base::win::ScopedProcessInformation process_info; |
- MockCreateProcess(&process_info); |
- |
- PROCESS_INFORMATION to_discard = process_info.Take(); |
- EXPECT_EQ(kProcessId, to_discard.dwProcessId); |
- EXPECT_EQ(kThreadId, to_discard.dwThreadId); |
- EXPECT_EQ(kProcessHandle, to_discard.hProcess); |
- EXPECT_EQ(kThreadHandle, to_discard.hThread); |
- EXPECT_FALSE(process_info.IsValid()); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, Duplicate) { |
- PROCESS_INFORMATION temp_process_information; |
- DoCreateProcess("ReturnSeven", &temp_process_information); |
- base::win::ScopedProcessInformation process_info; |
- process_info.Set(temp_process_information); |
- |
- base::win::ScopedProcessInformation duplicate; |
- duplicate.DuplicateFrom(process_info); |
- |
- ASSERT_TRUE(process_info.IsValid()); |
- ASSERT_NE(0u, process_info.process_id()); |
- ASSERT_EQ(duplicate.process_id(), process_info.process_id()); |
- ASSERT_NE(0u, process_info.thread_id()); |
- ASSERT_EQ(duplicate.thread_id(), process_info.thread_id()); |
- |
- // Validate that we have separate handles that are good. |
- int exit_code = 0; |
- base::Process process(process_info.TakeProcessHandle()); |
- ASSERT_TRUE(process.WaitForExit(&exit_code)); |
- ASSERT_EQ(7, exit_code); |
- |
- exit_code = 0; |
- base::Process dup_process(duplicate.TakeProcessHandle()); |
- ASSERT_TRUE(dup_process.WaitForExit(&exit_code)); |
- ASSERT_EQ(7, exit_code); |
- |
- ASSERT_TRUE(::CloseHandle(process_info.TakeThreadHandle())); |
- ASSERT_TRUE(::CloseHandle(duplicate.TakeThreadHandle())); |
-} |
- |
-TEST_F(ScopedProcessInformationTest, Set) { |
- base::win::ScopedProcessInformation base_process_info; |
- MockCreateProcess(&base_process_info); |
- |
- PROCESS_INFORMATION base_struct = base_process_info.Take(); |
- |
- base::win::ScopedProcessInformation process_info; |
- process_info.Set(base_struct); |
- |
- EXPECT_EQ(kProcessId, process_info.process_id()); |
- EXPECT_EQ(kThreadId, process_info.thread_id()); |
- EXPECT_EQ(kProcessHandle, process_info.process_handle()); |
- EXPECT_EQ(kThreadHandle, process_info.thread_handle()); |
- base_struct = process_info.Take(); |
-} |