Index: runtime/bin/run_vm_tests.cc |
diff --git a/runtime/bin/run_vm_tests.cc b/runtime/bin/run_vm_tests.cc |
index ed1e0969e6eef19406a84b0dfd86bf54922dd643..ddb8a4e37bb1846b32cc68cb8dade34fbce15b64 100644 |
--- a/runtime/bin/run_vm_tests.cc |
+++ b/runtime/bin/run_vm_tests.cc |
@@ -6,7 +6,9 @@ |
#include "bin/dartutils.h" |
#include "bin/file.h" |
+#include "bin/loader.h" |
#include "bin/platform.h" |
+#include "bin/snapshot_utils.h" |
#include "platform/assert.h" |
#include "vm/benchmark_test.h" |
#include "vm/dart.h" |
@@ -30,6 +32,7 @@ static const char* const kNone = "No Test or Benchmarks"; |
static const char* const kList = "List all Tests and Benchmarks"; |
static const char* const kAllBenchmarks = "All Benchmarks"; |
static const char* run_filter = kNone; |
+static const char* kernel_snapshot = NULL; |
static int run_matches = 0; |
@@ -75,12 +78,98 @@ void Benchmark::RunBenchmark() { |
static void PrintUsage() { |
OS::PrintErr( |
- "run_vm_tests [--list | --benchmarks | " |
- "<test name> | <benchmark name>]\n"); |
- OS::PrintErr("run_vm_tests [vm-flags ...] <test name>\n"); |
- OS::PrintErr("run_vm_tests [vm-flags ...] <benchmark name>\n"); |
+ "Usage: one of the following\n" |
+ " run_vm_tests --list\n" |
+ " run_vm_tests [--dfe=<snapshot file name>] --benchmarks\n" |
+ " run_vm_tests [--dfe=<snapshot file name>] [vm-flags ...] <test name>\n" |
+ " run_vm_tests [--dfe=<snapshot file name>] [vm-flags ...] <benchmark " |
+ "name>\n"); |
} |
+#define CHECK_RESULT(result) \ |
+ if (Dart_IsError(result)) { \ |
+ *error = strdup(Dart_GetError(result)); \ |
+ Dart_ExitScope(); \ |
+ Dart_ShutdownIsolate(); \ |
+ return NULL; \ |
+ } |
+ |
+ |
+static Dart_Isolate CreateIsolateAndSetup(const char* script_uri, |
+ const char* main, |
+ const char* package_root, |
+ const char* packages_config, |
+ Dart_IsolateFlags* flags, |
+ void* data, |
+ char** error) { |
+ ASSERT(script_uri != NULL); |
+ const bool is_service_isolate = |
+ strcmp(script_uri, DART_VM_SERVICE_ISOLATE_NAME) == 0; |
+ if (is_service_isolate) { |
+ // We don't need service isolate for VM tests. |
+ return NULL; |
+ } |
+ const bool is_kernel_isolate = |
+ strcmp(script_uri, DART_KERNEL_ISOLATE_NAME) == 0; |
+ if (!is_kernel_isolate) { |
+ *error = |
+ strdup("Spawning of only Kernel isolate is supported in run_vm_tests."); |
+ return NULL; |
+ } |
+ if (kernel_snapshot == NULL) { |
+ *error = |
+ strdup("Kernel snapshot location has to be specified via --dfe option"); |
+ return NULL; |
+ } |
+ script_uri = kernel_snapshot; |
+ |
+ bin::AppSnapshot* app_snapshot = |
+ bin::Snapshot::TryReadAppSnapshot(script_uri); |
+ if (app_snapshot == NULL) { |
+ *error = strdup("Failed to read kernel service app snapshot"); |
+ return NULL; |
+ } |
+ |
+ const uint8_t* isolate_snapshot_data = bin::core_isolate_snapshot_data; |
+ const uint8_t* isolate_snapshot_instructions = |
+ bin::core_isolate_snapshot_instructions; |
+ |
+ const uint8_t* ignore_vm_snapshot_data; |
+ const uint8_t* ignore_vm_snapshot_instructions; |
+ app_snapshot->SetBuffers( |
+ &ignore_vm_snapshot_data, &ignore_vm_snapshot_instructions, |
+ &isolate_snapshot_data, &isolate_snapshot_instructions); |
+ |
+ bin::IsolateData* isolate_data = new bin::IsolateData( |
+ script_uri, package_root, packages_config, NULL /* app_snapshot */); |
+ Dart_Isolate isolate = Dart_CreateIsolate( |
+ script_uri, main, isolate_snapshot_data, isolate_snapshot_instructions, |
+ flags, isolate_data, error); |
+ if (isolate == NULL) { |
+ *error = strdup("Failed to create isolate"); |
+ delete isolate_data; |
+ return NULL; |
+ } |
+ |
+ Dart_EnterScope(); |
+ |
+ bin::DartUtils::SetOriginalWorkingDirectory(); |
+ Dart_Handle result = bin::DartUtils::PrepareForScriptLoading( |
+ false /* is_service_isolate */, false /* trace_loading */); |
+ CHECK_RESULT(result); |
+ |
+ Dart_ExitScope(); |
+ Dart_ExitIsolate(); |
+ bool retval = Dart_IsolateMakeRunnable(isolate); |
+ if (!retval) { |
+ *error = strdup("Invalid isolate state - Unable to make it runnable"); |
+ Dart_EnterIsolate(isolate); |
+ Dart_ShutdownIsolate(); |
+ return NULL; |
+ } |
+ |
+ return isolate; |
+} |
static int Main(int argc, const char** argv) { |
// Flags being passed to the Dart VM. |
@@ -96,20 +185,36 @@ static int Main(int argc, const char** argv) { |
// Bad parameter count. |
PrintUsage(); |
return 1; |
- } else if (argc == 2) { |
- if (strcmp(argv[1], "--list") == 0) { |
- run_filter = kList; |
- // List all tests and benchmarks and exit without initializing the VM. |
- TestCaseBase::RunAll(); |
- Benchmark::RunAll(argv[0]); |
- TestCaseBase::RunAllRaw(); |
- fflush(stdout); |
- return 0; |
- } else if (strcmp(argv[1], "--benchmarks") == 0) { |
- run_filter = kAllBenchmarks; |
- } else { |
- run_filter = argv[1]; |
+ } |
+ |
+ if (argc == 2 && strcmp(argv[1], "--list") == 0) { |
+ run_filter = kList; |
+ // List all tests and benchmarks and exit without initializing the VM. |
+ TestCaseBase::RunAll(); |
+ Benchmark::RunAll(argv[0]); |
+ TestCaseBase::RunAllRaw(); |
+ fflush(stdout); |
+ return 0; |
+ } |
+ |
+ int arg_pos = 1; |
+ if (strstr(argv[arg_pos], "--dfe") == argv[arg_pos]) { |
+ const char* delim = strstr(argv[1], "="); |
+ if (delim == NULL || strlen(delim + 1) == 0) { |
+ OS::PrintErr("Invalid value for the option: %s\n", argv[1]); |
+ PrintUsage(); |
+ return 1; |
} |
+ kernel_snapshot = strdup(delim + 1); |
+ // VM needs '--use-dart-frontend' option, which we will insert in place |
+ // of '--dfe' option. |
+ argv[arg_pos] = strdup("--use-dart-frontend"); |
+ ++arg_pos; |
+ } |
+ |
+ if (arg_pos == argc - 1 && strcmp(argv[arg_pos], "--benchmarks") == 0) { |
+ // "--benchmarks" is the last argument. |
+ run_filter = kAllBenchmarks; |
} else { |
// Last argument is the test name, the rest are vm flags. |
run_filter = argv[argc - 1]; |
@@ -118,14 +223,18 @@ static int Main(int argc, const char** argv) { |
dart_argc = argc - 2; |
dart_argv = &argv[1]; |
} |
+ |
bool set_vm_flags_success = |
Flags::ProcessCommandLineFlags(dart_argc, dart_argv); |
ASSERT(set_vm_flags_success); |
const char* err_msg = Dart::InitOnce( |
- dart::bin::vm_snapshot_data, dart::bin::vm_snapshot_instructions, NULL, |
- NULL, NULL, NULL, dart::bin::DartUtils::OpenFile, |
- dart::bin::DartUtils::ReadFile, dart::bin::DartUtils::WriteFile, |
- dart::bin::DartUtils::CloseFile, NULL, NULL); |
+ dart::bin::vm_snapshot_data, dart::bin::vm_snapshot_instructions, |
+ CreateIsolateAndSetup /* create */, NULL /* shutdown */, |
+ NULL /* cleanup */, NULL /* thread_exit */, |
+ dart::bin::DartUtils::OpenFile, dart::bin::DartUtils::ReadFile, |
+ dart::bin::DartUtils::WriteFile, dart::bin::DartUtils::CloseFile, |
+ NULL /* entropy_source */, NULL /* get_service_assets */); |
+ |
ASSERT(err_msg == NULL); |
// Apply the filter to all registered tests. |
TestCaseBase::RunAll(); |