| Index: packages/stack_trace/test/frame_test.dart
|
| diff --git a/packages/stack_trace/test/frame_test.dart b/packages/stack_trace/test/frame_test.dart
|
| index 63035e0e692867676d52fc060f96f9cd87f5be12..42df4cddfae878874c811e85c18a8ee5c916d59e 100644
|
| --- a/packages/stack_trace/test/frame_test.dart
|
| +++ b/packages/stack_trace/test/frame_test.dart
|
| @@ -2,8 +2,6 @@
|
| // 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.
|
|
|
| -library frame_test;
|
| -
|
| import 'package:path/path.dart' as path;
|
| import 'package:stack_trace/stack_trace.dart';
|
| import 'package:test/test.dart';
|
| @@ -13,8 +11,8 @@ void main() {
|
| test('parses a stack frame with column correctly', () {
|
| var frame = new 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.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'));
|
| @@ -23,8 +21,8 @@ void main() {
|
| test('parses a stack frame without column correctly', () {
|
| var frame = new 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.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'));
|
| @@ -34,8 +32,8 @@ void main() {
|
| test('parses a stack frame without line or column correctly', () {
|
| var frame = new 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.uri, equals(Uri.parse("file:///home/nweiz/code/stuff.dart")));
|
| expect(frame.line, isNull);
|
| expect(frame.column, isNull);
|
| expect(frame.member, equals('Foo._bar'));
|
| @@ -57,8 +55,8 @@ void main() {
|
| });
|
|
|
| test('converts "<function_name_async_body>" to "<async>"', () {
|
| - var frame = new Frame.parseVM(
|
| - '#0 Foo.<function_name_async_body> (foo:0:0)');
|
| + var frame =
|
| + new Frame.parseVM('#0 Foo.<function_name_async_body> (foo:0:0)');
|
| expect(frame.member, equals('Foo.<async>'));
|
| });
|
|
|
| @@ -70,7 +68,9 @@ void main() {
|
| expect(frame.line, isNull);
|
| expect(frame.column, isNull);
|
| });
|
| + });
|
|
|
| + group('.parseV8', () {
|
| test('returns an UnparsedFrame for malformed frames', () {
|
| expectIsUnparsed((text) => new Frame.parseV8(text), '');
|
| expectIsUnparsed((text) => new Frame.parseV8(text), '#1');
|
| @@ -80,9 +80,7 @@ void main() {
|
| expectIsUnparsed((text) => new Frame.parseV8(text),
|
| 'Foo (dart:async/future.dart:10:15)');
|
| });
|
| - });
|
|
|
| - group('.parseV8', () {
|
| test('parses a stack frame correctly', () {
|
| var frame = new Frame.parseV8(" at VW.call\$0 "
|
| "(http://pub.dartlang.org/stuff.dart.js:560:28)");
|
| @@ -114,8 +112,8 @@ void main() {
|
| test('parses a stack frame with a Windows UNC path correctly', () {
|
| var frame = new 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.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'));
|
| @@ -150,8 +148,7 @@ void main() {
|
| });
|
|
|
| test('parses a native stack frame correctly', () {
|
| - var frame = new Frame.parseV8(
|
| - " at Object.stringify (native)");
|
| + var frame = new Frame.parseV8(" at Object.stringify (native)");
|
| expect(frame.uri, Uri.parse('native'));
|
| expect(frame.line, isNull);
|
| expect(frame.column, isNull);
|
| @@ -215,8 +212,8 @@ void main() {
|
| new Frame.parseV8(' at $member (foo:0:0)').member;
|
|
|
| expect(parsedMember('Foo.<anonymous>'), equals('Foo.<fn>'));
|
| - expect(parsedMember('<anonymous>.<anonymous>.bar'),
|
| - equals('<fn>.<fn>.bar'));
|
| + expect(
|
| + parsedMember('<anonymous>.<anonymous>.bar'), equals('<fn>.<fn>.bar'));
|
| });
|
|
|
| test('returns an UnparsedFrame for malformed frames', () {
|
| @@ -229,12 +226,12 @@ void main() {
|
| ' at (dart:async/future.dart:10:15)');
|
| expectIsUnparsed((text) => new Frame.parseV8(text),
|
| 'Foo (dart:async/future.dart:10:15)');
|
| - expectIsUnparsed((text) => new Frame.parseV8(text),
|
| - ' at dart:async/future.dart');
|
| + expectIsUnparsed(
|
| + (text) => new Frame.parseV8(text), ' at dart:async/future.dart');
|
| expectIsUnparsed((text) => new Frame.parseV8(text),
|
| ' at dart:async/future.dart:10');
|
| - expectIsUnparsed((text) => new Frame.parseV8(text),
|
| - 'dart:async/future.dart:10:15');
|
| + expectIsUnparsed(
|
| + (text) => new Frame.parseV8(text), 'dart:async/future.dart:10:15');
|
| });
|
| });
|
|
|
| @@ -250,8 +247,8 @@ void main() {
|
| });
|
|
|
| test('parses a stack frame with an absolute POSIX path correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - ".VW.call\$0@/path/to/stuff.dart.js:560");
|
| + var frame =
|
| + new 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);
|
| @@ -259,8 +256,8 @@ void main() {
|
| });
|
|
|
| test('parses a stack frame with an absolute Windows path correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - r".VW.call$0@C:\path\to\stuff.dart.js:560");
|
| + var frame =
|
| + new 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);
|
| @@ -270,16 +267,16 @@ void main() {
|
| test('parses a stack frame with a Windows UNC path correctly', () {
|
| var frame = new 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.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 = new Frame.parseFirefox(
|
| - ".VW.call\$0@path/to/stuff.dart.js:560");
|
| + var frame =
|
| + new 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);
|
| @@ -287,8 +284,8 @@ void main() {
|
| });
|
|
|
| test('parses a stack frame with a relative Windows path correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - r".VW.call$0@path\to\stuff.dart.js:560");
|
| + var frame =
|
| + new 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);
|
| @@ -296,8 +293,8 @@ void main() {
|
| });
|
|
|
| test('parses a simple anonymous stack frame correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - "@http://pub.dartlang.org/stuff.dart.js:560");
|
| + var frame =
|
| + new Frame.parseFirefox("@http://pub.dartlang.org/stuff.dart.js:560");
|
| expect(frame.uri,
|
| equals(Uri.parse("http://pub.dartlang.org/stuff.dart.js")));
|
| expect(frame.line, equals(560));
|
| @@ -352,8 +349,7 @@ void main() {
|
| });
|
|
|
| test('parses a nested anonymous stack frame with parameters correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - '.foo(12, "@)()/<")/.fn<@'
|
| + var frame = new Frame.parseFirefox('.foo(12, "@)()/<")/.fn<@'
|
| 'http://pub.dartlang.org/stuff.dart.js:560');
|
| expect(frame.uri,
|
| equals(Uri.parse("http://pub.dartlang.org/stuff.dart.js")));
|
| @@ -362,11 +358,12 @@ void main() {
|
| expect(frame.member, equals("foo.<fn>"));
|
| });
|
|
|
| - test('parses a deeply-nested anonymous stack frame with parameters '
|
| + test(
|
| + 'parses a deeply-nested anonymous stack frame with parameters '
|
| 'correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - '.convertDartClosureToJS/\$function</<@'
|
| - 'http://pub.dartlang.org/stuff.dart.js:560');
|
| + var frame =
|
| + new Frame.parseFirefox('.convertDartClosureToJS/\$function</<@'
|
| + 'http://pub.dartlang.org/stuff.dart.js:560');
|
| expect(frame.uri,
|
| equals(Uri.parse("http://pub.dartlang.org/stuff.dart.js")));
|
| expect(frame.line, equals(560));
|
| @@ -381,8 +378,8 @@ void main() {
|
| '.foo@dart:async/future.dart');
|
| expectIsUnparsed((text) => new Frame.parseFirefox(text),
|
| '.foo(@dart:async/future.dart:10');
|
| - expectIsUnparsed((text) => new Frame.parseFirefox(text),
|
| - '@dart:async/future.dart');
|
| + expectIsUnparsed(
|
| + (text) => new Frame.parseFirefox(text), '@dart:async/future.dart');
|
| });
|
|
|
| test('parses a simple stack frame correctly', () {
|
| @@ -395,8 +392,8 @@ void main() {
|
| });
|
|
|
| test('parses an anonymous stack frame correctly', () {
|
| - var frame = new Frame.parseFirefox(
|
| - "http://dartlang.org/foo/bar.dart:10:11");
|
| + var frame =
|
| + new Frame.parseFirefox("http://dartlang.org/foo/bar.dart:10:11");
|
| expect(frame.uri, equals(Uri.parse("http://dartlang.org/foo/bar.dart")));
|
| expect(frame.line, equals(10));
|
| expect(frame.column, equals(11));
|
| @@ -450,7 +447,7 @@ void main() {
|
| expect(frame.member, equals('Foo.<fn>.bar'));
|
| });
|
|
|
| - test('parses a stack frame with no line correctly', () {
|
| + test('parses a stack frame with no column correctly', () {
|
| var frame = new Frame.parseFriendly(
|
| "http://dartlang.org/foo/bar.dart 10 Foo.<fn>.bar");
|
| expect(frame.uri, equals(Uri.parse("http://dartlang.org/foo/bar.dart")));
|
| @@ -461,8 +458,8 @@ void main() {
|
|
|
| test('parses a stack frame with a relative path correctly', () {
|
| var frame = new 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.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'));
|
| @@ -471,14 +468,51 @@ void main() {
|
| test('returns an UnparsedFrame for malformed frames', () {
|
| expectIsUnparsed((text) => new Frame.parseFriendly(text), '');
|
| expectIsUnparsed((text) => new Frame.parseFriendly(text), 'foo/bar.dart');
|
| - expectIsUnparsed((text) => new Frame.parseFriendly(text),
|
| - 'foo/bar.dart 10:11');
|
| + expectIsUnparsed(
|
| + (text) => new Frame.parseFriendly(text), 'foo/bar.dart 10:11');
|
| + });
|
| +
|
| + test('parses a data url stack frame with no line or column correctly', () {
|
| + var frame = new 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 = new 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 = new 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 = new Frame.parseFriendly(
|
| + "http://dartlang.org/foo/bar.dart (anonymous function).dart.fn");
|
| + expect(frame.uri, equals(Uri.parse("http://dartlang.org/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) =>
|
| - new Frame.parseVM('#0 Foo ($library:0:0)').isCore;
|
| + new Frame.parseVM('#0 Foo ($library:0:0)').isCore;
|
|
|
| expect(isCore('dart:core'), isTrue);
|
| expect(isCore('dart:async'), isTrue);
|
| @@ -494,8 +528,10 @@ void main() {
|
| test('returns the URI string for non-file URIs', () {
|
| expect(new Frame.parseVM('#0 Foo (dart:async/future.dart:0:0)').library,
|
| equals('dart:async/future.dart'));
|
| - expect(new Frame.parseVM('#0 Foo '
|
| - '(http://dartlang.org/stuff/thing.dart:0:0)').library,
|
| + expect(
|
| + new Frame.parseVM('#0 Foo '
|
| + '(http://dartlang.org/stuff/thing.dart:0:0)')
|
| + .library,
|
| equals('http://dartlang.org/stuff/thing.dart'));
|
| });
|
|
|
| @@ -512,10 +548,13 @@ void main() {
|
| });
|
|
|
| group('.location', () {
|
| - test('returns the library and line/column numbers for non-core '
|
| + test(
|
| + 'returns the library and line/column numbers for non-core '
|
| 'libraries', () {
|
| - expect(new Frame.parseVM('#0 Foo '
|
| - '(http://dartlang.org/thing.dart:5:10)').location,
|
| + expect(
|
| + new Frame.parseVM('#0 Foo '
|
| + '(http://dartlang.org/thing.dart:5:10)')
|
| + .location,
|
| equals('http://dartlang.org/thing.dart 5:10'));
|
| expect(new Frame.parseVM('#0 Foo (foo/bar.dart:1:2)').location,
|
| equals('${path.join('foo', 'bar.dart')} 1:2'));
|
| @@ -526,8 +565,10 @@ void main() {
|
| test('returns null for non-package URIs', () {
|
| expect(new Frame.parseVM('#0 Foo (dart:async/future.dart:0:0)').package,
|
| isNull);
|
| - expect(new Frame.parseVM('#0 Foo '
|
| - '(http://dartlang.org/stuff/thing.dart:0:0)').package,
|
| + expect(
|
| + new Frame.parseVM('#0 Foo '
|
| + '(http://dartlang.org/stuff/thing.dart:0:0)')
|
| + .package,
|
| isNull);
|
| });
|
|
|
| @@ -540,16 +581,20 @@ void main() {
|
| });
|
|
|
| group('.toString()', () {
|
| - test('returns the library and line/column numbers for non-core '
|
| + test(
|
| + 'returns the library and line/column numbers for non-core '
|
| 'libraries', () {
|
| - expect(new Frame.parseVM('#0 Foo (http://dartlang.org/thing.dart:5:10)')
|
| + expect(
|
| + new Frame.parseVM('#0 Foo (http://dartlang.org/thing.dart:5:10)')
|
| .toString(),
|
| equals('http://dartlang.org/thing.dart 5:10 in Foo'));
|
| });
|
|
|
| test('converts "<anonymous closure>" to "<fn>"', () {
|
| - expect(new Frame.parseVM('#0 Foo.<anonymous closure> '
|
| - '(dart:core/uri.dart:5:10)').toString(),
|
| + expect(
|
| + new Frame.parseVM('#0 Foo.<anonymous closure> '
|
| + '(dart:core/uri.dart:5:10)')
|
| + .toString(),
|
| equals('dart:core/uri.dart 5:10 in Foo.<fn>'));
|
| });
|
|
|
|
|