blob: 87880395e21a15544fe937cf1a630b7c428b2b8d [file] [log] [blame]
// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
// for details. 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:path/path.dart' as path;
import 'package:stack_trace/stack_trace.dart';
import 'package:test/test.dart';
void main() {
group('.parseVM', () {
test('parses a stack frame with column correctly', () {
var frame = Frame.parseVM('#1 Foo._bar '
'(file:///home/nweiz/code/stuff.dart:42:21)');
expect(
frame.uri, equals(Uri.parse('file:///home/nweiz/code/stuff.dart')));
expect(frame.line, equals(42));
expect(frame.column, equals(21));
expect(frame.member, equals('Foo._bar'));
});
test('parses a stack frame without column correctly', () {
var frame = Frame.parseVM('#1 Foo._bar '
'(file:///home/nweiz/code/stuff.dart:24)');
expect(
frame.uri, equals(Uri.parse('file:///home/nweiz/code/stuff.dart')));
expect(frame.line, equals(24));
expect(frame.column, null);
expect(frame.member, equals('Foo._bar'));
});
// This can happen with async stack traces. See issue 22009.
test('parses a stack frame without line or column correctly', () {
var frame = Frame.parseVM('#1 Foo._bar '
'(file:///home/nweiz/code/stuff.dart)');
expect(
frame.uri, equals(Uri.parse('file:///home/nweiz/code/stuff.dart')));
expect(frame.line, isNull);
expect(frame.column, isNull);
expect(frame.member, equals('Foo._bar'));
});
test('converts "<anonymous closure>" to "<fn>"', () {
String? parsedMember(String member) =>
Frame.parseVM('#0 $member (foo:0:0)').member;
expect(parsedMember('Foo.<anonymous closure>'), equals('Foo.<fn>'));
expect(parsedMember('<anonymous closure>.<anonymous closure>.bar'),
equals('<fn>.<fn>.bar'));
});
test('converts "<<anonymous closure>_async_body>" to "<async>"', () {
var frame =
Frame.parseVM('#0 Foo.<<anonymous closure>_async_body> (foo:0:0)');
expect(frame.member, equals('Foo.<async>'));
});
test('converts "<function_name_async_body>" to "<async>"', () {
var frame = Frame.parseVM('#0 Foo.<function_name_async_body> (foo:0:0)');
expect(frame.member, equals('Foo.<async>'));
});
test('parses a folded frame correctly', () {
var frame = Frame.parseVM('...');
expect(frame.member, equals('...'));
expect(frame.uri, equals(Uri()));
expect(frame.line, isNull);
expect(frame.column, isNull);
});
});
group('.parseV8', () {
test('returns an UnparsedFrame for malformed frames', () {
expectIsUnparsed((text) => Frame.parseV8(text), '');
expectIsUnparsed((text) => Frame.parseV8(text), '#1');
expectIsUnparsed((text) => Frame.parseV8(text), '#1 Foo');
expectIsUnparsed((text) => Frame.parseV8(text),
'#1 (dart:async/future.dart:10:15)');
expectIsUnparsed(
(text) => Frame.parseV8(text), 'Foo (dart:async/future.dart:10:15)');
});
test('parses a stack frame correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
'(https://example.com/stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a : in the authority', () {
var frame = Frame.parseV8(' at VW.call\$0 '
'(http://localhost:8080/stuff.dart.js:560:28)');
expect(
frame.uri, equals(Uri.parse('http://localhost:8080/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with an absolute POSIX path correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
'(/path/to/stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('file:///path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with an absolute Windows path correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
r'(C:\path\to\stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('file:///C:/path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a Windows UNC path correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
r'(\\mount\path\to\stuff.dart.js:560:28)');
expect(
frame.uri, equals(Uri.parse('file://mount/path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a relative POSIX path correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
'(path/to/stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a relative Windows path correctly', () {
var frame = Frame.parseV8(' at VW.call\$0 '
r'(path\to\stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses an anonymous stack frame correctly', () {
var frame =
Frame.parseV8(' at https://example.com/stuff.dart.js:560:28');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('<fn>'));
});
test('parses a native stack frame correctly', () {
var frame = Frame.parseV8(' at Object.stringify (native)');
expect(frame.uri, Uri.parse('native'));
expect(frame.line, isNull);
expect(frame.column, isNull);
expect(frame.member, equals('Object.stringify'));
});
test('parses a stack frame with [as ...] correctly', () {
// Ignore "[as ...]", since other stack trace formats don't support a
// similar construct.
var frame = Frame.parseV8(' at VW.call\$0 [as call\$4] '
'(https://example.com/stuff.dart.js:560:28)');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('VW.call\$0'));
});
test('parses a basic eval stack frame correctly', () {
var frame = Frame.parseV8(' at eval (eval at <anonymous> '
'(https://example.com/stuff.dart.js:560:28))');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('eval'));
});
test('parses an IE10 eval stack frame correctly', () {
var frame = Frame.parseV8(' at eval (eval at Anonymous function '
'(https://example.com/stuff.dart.js:560:28))');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('eval'));
});
test('parses an eval stack frame with inner position info correctly', () {
var frame = Frame.parseV8(' at eval (eval at <anonymous> '
'(https://example.com/stuff.dart.js:560:28), <anonymous>:3:28)');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('eval'));
});
test('parses a nested eval stack frame correctly', () {
var frame = Frame.parseV8(' at eval (eval at <anonymous> '
'(eval at sub (https://example.com/stuff.dart.js:560:28)))');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, equals(28));
expect(frame.member, equals('eval'));
});
test('converts "<anonymous>" to "<fn>"', () {
String? parsedMember(String member) =>
Frame.parseV8(' at $member (foo:0:0)').member;
expect(parsedMember('Foo.<anonymous>'), equals('Foo.<fn>'));
expect(
parsedMember('<anonymous>.<anonymous>.bar'), equals('<fn>.<fn>.bar'));
});
test('returns an UnparsedFrame for malformed frames', () {
expectIsUnparsed((text) => Frame.parseV8(text), '');
expectIsUnparsed((text) => Frame.parseV8(text), ' at');
expectIsUnparsed((text) => Frame.parseV8(text), ' at Foo');
expectIsUnparsed(
(text) => Frame.parseV8(text), ' at Foo (dart:async/future.dart)');
expectIsUnparsed((text) => Frame.parseV8(text),
' at (dart:async/future.dart:10:15)');
expectIsUnparsed(
(text) => Frame.parseV8(text), 'Foo (dart:async/future.dart:10:15)');
expectIsUnparsed(
(text) => Frame.parseV8(text), ' at dart:async/future.dart');
expectIsUnparsed(
(text) => Frame.parseV8(text), 'dart:async/future.dart:10:15');
});
});
group('.parseFirefox/.parseSafari', () {
test('parses a Firefox stack trace with anonymous function', () {
var trace = Trace.parse('''
Foo._bar@https://example.com/stuff.js:18056:12
anonymous/<@https://example.com/stuff.js line 693 > Function:3:40
baz@https://pub.dev/buz.js:56355:55
''');
expect(trace.frames[0].uri,
equals(Uri.parse('https://example.com/stuff.js')));
expect(trace.frames[0].line, equals(18056));
expect(trace.frames[0].column, equals(12));
expect(trace.frames[0].member, equals('Foo._bar'));
expect(trace.frames[1].uri,
equals(Uri.parse('https://example.com/stuff.js')));
expect(trace.frames[1].line, equals(693));
expect(trace.frames[1].column, isNull);
expect(trace.frames[1].member, equals('<fn>'));
expect(trace.frames[2].uri, equals(Uri.parse('https://pub.dev/buz.js')));
expect(trace.frames[2].line, equals(56355));
expect(trace.frames[2].column, equals(55));
expect(trace.frames[2].member, equals('baz'));
});
test('parses a Firefox stack trace with nested evals in anonymous function',
() {
var trace = Trace.parse('''
Foo._bar@https://example.com/stuff.js:18056:12
anonymous@file:///C:/example.html line 7 > eval line 1 > eval:1:1
anonymous@file:///C:/example.html line 45 > Function:1:1
''');
expect(trace.frames[0].uri,
equals(Uri.parse('https://example.com/stuff.js')));
expect(trace.frames[0].line, equals(18056));
expect(trace.frames[0].column, equals(12));
expect(trace.frames[0].member, equals('Foo._bar'));
expect(trace.frames[1].uri, equals(Uri.parse('file:///C:/example.html')));
expect(trace.frames[1].line, equals(7));
expect(trace.frames[1].column, isNull);
expect(trace.frames[1].member, equals('<fn>'));
expect(trace.frames[2].uri, equals(Uri.parse('file:///C:/example.html')));
expect(trace.frames[2].line, equals(45));
expect(trace.frames[2].column, isNull);
expect(trace.frames[2].member, equals('<fn>'));
});
test('parses a simple stack frame correctly', () {
var frame = Frame.parseFirefox(
'.VW.call\$0@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with an absolute POSIX path correctly', () {
var frame = Frame.parseFirefox('.VW.call\$0@/path/to/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('file:///path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with an absolute Windows path correctly', () {
var frame =
Frame.parseFirefox(r'.VW.call$0@C:\path\to\stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('file:///C:/path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a Windows UNC path correctly', () {
var frame =
Frame.parseFirefox(r'.VW.call$0@\\mount\path\to\stuff.dart.js:560');
expect(
frame.uri, equals(Uri.parse('file://mount/path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a relative POSIX path correctly', () {
var frame = Frame.parseFirefox('.VW.call\$0@path/to/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a stack frame with a relative Windows path correctly', () {
var frame = Frame.parseFirefox(r'.VW.call$0@path\to\stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('path/to/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('VW.call\$0'));
});
test('parses a simple anonymous stack frame correctly', () {
var frame = Frame.parseFirefox('@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('<fn>'));
});
test('parses a nested anonymous stack frame correctly', () {
var frame =
Frame.parseFirefox('.foo/<@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo.<fn>'));
frame = Frame.parseFirefox('.foo/@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo.<fn>'));
});
test('parses a named nested anonymous stack frame correctly', () {
var frame = Frame.parseFirefox(
'.foo/.name<@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo.<fn>'));
frame = Frame.parseFirefox(
'.foo/.name@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo.<fn>'));
});
test('parses a stack frame with parameters correctly', () {
var frame = Frame.parseFirefox(
'.foo(12, "@)()/<")@https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo'));
});
test('parses a nested anonymous stack frame with parameters correctly', () {
var frame = Frame.parseFirefox('.foo(12, "@)()/<")/.fn<@'
'https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('foo.<fn>'));
});
test(
'parses a deeply-nested anonymous stack frame with parameters '
'correctly', () {
var frame = Frame.parseFirefox('.convertDartClosureToJS/\$function</<@'
'https://example.com/stuff.dart.js:560');
expect(frame.uri, equals(Uri.parse('https://example.com/stuff.dart.js')));
expect(frame.line, equals(560));
expect(frame.column, isNull);
expect(frame.member, equals('convertDartClosureToJS.<fn>.<fn>'));
});
test('returns an UnparsedFrame for malformed frames', () {
expectIsUnparsed((text) => Frame.parseFirefox(text), '');
expectIsUnparsed((text) => Frame.parseFirefox(text), '.foo');
expectIsUnparsed(
(text) => Frame.parseFirefox(text), '.foo@dart:async/future.dart');
expectIsUnparsed((text) => Frame.parseFirefox(text),
'.foo(@dart:async/future.dart:10');
expectIsUnparsed(
(text) => Frame.parseFirefox(text), '@dart:async/future.dart');
});
test('parses a simple stack frame correctly', () {
var frame =
Frame.parseFirefox('foo\$bar@https://dart.dev/foo/bar.dart:10:11');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('foo\$bar'));
});
test('parses an anonymous stack frame correctly', () {
var frame = Frame.parseFirefox('https://dart.dev/foo/bar.dart:10:11');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('<fn>'));
});
test('parses a stack frame with no line correctly', () {
var frame =
Frame.parseFirefox('foo\$bar@https://dart.dev/foo/bar.dart::11');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, isNull);
expect(frame.column, equals(11));
expect(frame.member, equals('foo\$bar'));
});
test('parses a stack frame with no column correctly', () {
var frame =
Frame.parseFirefox('foo\$bar@https://dart.dev/foo/bar.dart:10:');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, isNull);
expect(frame.member, equals('foo\$bar'));
});
test('parses a stack frame with no line or column correctly', () {
var frame =
Frame.parseFirefox('foo\$bar@https://dart.dev/foo/bar.dart:10:11');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('foo\$bar'));
});
});
group('.parseFriendly', () {
test('parses a simple stack frame correctly', () {
var frame = Frame.parseFriendly(
'https://dart.dev/foo/bar.dart 10:11 Foo.<fn>.bar');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('Foo.<fn>.bar'));
});
test('parses a stack frame with no line or column correctly', () {
var frame =
Frame.parseFriendly('https://dart.dev/foo/bar.dart Foo.<fn>.bar');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, isNull);
expect(frame.column, isNull);
expect(frame.member, equals('Foo.<fn>.bar'));
});
test('parses a stack frame with no column correctly', () {
var frame =
Frame.parseFriendly('https://dart.dev/foo/bar.dart 10 Foo.<fn>.bar');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, equals(10));
expect(frame.column, isNull);
expect(frame.member, equals('Foo.<fn>.bar'));
});
test('parses a stack frame with a relative path correctly', () {
var frame = Frame.parseFriendly('foo/bar.dart 10:11 Foo.<fn>.bar');
expect(frame.uri,
equals(path.toUri(path.absolute(path.join('foo', 'bar.dart')))));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('Foo.<fn>.bar'));
});
test('returns an UnparsedFrame for malformed frames', () {
expectIsUnparsed((text) => Frame.parseFriendly(text), '');
expectIsUnparsed((text) => Frame.parseFriendly(text), 'foo/bar.dart');
expectIsUnparsed(
(text) => Frame.parseFriendly(text), 'foo/bar.dart 10:11');
});
test('parses a data url stack frame with no line or column correctly', () {
var frame = Frame.parseFriendly('data:... main');
expect(frame.uri.scheme, equals('data'));
expect(frame.line, isNull);
expect(frame.column, isNull);
expect(frame.member, equals('main'));
});
test('parses a data url stack frame correctly', () {
var frame = Frame.parseFriendly('data:... 10:11 main');
expect(frame.uri.scheme, equals('data'));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('main'));
});
test('parses a stack frame with spaces in the member name correctly', () {
var frame = Frame.parseFriendly(
'foo/bar.dart 10:11 (anonymous function).dart.fn');
expect(frame.uri,
equals(path.toUri(path.absolute(path.join('foo', 'bar.dart')))));
expect(frame.line, equals(10));
expect(frame.column, equals(11));
expect(frame.member, equals('(anonymous function).dart.fn'));
});
test(
'parses a stack frame with spaces in the member name and no line or '
'column correctly', () {
var frame = Frame.parseFriendly(
'https://dart.dev/foo/bar.dart (anonymous function).dart.fn');
expect(frame.uri, equals(Uri.parse('https://dart.dev/foo/bar.dart')));
expect(frame.line, isNull);
expect(frame.column, isNull);
expect(frame.member, equals('(anonymous function).dart.fn'));
});
});
test('only considers dart URIs to be core', () {
bool isCore(String library) =>
Frame.parseVM('#0 Foo ($library:0:0)').isCore;
expect(isCore('dart:core'), isTrue);
expect(isCore('dart:async'), isTrue);
expect(isCore('dart:core/uri.dart'), isTrue);
expect(isCore('dart:async/future.dart'), isTrue);
expect(isCore('bart:core'), isFalse);
expect(isCore('sdart:core'), isFalse);
expect(isCore('darty:core'), isFalse);
expect(isCore('bart:core/uri.dart'), isFalse);
});
group('.library', () {
test('returns the URI string for non-file URIs', () {
expect(Frame.parseVM('#0 Foo (dart:async/future.dart:0:0)').library,
equals('dart:async/future.dart'));
expect(
Frame.parseVM('#0 Foo '
'(https://dart.dev/stuff/thing.dart:0:0)')
.library,
equals('https://dart.dev/stuff/thing.dart'));
});
test('returns the relative path for file URIs', () {
expect(Frame.parseVM('#0 Foo (foo/bar.dart:0:0)').library,
equals(path.join('foo', 'bar.dart')));
});
test('truncates legacy data: URIs', () {
var frame = Frame.parseVM(
'#0 Foo (data:application/dart;charset=utf-8,blah:0:0)');
expect(frame.library, equals('data:...'));
});
test('truncates data: URIs', () {
var frame = Frame.parseVM(
'#0 main (<data:application/dart;charset=utf-8>:1:15)');
expect(frame.library, equals('data:...'));
});
});
group('.location', () {
test(
'returns the library and line/column numbers for non-core '
'libraries', () {
expect(
Frame.parseVM('#0 Foo '
'(https://dart.dev/thing.dart:5:10)')
.location,
equals('https://dart.dev/thing.dart 5:10'));
expect(Frame.parseVM('#0 Foo (foo/bar.dart:1:2)').location,
equals('${path.join('foo', 'bar.dart')} 1:2'));
});
});
group('.package', () {
test('returns null for non-package URIs', () {
expect(
Frame.parseVM('#0 Foo (dart:async/future.dart:0:0)').package, isNull);
expect(
Frame.parseVM('#0 Foo '
'(https://dart.dev/stuff/thing.dart:0:0)')
.package,
isNull);
});
test('returns the package name for package: URIs', () {
expect(Frame.parseVM('#0 Foo (package:foo/foo.dart:0:0)').package,
equals('foo'));
expect(Frame.parseVM('#0 Foo (package:foo/zap/bar.dart:0:0)').package,
equals('foo'));
});
});
group('.toString()', () {
test(
'returns the library and line/column numbers for non-core '
'libraries', () {
expect(
Frame.parseVM('#0 Foo (https://dart.dev/thing.dart:5:10)').toString(),
equals('https://dart.dev/thing.dart 5:10 in Foo'));
});
test('converts "<anonymous closure>" to "<fn>"', () {
expect(
Frame.parseVM('#0 Foo.<anonymous closure> '
'(dart:core/uri.dart:5:10)')
.toString(),
equals('dart:core/uri.dart 5:10 in Foo.<fn>'));
});
test('prints a frame without a column correctly', () {
expect(Frame.parseVM('#0 Foo (dart:core/uri.dart:5)').toString(),
equals('dart:core/uri.dart 5 in Foo'));
});
test('prints relative paths as relative', () {
var relative = path.normalize('relative/path/to/foo.dart');
expect(Frame.parseFriendly('$relative 5:10 Foo').toString(),
equals('$relative 5:10 in Foo'));
});
});
}
void expectIsUnparsed(Frame Function(String) constructor, String text) {
var frame = constructor(text);
expect(frame, isA<UnparsedFrame>());
expect(frame.toString(), equals(text));
}