main.dart 2.41 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 16
import 'src/tests/popup_constants.dart';
import 'src/tests/popup_page.dart';
17
import 'src/tests/text_field_page.dart';
18 19

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

const MethodChannel kSemanticsChannel = MethodChannel('semantics');

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

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

class TestApp extends StatelessWidget {
  const TestApp();

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