1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
// 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 "base/command_line.h"
#include "base/environment.h"
#include "base/path_service.h"
#include "base/process/kill.h"
#include "base/process/launch.h"
#include "base/process/process.h"
#include "base/strings/string_number_conversions.h"
#include "chrome/common/chrome_paths.h"
#include "chrome/test/ppapi/ppapi_test.h"
#include "components/nacl/browser/nacl_browser.h"
#include "components/nacl/common/nacl_switches.h"
#include "content/public/test/test_utils.h"
class NaClGdbDebugStubTest : public PPAPINaClNewlibTest {
public:
NaClGdbDebugStubTest() {
}
void SetUpCommandLine(base::CommandLine* command_line) override;
void StartTestScript(base::Process* test_process,
const std::string& test_name,
int debug_stub_port);
void RunDebugStubTest(const std::string& nacl_module,
const std::string& test_name);
};
void NaClGdbDebugStubTest::SetUpCommandLine(base::CommandLine* command_line) {
PPAPINaClNewlibTest::SetUpCommandLine(command_line);
command_line->AppendSwitch(switches::kEnableNaClDebug);
}
void NaClGdbDebugStubTest::StartTestScript(base::Process* test_process,
const std::string& test_name,
int debug_stub_port) {
// We call python script to reuse GDB RSP protocol implementation.
base::CommandLine cmd(base::FilePath(FILE_PATH_LITERAL("python")));
base::FilePath script;
PathService::Get(chrome::DIR_TEST_DATA, &script);
script = script.AppendASCII("nacl/debug_stub_browser_tests.py");
cmd.AppendArgPath(script);
cmd.AppendArg(base::IntToString(debug_stub_port));
cmd.AppendArg(test_name);
LOG(INFO) << cmd.GetCommandLineString();
*test_process = base::LaunchProcess(cmd, base::LaunchOptions());
}
void NaClGdbDebugStubTest::RunDebugStubTest(const std::string& nacl_module,
const std::string& test_name) {
base::Process test_script;
scoped_ptr<base::Environment> env(base::Environment::Create());
nacl::NaClBrowser::GetInstance()->SetGdbDebugStubPortListener(
base::Bind(&NaClGdbDebugStubTest::StartTestScript,
base::Unretained(this), &test_script, test_name));
// Turn on debug stub logging.
env->SetVar("NACLVERBOSITY", "1");
RunTestViaHTTP(nacl_module);
env->UnSetVar("NACLVERBOSITY");
nacl::NaClBrowser::GetInstance()->ClearGdbDebugStubPortListener();
int exit_code;
test_script.WaitForExit(&exit_code);
EXPECT_EQ(0, exit_code);
}
// NaCl tests are disabled under ASAN because of qualification test.
#if defined(ADDRESS_SANITIZER)
# define MAYBE_Empty DISABLED_Empty
#else
# define MAYBE_Empty Empty
#endif
IN_PROC_BROWSER_TEST_F(NaClGdbDebugStubTest, MAYBE_Empty) {
RunDebugStubTest("Empty", "continue");
}
#if defined(ADDRESS_SANITIZER)
# define MAYBE_Breakpoint DISABLED_Breakpoint
#elif defined(OS_LINUX) && !defined(OS_CHROMEOS) && defined(ARCH_CPU_ARM_FAMILY)
// Timing out on ARM linux: http://crbug.com/238469
# define MAYBE_Breakpoint DISABLED_Breakpoint
#else
# define MAYBE_Breakpoint Breakpoint
#endif
IN_PROC_BROWSER_TEST_F(NaClGdbDebugStubTest, MAYBE_Breakpoint) {
RunDebugStubTest("Empty", "breakpoint");
}
|