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

Unified Diff: runtime/vm/service_test.cc

Issue 145323002: Post-meetup feature extravaganza. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 6 years, 11 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 | « runtime/vm/service/running_isolates.dart ('k') | runtime/vm/timer.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/vm/service_test.cc
===================================================================
--- runtime/vm/service_test.cc (revision 32126)
+++ runtime/vm/service_test.cc (working copy)
@@ -88,6 +88,103 @@
}
+TEST_CASE(Service_Isolate) {
+ const char* kScript =
+ "var port;\n" // Set to our mock port by C++.
+ "\n"
+ "main() {\n"
+ "}";
+
+ Isolate* isolate = Isolate::Current();
+ Dart_Handle lib = TestCase::LoadTestScript(kScript, NULL);
+ EXPECT_VALID(lib);
+
+ // Build a mock message handler and wrap it in a dart port.
+ ServiceTestMessageHandler handler;
+ Dart_Port port_id = PortMap::CreatePort(&handler);
+ Dart_Handle port =
+ Api::NewHandle(isolate, DartLibraryCalls::NewSendPort(port_id));
+ EXPECT_VALID(port);
+ EXPECT_VALID(Dart_SetField(lib, NewString("port"), port));
+
+ Instance& service_msg = Instance::Handle();
+
+ // Get the isolate summary.
+ service_msg = Eval(lib, "[port, [], [], []]");
+ Service::HandleIsolateMessage(isolate, service_msg);
+ handler.HandleNextMessage();
+
+ JSONReader reader(handler.msg());
+
+ const int kBufferSize = 128;
+ char buffer[kBufferSize];
+
+ // Check that the response string is somewhat sane.
+
+ // type
+ EXPECT(reader.Seek("type"));
+ EXPECT_EQ(reader.Type(), JSONReader::kString);
+ reader.GetDecodedValueChars(buffer, kBufferSize);
+ EXPECT_STREQ("Isolate", buffer);
+
+ // id
+ EXPECT(reader.Seek("id"));
+ EXPECT_EQ(reader.Type(), JSONReader::kString);
+ reader.GetDecodedValueChars(buffer, kBufferSize);
+ EXPECT_SUBSTRING("isolates/", buffer);
+
+ // heap
+ EXPECT(reader.Seek("heap"));
+ EXPECT_EQ(reader.Type(), JSONReader::kObject);
+
+ // timers
+ EXPECT(reader.Seek("timers"));
+ EXPECT_EQ(reader.Type(), JSONReader::kArray);
+}
+
+
+TEST_CASE(Service_StackTrace) {
+ // TODO(turnidge): Extend this test to cover a non-trivial stack trace.
+ const char* kScript =
+ "var port;\n" // Set to our mock port by C++.
+ "\n"
+ "main() {\n"
+ "}";
+
+ Isolate* isolate = Isolate::Current();
+ Dart_Handle lib = TestCase::LoadTestScript(kScript, NULL);
+ EXPECT_VALID(lib);
+
+ // Build a mock message handler and wrap it in a dart port.
+ ServiceTestMessageHandler handler;
+ Dart_Port port_id = PortMap::CreatePort(&handler);
+ Dart_Handle port =
+ Api::NewHandle(isolate, DartLibraryCalls::NewSendPort(port_id));
+ EXPECT_VALID(port);
+ EXPECT_VALID(Dart_SetField(lib, NewString("port"), port));
+
+ Instance& service_msg = Instance::Handle();
+
+ // Get the stacktrace.
+ service_msg = Eval(lib, "[port, ['stacktrace'], [], []]");
+ Service::HandleIsolateMessage(isolate, service_msg);
+ handler.HandleNextMessage();
+ EXPECT_STREQ(
+ "{\"type\":\"StackTrace\",\"members\":[]}",
+ handler.msg());
+
+ // Malformed request.
+ service_msg = Eval(lib, "[port, ['stacktrace', 'jamboree'], [], []]");
+ Service::HandleIsolateMessage(isolate, service_msg);
+ handler.HandleNextMessage();
+ EXPECT_STREQ(
+ "{\"type\":\"Error\",\"text\":\"Command too long\","
+ "\"message\":{\"arguments\":[\"stacktrace\",\"jamboree\"],"
+ "\"option_keys\":[],\"option_values\":[]}}",
+ handler.msg());
+}
+
+
TEST_CASE(Service_DebugBreakpoints) {
const char* kScript =
"var port;\n" // Set to our mock port by C++.
@@ -465,7 +562,7 @@
const char* kScript =
"var port;\n" // Set to our mock port by C++.
"\n"
- "main() {\n" // We set breakpoint here.
+ "main() {\n"
"}";
Isolate* isolate = Isolate::Current();
« no previous file with comments | « runtime/vm/service/running_isolates.dart ('k') | runtime/vm/timer.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698