Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(130)

Unified Diff: remoting/base/breakpad_win_unittest.cc

Issue 10535082: /C++ readability/ - Make Chromoting Host report crashes to Breakpad (Windows only). The user must e… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fixing a bad merge. Created 8 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « remoting/base/breakpad_win.cc ('k') | remoting/host/breakpad.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/base/breakpad_win_unittest.cc
diff --git a/remoting/base/breakpad_win_unittest.cc b/remoting/base/breakpad_win_unittest.cc
index 859dba9d6a4c1ae99f83bd7a12d01dcebfb6095e..ea85280d29c749e42e217150353009e2e3c18585 100644
--- a/remoting/base/breakpad_win_unittest.cc
+++ b/remoting/base/breakpad_win_unittest.cc
@@ -3,12 +3,12 @@
// found in the LICENSE file.
#include <stdio.h>
+#include <string>
#include "base/compiler_specific.h"
#include "base/environment.h"
#include "base/logging.h"
#include "base/memory/scoped_ptr.h"
-#include "base/string16.h"
#include "base/stringprintf.h"
#include "base/utf_string_conversions.h"
#include "breakpad/src/client/windows/crash_generation/client_info.h"
@@ -16,8 +16,6 @@
#include "testing/gmock/include/gmock/gmock.h"
#include "testing/gtest/include/gtest/gtest.h"
-namespace remoting {
-
namespace {
// The name of the environment variable used to pass the crash server pipe name
@@ -31,8 +29,8 @@ const wchar_t kPipeNamePrefix[] = L"\\\\.\\pipe\\";
class MockCrashServerCallbacks {
public:
- MockCrashServerCallbacks() {}
- virtual ~MockCrashServerCallbacks() {}
+ MockCrashServerCallbacks();
+ virtual ~MockCrashServerCallbacks();
// |google_breakpad::CrashGenerationServer| invokes callbacks from artitrary
// thread pool threads. |OnClientDumpRequested| is the only one that happened
@@ -45,75 +43,108 @@ class MockCrashServerCallbacks {
static void OnClientDumpRequestCallback(
void* context,
const google_breakpad::ClientInfo* client_info,
- const string16* file_path) {
- reinterpret_cast<MockCrashServerCallbacks*>(context)->
- OnClientDumpRequested();
- }
+ const std::wstring* file_path);
};
+MockCrashServerCallbacks::MockCrashServerCallbacks() {
+}
+
+MockCrashServerCallbacks::~MockCrashServerCallbacks() {
+}
+
+// static
+void MockCrashServerCallbacks::OnClientDumpRequestCallback(
+ void* context,
+ const google_breakpad::ClientInfo* /* client_info */,
+ const std::wstring* /* file_path */) {
+ reinterpret_cast<MockCrashServerCallbacks*>(context)->OnClientDumpRequested();
+}
+
} // namespace
-void InitializeCrashReportingForTest(const wchar_t*);
+namespace remoting {
+
+void InitializeCrashReportingForTest(const wchar_t* pipe_name);
class BreakpadWinDeathTest : public testing::Test {
public:
- BreakpadWinDeathTest() {}
- virtual void SetUp() OVERRIDE {
- scoped_ptr<base::Environment> environment(base::Environment::Create());
- std::string pipe_name;
- if (environment->GetVar(kPipeVariableName, &pipe_name)) {
- // This is a child process. Initialize crash dump reporting to the crash
- // dump server.
- pipe_name_ = UTF8ToUTF16(pipe_name);
- ::remoting::InitializeCrashReportingForTest(pipe_name_.c_str());
- } else {
- // This is the parent process. Generate a unique pipe name and setup
- // a dummy crash dump server.
- UUID guid = {0};
- RPC_STATUS status = ::UuidCreate(&guid);
- EXPECT_TRUE(status == RPC_S_OK || status == RPC_S_UUID_LOCAL_ONLY);
-
- pipe_name_ = kPipeNamePrefix +
- base::StringPrintf(
- L"%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
- guid.Data1, guid.Data2, guid.Data3,
- guid.Data4[0], guid.Data4[1], guid.Data4[2],
- guid.Data4[3], guid.Data4[4], guid.Data4[5],
- guid.Data4[6], guid.Data4[7]);
- bool result = environment->SetVar(kPipeVariableName,
- UTF16ToUTF8(pipe_name_));
- EXPECT_TRUE(result);
-
- // Setup a dummy crash dump server.
- callbacks_.reset(new MockCrashServerCallbacks());
- crash_server_.reset(
- new google_breakpad::CrashGenerationServer(
- pipe_name_, NULL,
- NULL, NULL,
- MockCrashServerCallbacks::OnClientDumpRequestCallback,
- callbacks_.get(),
- NULL, NULL,
- NULL, NULL,
- false, NULL));
-
- result = crash_server_->Start();
- ASSERT_TRUE(result);
- }
- }
+ BreakpadWinDeathTest();
+ virtual ~BreakpadWinDeathTest();
+
+ virtual void SetUp() OVERRIDE;
protected:
scoped_ptr<google_breakpad::CrashGenerationServer> crash_server_;
scoped_ptr<MockCrashServerCallbacks> callbacks_;
- string16 pipe_name_;
+ std::wstring pipe_name_;
};
+BreakpadWinDeathTest::BreakpadWinDeathTest() {
+}
+
+BreakpadWinDeathTest::~BreakpadWinDeathTest() {
+}
+
+void BreakpadWinDeathTest::SetUp() {
+ scoped_ptr<base::Environment> environment(base::Environment::Create());
+ std::string pipe_name;
+ if (environment->GetVar(kPipeVariableName, &pipe_name)) {
+ // This is a child process. Initialize crash dump reporting to the crash
+ // dump server.
+ pipe_name_ = UTF8ToWide(pipe_name);
+ InitializeCrashReportingForTest(pipe_name_.c_str());
+ } else {
+ // This is the parent process. Generate a unique pipe name and setup
+ // a dummy crash dump server.
+ UUID guid = {0};
+ RPC_STATUS status = UuidCreate(&guid);
+ EXPECT_TRUE(status == RPC_S_OK || status == RPC_S_UUID_LOCAL_ONLY);
+
+ pipe_name_ =
+ base::StringPrintf(
+ L"%ls%08x-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x",
+ kPipeNamePrefix,
+ guid.Data1,
+ guid.Data2,
+ guid.Data3,
+ guid.Data4[0],
+ guid.Data4[1],
+ guid.Data4[2],
+ guid.Data4[3],
+ guid.Data4[4],
+ guid.Data4[5],
+ guid.Data4[6],
+ guid.Data4[7]);
+ EXPECT_TRUE(environment->SetVar(kPipeVariableName,
+ WideToUTF8(pipe_name_)));
+
+ // Setup a dummy crash dump server.
+ callbacks_.reset(new MockCrashServerCallbacks());
+ crash_server_.reset(
+ new google_breakpad::CrashGenerationServer(
+ pipe_name_,
+ NULL,
+ NULL,
+ NULL,
+ MockCrashServerCallbacks::OnClientDumpRequestCallback,
+ callbacks_.get(),
+ NULL,
+ NULL,
+ NULL,
+ NULL,
+ false,
+ NULL));
+ ASSERT_TRUE(crash_server_->Start());
+ }
+}
+
TEST_F(BreakpadWinDeathTest, TestAccessViolation) {
if (callbacks_.get()) {
EXPECT_CALL(*callbacks_, OnClientDumpRequested());
}
// Generate access violation exception.
- ASSERT_DEATH(*reinterpret_cast<int*>(0) = 1, "");
+ ASSERT_DEATH(*reinterpret_cast<int*>(NULL) = 1, "");
}
TEST_F(BreakpadWinDeathTest, TestInvalidParameter) {
@@ -122,7 +153,7 @@ TEST_F(BreakpadWinDeathTest, TestInvalidParameter) {
}
// Cause the invalid parameter callback to be called.
- ASSERT_EXIT(printf(NULL), ::testing::ExitedWithCode(0), "");
+ ASSERT_EXIT(printf(NULL), testing::ExitedWithCode(0), "");
}
TEST_F(BreakpadWinDeathTest, TestDebugbreak) {
« no previous file with comments | « remoting/base/breakpad_win.cc ('k') | remoting/host/breakpad.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698