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

Unified Diff: runtime/vm/debugger_api_impl_test.cc

Issue 9668036: Teach debugger to ignore breakpoints (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 8 years, 9 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
Index: runtime/vm/debugger_api_impl_test.cc
===================================================================
--- runtime/vm/debugger_api_impl_test.cc (revision 5243)
+++ runtime/vm/debugger_api_impl_test.cc (working copy)
@@ -33,6 +33,129 @@
}
+static char const* ToCString(Dart_Handle str) {
+ EXPECT(Dart_IsString(str));
+ char const* c_str = NULL;
+ Dart_StringToCString(str, &c_str);
+ return c_str;
+}
+
+
+static char const* BPFunctionName(Dart_StackTrace trace) {
+ Dart_ActivationFrame frame;
+ Dart_Handle res = Dart_GetActivationFrame(trace, 0, &frame);
+ EXPECT_NOT_ERROR(res);
+ Dart_Handle func_name;
+ res = Dart_ActivationFrameInfo(frame, &func_name, NULL, NULL);
+ EXPECT_NOT_ERROR(res);
+ return ToCString(func_name);
+}
+
+
+static char const* BreakpointInfo(Dart_StackTrace trace) {
+ static char info_str[128];
+ Dart_ActivationFrame frame;
+ Dart_Handle res = Dart_GetActivationFrame(trace, 0, &frame);
+ EXPECT_NOT_ERROR(res);
+ Dart_Handle func_name;
+ Dart_Handle url;
+ intptr_t line_number = 0;
+ res = Dart_ActivationFrameInfo(frame, &func_name, &url, &line_number);
+ EXPECT_NOT_ERROR(res);
+ OS::SNPrint(info_str, sizeof(info_str), "function %s (%s:%d)",
+ ToCString(func_name), ToCString(url), line_number);
+ return info_str;
+}
+
+
+static void PrintValue(Dart_Handle value, bool expand);
+
+static void PrintObject(Dart_Handle obj, bool expand) {
+ Dart_Handle obj_class = Dart_GetObjClass(obj);
+ EXPECT_NOT_ERROR(obj_class);
+ EXPECT(!Dart_IsNull(obj_class));
+ Dart_Handle class_name = Dart_ToString(obj_class);
+ EXPECT_NOT_ERROR(class_name);
+ EXPECT(Dart_IsString(class_name));
+ char const* class_name_str;
+ Dart_StringToCString(class_name, &class_name_str);
+ Dart_Handle fields = Dart_GetInstanceFields(obj);
+ EXPECT_NOT_ERROR(fields);
+ EXPECT(Dart_IsList(fields));
+ intptr_t list_length = 0;
+ Dart_Handle retval = Dart_ListLength(fields, &list_length);
+ EXPECT_NOT_ERROR(retval);
+ OS::Print("object of type '%s'", class_name_str);
+ for (int i = 0; i + 1 < list_length; i += 2) {
+ Dart_Handle name_handle = Dart_ListGetAt(fields, i);
+ EXPECT_NOT_ERROR(name_handle);
+ EXPECT(Dart_IsString(name_handle));
+ Dart_Handle value_handle = Dart_ListGetAt(fields, i + 1);
+ OS::Print("\n field %s = ", ToCString(name_handle));
+ PrintValue(value_handle, false);
+ }
+}
+
+
+static void PrintValue(Dart_Handle value, bool expand) {
+ if (Dart_IsNull(value)) {
+ OS::Print("null");
+ } else if (Dart_IsString(value)) {
+ Dart_Handle str_value = Dart_ToString(value);
+ EXPECT_NOT_ERROR(str_value);
+ EXPECT(Dart_IsString(str_value));
+ OS::Print("\"%s\"", ToCString(str_value));
+ } else if (Dart_IsNumber(value) || Dart_IsBoolean(value)) {
+ Dart_Handle str_value = Dart_ToString(value);
+ EXPECT_NOT_ERROR(str_value);
+ EXPECT(Dart_IsString(str_value));
+ OS::Print("%s", ToCString(str_value));
+ } else {
+ PrintObject(value, expand);
+ }
+}
+
+
+static void PrintActivationFrame(Dart_ActivationFrame frame) {
+ Dart_Handle func_name;
+ Dart_Handle res;
+ res = Dart_ActivationFrameInfo(frame, &func_name, NULL, NULL);
+ EXPECT_NOT_ERROR(res);
+ EXPECT(Dart_IsString(func_name));
+ const char* func_name_chars;
+ Dart_StringToCString(func_name, &func_name_chars);
+ OS::Print(" function %s\n", func_name_chars);
+ Dart_Handle locals = Dart_GetLocalVariables(frame);
+ EXPECT_NOT_ERROR(locals);
+ intptr_t list_length = 0;
+ Dart_Handle ret = Dart_ListLength(locals, &list_length);
+ EXPECT_NOT_ERROR(ret);
+ for (int i = 0; i + 1 < list_length; i += 2) {
+ Dart_Handle name_handle = Dart_ListGetAt(locals, i);
+ EXPECT_NOT_ERROR(name_handle);
+ EXPECT(Dart_IsString(name_handle));
+ OS::Print(" local var %s = ", ToCString(name_handle));
+ Dart_Handle value_handle = Dart_ListGetAt(locals, i + 1);
+ EXPECT_NOT_ERROR(value_handle);
+ PrintValue(value_handle, true);
+ OS::Print("\n");
+ }
+}
+
+
+static void PrintStackTrace(Dart_StackTrace trace) {
+ intptr_t trace_len;
+ Dart_Handle res = Dart_StackTraceLength(trace, &trace_len);
+ EXPECT_NOT_ERROR(res);
+ for (int i = 0; i < trace_len; i++) {
+ Dart_ActivationFrame frame;
+ res = Dart_GetActivationFrame(trace, i, &frame);
+ EXPECT_NOT_ERROR(res);
+ PrintActivationFrame(frame);
+ }
+}
+
+
void TestBreakpointHandler(Dart_Breakpoint bpt, Dart_StackTrace trace) {
const char* expected_trace[] = {"A.foo", "main"};
const intptr_t expected_trace_length = 2;
@@ -53,7 +176,7 @@
const char* name_chars;
Dart_StringToCString(func_name, &name_chars);
EXPECT_STREQ(expected_trace[i], name_chars);
- if (verbose) printf(" >> %d: %s\n", i, name_chars);
+ if (verbose) OS::Print(" >> %d: %s\n", i, name_chars);
}
}
@@ -108,7 +231,7 @@
EXPECT_STREQ(expected_bpts[breakpoint_hit_counter], name_chars);
}
if (verbose) {
- printf(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
+ OS::Print(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
}
breakpoint_hit = true;
breakpoint_hit_counter++;
@@ -194,7 +317,7 @@
EXPECT_STREQ(expected_bpts[breakpoint_hit_counter], name_chars);
}
if (verbose) {
- printf(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
+ OS::Print(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
}
breakpoint_hit = true;
breakpoint_hit_counter++;
@@ -249,6 +372,54 @@
}
+void TestIgnoreBPHandler(Dart_Breakpoint bpt, Dart_StackTrace trace) {
+ if (verbose) {
+ OS::Print(">>> Breakpoint nr. %d in %s <<<\n",
+ breakpoint_hit_counter, BreakpointInfo(trace));
+ PrintStackTrace(trace);
siva 2012/03/10 00:11:40 This ensures that the ignore breakpoint feature is
hausner 2012/03/10 00:41:56 Added a static field to the sample and to the stac
+ }
+ breakpoint_hit = true;
+ breakpoint_hit_counter++;
+ Dart_SetStepInto();
siva 2012/03/10 00:11:40 Why is it necessary to single step after this?
hausner 2012/03/10 00:41:56 It's just the easiest way to make sure we get into
siva 2012/03/12 22:19:14 Not sure I understand what you mean by get into ev
hausner 2012/03/12 22:36:44 The relevant case that we test here happens when w
+}
+
+
+TEST_CASE(Debug_IgnoreBP) {
+ const char* kScriptChars =
+ "class B { \n"
+ " var i = 100; \n"
+ " var d = 3.14; \n"
+ " var s = 'Dr Seuss'; \n"
+ "} \n"
+ " \n"
+ "void main() { \n"
+ " var x = new B(); \n"
+ " return x.i + 1; \n"
+ "} \n";
+
+ Dart_Handle lib = TestCase::LoadTestScript(kScriptChars, NULL);
+ EXPECT(!Dart_IsError(lib));
+
+ Dart_SetBreakpointHandler(&TestIgnoreBPHandler);
+
+ Dart_Handle c_name = Dart_NewString("");
+ Dart_Handle f_name = Dart_NewString("main");
+ Dart_Breakpoint bpt;
+ Dart_Handle res = Dart_SetBreakpointAtEntry(lib, c_name, f_name, &bpt);
+ EXPECT_NOT_ERROR(res);
+
+ breakpoint_hit = false;
+ breakpoint_hit_counter = 0;
siva 2012/03/10 00:11:40 What is the significance of breakpoint_hit_counter
hausner 2012/03/10 00:41:56 It's just boilerplate that I copied from other tes
siva 2012/03/12 22:19:14 If you are retaining it then why not add the check
hausner 2012/03/12 22:36:44 This test hits many breakpoints (including the int
+ Dart_Handle retval = Invoke(lib, "main");
+ EXPECT(!Dart_IsError(retval));
+ EXPECT(Dart_IsInteger(retval));
+ int64_t int_value = 0;
+ Dart_IntegerToInt64(retval, &int_value);
+ EXPECT_EQ(101, int_value);
+ EXPECT(breakpoint_hit == true);
+}
+
+
void TestSingleStepHandler(Dart_Breakpoint bpt, Dart_StackTrace trace) {
const char* expected_bpts[] = {
"moo", "foo", "moo", "foo", "moo", "foo", "main"};
@@ -267,7 +438,7 @@
const char* name_chars;
Dart_StringToCString(func_name, &name_chars);
if (verbose) {
- printf(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
+ OS::Print(" >> bpt nr %d: %s\n", breakpoint_hit_counter, name_chars);
}
if (breakpoint_hit_counter < expected_bpts_length) {
EXPECT_STREQ(expected_bpts[breakpoint_hit_counter], name_chars);
@@ -331,7 +502,7 @@
const char* name_chars;
Dart_StringToCString(func_name, &name_chars);
EXPECT_STREQ(expected_trace[i], name_chars);
- if (verbose) printf(" >> %d: %s\n", i, name_chars);
+ if (verbose) OS::Print(" >> %d: %s\n", i, name_chars);
}
}
@@ -390,11 +561,11 @@
const char* name_chars;
Dart_StringToCString(func_name, &name_chars);
EXPECT_STREQ(expected_trace[i], name_chars);
- if (verbose) printf(" >> %d: %s\n", i, name_chars);
+ if (verbose) OS::Print(" >> %d: %s\n", i, name_chars);
}
// Remove the breakpoint after we've hit it twice
if (breakpoint_hit_counter == 2) {
- if (verbose) printf("uninstalling breakpoint\n");
+ if (verbose) OS::Print("uninstalling breakpoint\n");
Dart_Handle res = Dart_DeleteBreakpoint(bpt);
EXPECT_NOT_ERROR(res);
}
@@ -470,7 +641,7 @@
EXPECT_NOT_ERROR(retval);
int num_fields = list_length / 2;
EXPECT_EQ(kNumObjectFields, num_fields);
- printf("Object has %d fields:\n", num_fields);
+ OS::Print("Object has %d fields:\n", num_fields);
for (int i = 0; i + 1 < list_length; i += 2) {
Dart_Handle name_handle = Dart_ListGetAt(fields, i);
EXPECT_NOT_ERROR(name_handle);
@@ -484,7 +655,7 @@
EXPECT(Dart_IsString(value_handle));
char const* value;
Dart_StringToCString(value_handle, &value);
- printf(" %s: %s\n", name, value);
+ OS::Print(" %s: %s\n", name, value);
}
// Check that an integer value returns an empty list of fields.
@@ -610,7 +781,7 @@
EXPECT(Dart_IsString(lib_url));
char const* chars;
Dart_StringToCString(lib_url, &chars);
- printf("Lib %d: %s\n", i, chars);
+ OS::Print("Lib %d: %s\n", i, chars);
Dart_Handle scripts = Dart_GetScriptURLs(lib_url);
EXPECT(Dart_IsList(scripts));
@@ -621,7 +792,7 @@
Dart_Handle script_url = Dart_ListGetAt(scripts, i);
char const* chars;
Dart_StringToCString(script_url, &chars);
- printf(" script %d: '%s'\n", i + 1, chars);
+ OS::Print(" script %d: '%s'\n", i + 1, chars);
}
}
@@ -630,7 +801,7 @@
EXPECT(Dart_IsString(source));
char const* source_chars;
Dart_StringToCString(source, &source_chars);
- printf("\n=== source: ===\n%s", source_chars);
+ OS::Print("\n=== source: ===\n%s", source_chars);
EXPECT_STREQ(kScriptChars, source_chars);
}
« runtime/vm/debugger.cc ('K') | « runtime/vm/debugger.cc ('k') | runtime/vm/debugger_x64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698