main.dart 2.42 KB
Newer Older
Ian Hickson's avatar
Ian Hickson committed
1
// Copyright 2014 The Flutter Authors. All rights reserved.
2 3 4 5 6 7 8
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'dart:async';
import 'dart:convert';

import 'package:flutter/material.dart';
9
import 'package:flutter/scheduler.dart';
10 11 12 13
import 'package:flutter/services.dart';
import 'package:flutter_driver/driver_extension.dart';

import 'src/tests/controls_page.dart';
14
import 'src/tests/headings_page.dart';
15
import 'src/tests/popup_page.dart';
16
import 'src/tests/text_field_page.dart';
17 18

void main() {
19
  timeDilation = 0.05; // remove animations.
20 21 22 23 24 25 26 27
  enableFlutterDriverExtension(handler: dataHandler);
  runApp(const TestApp());
}

const MethodChannel kSemanticsChannel = MethodChannel('semantics');

Future<String> dataHandler(String message) async {
  if (message.contains('getSemanticsNode')) {
28
    final Completer<String> completer = Completer<String>();
29
    final int id = int.tryParse(message.split('#')[1]) ?? 0;
30
    Future<void> completeSemantics([Object _]) async {
31
      final dynamic result = await kSemanticsChannel.invokeMethod<dynamic>('getSemanticsNode', <String, dynamic>{
32 33 34 35 36 37 38 39 40
        'id': id,
      });
      completer.complete(json.encode(result));
    }
    if (SchedulerBinding.instance.hasScheduledFrame)
      SchedulerBinding.instance.addPostFrameCallback(completeSemantics);
    else
      completeSemantics();
    return completer.future;
41
  }
42
  throw UnimplementedError();
43 44
}

45
Map<String, WidgetBuilder> routes = <String, WidgetBuilder>{
46 47 48 49
  selectionControlsRoute : (BuildContext context) => const SelectionControlsPage(),
  popupControlsRoute : (BuildContext context) => const PopupControlsPage(),
  textFieldRoute : (BuildContext context) => const TextFieldPage(),
  headingsRoute: (BuildContext context) => const HeadingsPage(),
50
};
51 52

class TestApp extends StatelessWidget {
53
  const TestApp({Key key}) : super(key: key);
54 55 56

  @override
  Widget build(BuildContext context) {
57
    return MaterialApp(
58
      routes: routes,
59
      home: Builder(
60
        builder: (BuildContext context) {
61 62
          return Scaffold(
            body: ListView(
63
              children: routes.keys.map<Widget>((String value) {
64 65
                return MaterialButton(
                  child: Text(value),
66 67 68 69 70 71 72 73 74 75 76 77
                  onPressed: () {
                    Navigator.of(context).pushNamed(value);
                  },
                );
              }).toList(),
            ),
          );
        }
      ),
    );
  }
}