iosWebViewFix/example/integration_test/in_app_webview/inject_css.dart

127 lines
4.0 KiB
Dart
Raw Normal View History

part of 'main.dart';
2022-04-28 21:23:38 +00:00
void injectCSS() {
2022-04-29 11:39:28 +00:00
final shouldSkip = kIsWeb
? false
: ![
TargetPlatform.android,
TargetPlatform.iOS,
TargetPlatform.macOS,
].contains(defaultTargetPlatform);
2022-04-28 21:23:38 +00:00
var url = !kIsWeb ? TEST_URL_ABOUT_BLANK : TEST_WEB_PLATFORM_URL_1;
skippableGroup('inject CSS', () {
skippableTestWidgets('code', (WidgetTester tester) async {
final Completer<PlatformInAppWebViewController> controllerCompleter =
Completer<PlatformInAppWebViewController>();
2022-04-28 21:23:38 +00:00
final Completer<void> pageLoaded = Completer<void>();
await tester.pumpWidget(
Directionality(
textDirection: TextDirection.ltr,
child: InAppWebView(
key: GlobalKey(),
initialUrlRequest: URLRequest(url: url),
onWebViewCreated: (controller) {
controllerCompleter.complete(controller);
},
onLoadStop: (controller, url) {
pageLoaded.complete();
},
),
),
);
final PlatformInAppWebViewController controller =
2022-04-29 11:39:28 +00:00
await controllerCompleter.future;
2022-04-28 21:23:38 +00:00
await pageLoaded.future;
await controller.injectCSSCode(source: """
body {
background-color: rgb(0, 0, 255);
}
""");
String? backgroundColor = await controller.evaluateJavascript(source: """
var element = document.body;
var style = getComputedStyle(element);
style.backgroundColor;
""");
expect(backgroundColor, 'rgb(0, 0, 255)');
});
skippableTestWidgets('file from url', (WidgetTester tester) async {
final Completer<PlatformInAppWebViewController> controllerCompleter =
Completer<PlatformInAppWebViewController>();
2022-04-28 21:23:38 +00:00
final Completer<void> pageLoaded = Completer<void>();
await tester.pumpWidget(
Directionality(
textDirection: TextDirection.ltr,
child: InAppWebView(
key: GlobalKey(),
initialUrlRequest: URLRequest(url: url),
onWebViewCreated: (controller) {
controllerCompleter.complete(controller);
},
onLoadStop: (controller, url) {
pageLoaded.complete();
},
),
),
);
final PlatformInAppWebViewController controller =
2022-04-29 11:39:28 +00:00
await controllerCompleter.future;
2022-04-28 21:23:38 +00:00
await pageLoaded.future;
await controller.injectCSSFileFromUrl(
urlFile: WebUri(
2022-04-28 21:23:38 +00:00
'https://getbootstrap.com/docs/4.3/dist/css/bootstrap.min.css'),
cssLinkHtmlTagAttributes: CSSLinkHtmlTagAttributes(id: 'bootstrap'));
await Future.delayed(Duration(seconds: 2));
expect(
await controller.evaluateJavascript(
source: "document.head.querySelector('#bootstrap') == null;"),
false);
});
skippableTestWidgets('file from asset', (WidgetTester tester) async {
final Completer<PlatformInAppWebViewController> controllerCompleter =
Completer<PlatformInAppWebViewController>();
2022-04-28 21:23:38 +00:00
final Completer<void> pageLoaded = Completer<void>();
await tester.pumpWidget(
Directionality(
textDirection: TextDirection.ltr,
child: InAppWebView(
key: GlobalKey(),
initialUrlRequest: URLRequest(url: url),
onWebViewCreated: (controller) {
controllerCompleter.complete(controller);
},
onLoadStop: (controller, url) {
pageLoaded.complete();
},
),
),
);
final PlatformInAppWebViewController controller =
2022-04-29 11:39:28 +00:00
await controllerCompleter.future;
2022-04-28 21:23:38 +00:00
await pageLoaded.future;
await controller.injectCSSFileFromAsset(
assetFilePath: 'test_assets/css/blue-body.css');
String? backgroundColor = await controller.evaluateJavascript(source: """
var element = document.body;
var style = getComputedStyle(element);
style.backgroundColor;
""");
expect(backgroundColor, 'rgb(0, 0, 255)');
});
}, skip: shouldSkip);
}