blob: 01aefa9ede04bc85e8dd1f079ed2257a35f95700 [file] [log] [blame]
// Copyright 2013 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.
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:rfw/formats.dart' show parseLibraryFile;
import 'package:rfw/rfw.dart';
import 'utils.dart';
void main() {
testWidgets('Material widgets', (WidgetTester tester) async {
final Runtime runtime = Runtime()
..update(const LibraryName(<String>['core']), createCoreWidgets())
..update(
const LibraryName(<String>['material']), createMaterialWidgets());
final DynamicContent data = DynamicContent();
final List<String> eventLog = <String>[];
await tester.pumpWidget(
MaterialApp(
theme: ThemeData(useMaterial3: false),
home: RemoteWidget(
runtime: runtime,
data: data,
widget: const FullyQualifiedWidgetName(
LibraryName(<String>['test']), 'root'),
onEvent: (String eventName, DynamicMap eventArguments) {
eventLog.add('$eventName $eventArguments');
},
),
),
);
expect(tester.takeException().toString(),
contains('Could not find remote widget named'));
runtime.update(const LibraryName(<String>['test']), parseLibraryFile('''
import core;
import material;
widget root = Scaffold(
appBar: AppBar(
title: Text(text: 'Title'),
flexibleSpace: Placeholder(),
bottom: SizedBox(height: 56.0, child: Placeholder()),
),
drawer: Drawer(
child: ListView(
children: [
DrawerHeader(),
ListTile(
visualDensity: 'adaptivePlatformDensity',
title: Text(text: 'title'),
subtitle: Text(text: 'title'),
),
ListTile(
visualDensity: 'comfortable',
title: Text(text: 'title'),
subtitle: Text(text: 'title'),
),
ListTile(
visualDensity: 'compact',
title: Text(text: 'title'),
subtitle: Text(text: 'title'),
),
ListTile(
visualDensity: 'standard',
title: Text(text: 'title'),
subtitle: Text(text: 'title'),
),
ListTile(
visualDensity: { horizontal: -4.0, vertical: 4.0 },
title: Text(text: 'title'),
subtitle: Text(text: 'title'),
),
AboutListTile(),
],
),
),
body: ListView(
children: [
Card(
margin: [20.0],
child: ListBody(
children: [
ButtonBar(
children: [
ElevatedButton(
onPressed: event 'button' { },
child: Text(text: 'Elevated'),
),
OutlinedButton(
onPressed: event 'button' { },
child: Text(text: 'Outlined'),
),
TextButton(
onPressed: event 'button' { },
child: Text(text: 'Text'),
),
VerticalDivider(),
InkWell(
child: Text(text: 'Ink'),
),
],
),
],
),
),
Divider(),
Padding(
padding: [20.0],
child: Center(
child: CircularProgressIndicator(
value: 0.6,
),
),
),
Divider(),
Padding(
padding: [20.0],
child: Center(
child: LinearProgressIndicator(
value: 0.6,
),
),
),
],
),
floatingActionButton: FloatingActionButton(
onPressed: event 'fab' {},
child: Placeholder(),
),
);
'''));
await tester.pump();
await expectLater(
find.byType(RemoteWidget),
matchesGoldenFile('goldens/material_test.scaffold.png'),
skip: !runGoldens,
);
await tester.tapAt(const Offset(20.0, 20.0));
await tester.pump();
await tester.pump(const Duration(seconds: 1));
await expectLater(
find.byType(RemoteWidget),
matchesGoldenFile('goldens/material_test.drawer.png'),
skip: !runGoldens,
);
});
}