| Index: runtime/bin/run_vm_tests.cc
|
| diff --git a/runtime/bin/run_vm_tests.cc b/runtime/bin/run_vm_tests.cc
|
| index ddb8a4e37bb1846b32cc68cb8dade34fbce15b64..ed1e0969e6eef19406a84b0dfd86bf54922dd643 100644
|
| --- a/runtime/bin/run_vm_tests.cc
|
| +++ b/runtime/bin/run_vm_tests.cc
|
| @@ -6,9 +6,7 @@
|
|
|
| #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"
|
| @@ -32,7 +30,6 @@ 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;
|
|
|
| @@ -78,98 +75,12 @@ void Benchmark::RunBenchmark() {
|
|
|
| static void PrintUsage() {
|
| OS::PrintErr(
|
| - "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");
|
| + "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");
|
| }
|
|
|
| -#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.
|
| @@ -185,36 +96,20 @@ static int Main(int argc, const char** argv) {
|
| // Bad parameter count.
|
| PrintUsage();
|
| return 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;
|
| + } 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];
|
| }
|
| - 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];
|
| @@ -223,18 +118,14 @@ 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,
|
| - 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 */);
|
| -
|
| + 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);
|
| ASSERT(err_msg == NULL);
|
| // Apply the filter to all registered tests.
|
| TestCaseBase::RunAll();
|
|
|