mirror of
https://github.com/flutter/flutter.git
synced 2025-06-03 00:51:18 +00:00

* Adds support for `flutter test --wasm`. * The test compilation flow is a bit different now, so that it supports compilers other than DDC. Specifically, when we run a set of unit tests, we generate a "switchboard" main function that imports each unit test and runs the main function for a specific one based off of a value set by the JS bootstrapping code. This way, there is one compile step and the same compile output is invoked for each unit test file. * Also, removes all references to `dart:html` from flutter/flutter. * Adds CI steps for running the framework unit tests with dart2wasm+skwasm * These steps are marked as `bringup: true`, so we don't know what kind of failures they will result in. Any failures they have will not block the tree at all yet while we're still in `bringup: true`. Once this PR is merged, I plan on looking at any failures and either fixing them or disabling them so we can get these CI steps running on presubmit. This fixes https://github.com/flutter/flutter/issues/126692
75 lines
2.4 KiB
Dart
75 lines
2.4 KiB
Dart
// Copyright 2014 The Flutter Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// This code is copied from `package:web` which still needs its own
|
|
// documentation for public members. Since this is a shim that users should not
|
|
// use, we ignore this lint for this file.
|
|
// ignore_for_file: public_member_api_docs
|
|
|
|
/// A stripped down version of `package:web` to avoid pinning that repo in
|
|
/// Flutter as a dependency.
|
|
///
|
|
/// These are manually copied over from `package:web` as needed, and should stay
|
|
/// in sync with the latest package version as much as possible.
|
|
///
|
|
/// If missing members are needed, copy them over into the corresponding
|
|
/// extension or interface. If missing interfaces/types are needed, copy them
|
|
/// over while excluding unnecessary inheritance to make the copy minimal. These
|
|
/// types are erased at runtime, so excluding supertypes is safe. If a member is
|
|
/// needed that belongs to a supertype, then add the necessary `implements`
|
|
/// clause to the subtype when you add that supertype. Keep extensions next to
|
|
/// the interface they extend.
|
|
library;
|
|
|
|
import 'dart:js_interop';
|
|
|
|
@JS()
|
|
external Window get window;
|
|
|
|
extension type Window._(JSObject _) implements JSObject {
|
|
external JSPromise<Response> fetch(
|
|
JSAny input, [
|
|
RequestInit init,
|
|
]);
|
|
external Location get location;
|
|
external Window? get parent;
|
|
external void postMessage(JSAny message, JSString targetOrigin, JSArray<JSAny> transfers);
|
|
|
|
external JSString? get testSelector;
|
|
}
|
|
|
|
extension type Response._(JSObject _) implements JSObject {
|
|
external JSPromise<JSString> text();
|
|
}
|
|
|
|
extension type RequestInit._(JSObject _) implements JSObject {
|
|
external factory RequestInit({
|
|
String method,
|
|
JSAny? body,
|
|
});
|
|
}
|
|
|
|
extension type Location._(JSObject _) implements JSObject {
|
|
external JSString get origin;
|
|
}
|
|
|
|
extension type MessageChannel._(JSObject _) implements JSObject {
|
|
external factory MessageChannel();
|
|
|
|
external MessagePort port1;
|
|
external MessagePort port2;
|
|
}
|
|
|
|
extension type MessagePort._(JSObject _) implements JSObject {
|
|
external void addEventListener(JSString eventName, JSFunction callback);
|
|
external void removeEventListener(JSString eventName, JSFunction callback);
|
|
external void postMessage(JSAny? message);
|
|
|
|
external void start();
|
|
}
|
|
|
|
extension type Event._(JSObject _) implements JSObject {
|
|
external JSObject? get data;
|
|
}
|