Skip to content

Commit

Permalink
Remove use of the blobs snapshot format from unittests (flutter#12563)
Browse files Browse the repository at this point in the history
* Remove uses of the "blobs" snapshot format in Engine tests.

* Comments

* Rebasing against updated ELF loader API.
  • Loading branch information
sjindel-google authored Oct 10, 2019
1 parent d25a623 commit d908002
Show file tree
Hide file tree
Showing 5 changed files with 43 additions and 25 deletions.
1 change: 1 addition & 0 deletions shell/platform/embedder/BUILD.gn
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ if (current_toolchain == host_toolchain) {
"$flutter_root/testing:skia",
"//third_party/skia",
"//third_party/tonic",
"//third_party/dart/runtime/bin:elf_loader",
]
}
}
Expand Down
40 changes: 31 additions & 9 deletions shell/platform/embedder/tests/embedder_test_context.cc
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@

#include "flutter/runtime/dart_vm.h"
#include "flutter/shell/platform/embedder/tests/embedder_assertions.h"
#include "third_party/dart/runtime/bin/elf_loader.h"
#include "third_party/skia/include/core/SkSurface.h"

namespace flutter {
Expand All @@ -16,16 +17,33 @@ EmbedderTestContext::EmbedderTestContext(std::string assets_path)
native_resolver_(std::make_shared<TestDartNativeResolver>()) {
auto assets_dir = fml::OpenDirectory(assets_path_.c_str(), false,
fml::FilePermission::kRead);
vm_snapshot_data_ =
fml::FileMapping::CreateReadOnly(assets_dir, "vm_snapshot_data");
isolate_snapshot_data_ =
fml::FileMapping::CreateReadOnly(assets_dir, "isolate_snapshot_data");

if (flutter::DartVM::IsRunningPrecompiledCode()) {
vm_snapshot_instructions_ =
fml::FileMapping::CreateReadExecute(assets_dir, "vm_snapshot_instr");
isolate_snapshot_instructions_ = fml::FileMapping::CreateReadExecute(
assets_dir, "isolate_snapshot_instr");
std::string filename(assets_path_);
filename += "/app_elf_snapshot.so";

const uint8_t *vm_snapshot_data = nullptr,
*vm_snapshot_instructions = nullptr,
*isolate_snapshot_data = nullptr,
*isolate_snapshot_instructions = nullptr;
const char* error = nullptr;

elf_library_handle_ =
Dart_LoadELF(filename.c_str(), /*file_offset=*/0, &error,
&vm_snapshot_data, &vm_snapshot_instructions,
&isolate_snapshot_data, &isolate_snapshot_instructions);

if (elf_library_handle_ != nullptr) {
vm_snapshot_data_.reset(new fml::NonOwnedMapping(vm_snapshot_data, 0));
vm_snapshot_instructions_.reset(
new fml::NonOwnedMapping(vm_snapshot_instructions, 0));
isolate_snapshot_data_.reset(
new fml::NonOwnedMapping(isolate_snapshot_data, 0));
isolate_snapshot_instructions_.reset(
new fml::NonOwnedMapping(isolate_snapshot_instructions, 0));
} else {
FML_LOG(WARNING) << "Could not load snapshot: " << error;
}
}

isolate_create_callbacks_.push_back(
Expand All @@ -37,7 +55,11 @@ EmbedderTestContext::EmbedderTestContext(std::string assets_path)
});
}

EmbedderTestContext::~EmbedderTestContext() = default;
EmbedderTestContext::~EmbedderTestContext() {
if (elf_library_handle_ != nullptr) {
Dart_UnloadELF(elf_library_handle_);
}
}

const std::string& EmbedderTestContext::GetAssetsPath() const {
return assets_path_;
Expand Down
5 changes: 5 additions & 0 deletions shell/platform/embedder/tests/embedder_test_context.h
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
#include "flutter/shell/platform/embedder/tests/embedder_test_compositor.h"
#include "flutter/testing/test_dart_native_resolver.h"
#include "flutter/testing/test_gl_surface.h"
#include "third_party/dart/runtime/bin/elf_loader.h"
#include "third_party/skia/include/core/SkImage.h"

namespace flutter {
Expand Down Expand Up @@ -70,10 +71,14 @@ class EmbedderTestContext {
friend class EmbedderConfigBuilder;

std::string assets_path_;

// Pieces of the Dart snapshot in ELF form, loaded by Dart's ELF library.
Dart_LoadedElf* elf_library_handle_ = nullptr;
std::unique_ptr<fml::Mapping> vm_snapshot_data_;
std::unique_ptr<fml::Mapping> vm_snapshot_instructions_;
std::unique_ptr<fml::Mapping> isolate_snapshot_data_;
std::unique_ptr<fml::Mapping> isolate_snapshot_instructions_;

std::vector<fml::closure> isolate_create_callbacks_;
std::shared_ptr<TestDartNativeResolver> native_resolver_;
SemanticsNodeCallback update_semantics_node_callback_;
Expand Down
20 changes: 5 additions & 15 deletions testing/testing.gni
Original file line number Diff line number Diff line change
Expand Up @@ -125,26 +125,16 @@ template("dart_snapshot_aot") {
invoker.dart_kernel,
]

vm_snapshot_data = "$target_gen_dir/assets/vm_snapshot_data"
vm_snapshot_instr = "$target_gen_dir/assets/vm_snapshot_instr"
isolate_snapshot_data = "$target_gen_dir/assets/isolate_snapshot_data"
isolate_snapshot_instr = "$target_gen_dir/assets/isolate_snapshot_instr"
# Custom ELF loader is used for Mac and Windows.
elf_object = "$target_gen_dir/assets/app_elf_snapshot.so"

outputs = [
vm_snapshot_data,
vm_snapshot_instr,
isolate_snapshot_data,
isolate_snapshot_instr,
]
outputs = [elf_object]

args = [
"--causal_async_stacks",
"--deterministic",
"--snapshot_kind=app-aot-blobs",
"--vm_snapshot_data=" + rebase_path(vm_snapshot_data),
"--vm_snapshot_instructions=" + rebase_path(vm_snapshot_instr),
"--isolate_snapshot_data=" + rebase_path(isolate_snapshot_data),
"--isolate_snapshot_instructions=" + rebase_path(isolate_snapshot_instr),
"--snapshot_kind=app-aot-elf",
"--elf=" + rebase_path(elf_object),
rebase_path(invoker.dart_kernel),
]

Expand Down
2 changes: 1 addition & 1 deletion tools/gn
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,7 @@ def parse_args(args):

parser.add_argument('--runtime-mode', type=str, choices=['debug', 'profile', 'release', 'jit_release'], default='debug')
parser.add_argument('--interpreter', default=False, action='store_true')
parser.add_argument('--dart-debug', default=False, action='store_true', help='Enables assertsion in the Dart VM. ' +
parser.add_argument('--dart-debug', default=False, action='store_true', help='Enables assertions in the Dart VM. ' +
'Does not affect optimization levels. If you need to disable optimizations in Dart, use --full-dart-debug')
parser.add_argument('--full-dart-debug', default=False, action='store_true', help='Implies --dart-debug ' +
'and also disables optimizations in the Dart VM making it easier to step through VM code in the debugger.')
Expand Down

0 comments on commit d908002

Please sign in to comment.