stack_trace_test.dart 1.76 KB
Newer Older
1 2 3 4
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

5 6
@TestOn('!chrome') // web has different stack traces

7
import 'package:flutter/foundation.dart';
8
import '../flutter_test_alternative.dart';
9 10

void main() {
11 12
  // TODO(ianh): These tests and the filtering mechanism should be revisited to
  // account for causal async stack traces. https://github.com/flutter/flutter/issues/8128
13
  test('FlutterError.defaultStackFilter', () {
14
    final List<String> filtered = FlutterError.defaultStackFilter(StackTrace.current.toString().trimRight().split('\n')).toList();
15
    expect(filtered.length, greaterThanOrEqualTo(4));
16
    expect(filtered[0], matches(r'^#0 +main\.<anonymous closure> \(.*stack_trace_test\.dart:[0-9]+:[0-9]+\)$'));
17
    expect(filtered[1], matches(r'^#1 +Declarer\.test\.<anonymous closure>.<anonymous closure>.<anonymous closure> \(package:test_api/.+:[0-9]+:[0-9]+\)$'));
18
    expect(filtered[2], equals('<asynchronous suspension>'));
19
    expect(filtered.last, matches(r'^\(elided [1-9][0-9]+ frames from package dart:async(, package dart:async-patch,)? and package stack_trace\)$'));
20 21 22
  });

  test('FlutterError.defaultStackFilter (async test body)', () async {
23
    final List<String> filtered = FlutterError.defaultStackFilter(StackTrace.current.toString().trimRight().split('\n')).toList();
24
    expect(filtered.length, greaterThanOrEqualTo(3));
25
    expect(filtered[0], matches(r'^#0 +main\.<anonymous closure> \(.*stack_trace_test\.dart:[0-9]+:[0-9]+\)$'));
26
    expect(filtered[1], equals('<asynchronous suspension>'));
27
    expect(filtered.last, matches(r'^\(elided [1-9][0-9]+ frames from package dart:async(, package dart:async-patch,)? and package stack_trace\)$'));
28 29
  });
}