Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(759)

Unified Diff: packages/string_scanner/test/span_scanner_test.dart

Issue 2989763002: Update charted to 0.4.8 and roll (Closed)
Patch Set: Removed Cutch from list of reviewers Created 3 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: packages/string_scanner/test/span_scanner_test.dart
diff --git a/packages/string_scanner/test/span_scanner_test.dart b/packages/string_scanner/test/span_scanner_test.dart
index 114bff72669c6c8b4878c1c6c8c642cc279b7b57..ab3cc808743b942b692158d5ace2dda74fe92ea6 100644
--- a/packages/string_scanner/test/span_scanner_test.dart
+++ b/packages/string_scanner/test/span_scanner_test.dart
@@ -2,18 +2,105 @@
// 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 string_scanner.span_scanner_test;
-
+import 'package:source_span/source_span.dart';
import 'package:string_scanner/string_scanner.dart';
import 'package:test/test.dart';
+import 'utils.dart';
+
void main() {
- testForImplementation("lazy", () {
- return new SpanScanner('foo\nbar\nbaz', sourceUrl: 'source');
+ testForImplementation("lazy", ([string]) {
+ return new SpanScanner(string ?? 'foo\nbar\nbaz', sourceUrl: 'source');
});
- testForImplementation("eager", () {
- return new SpanScanner.eager('foo\nbar\nbaz', sourceUrl: 'source');
+ testForImplementation("eager", ([string]) {
+ return new SpanScanner.eager(string ?? 'foo\nbar\nbaz',
+ sourceUrl: 'source');
+ });
+
+ group("within", () {
+ var text = 'first\nbefore: foo\nbar\nbaz :after\nlast';
+ var startOffset = text.indexOf('foo');
+
+ var scanner;
+ setUp(() {
+ var file = new SourceFile.fromString(text, url: 'source');
+ scanner = new SpanScanner.within(
+ file.span(startOffset, text.indexOf(' :after')));
+ });
+
+ test("string only includes the span text", () {
+ expect(scanner.string, equals("foo\nbar\nbaz"));
+ });
+
+ test("line and column are span-relative", () {
+ expect(scanner.line, equals(0));
+ expect(scanner.column, equals(0));
+
+ scanner.scan("foo");
+ expect(scanner.line, equals(0));
+ expect(scanner.column, equals(3));
+
+ scanner.scan("\n");
+ expect(scanner.line, equals(1));
+ expect(scanner.column, equals(0));
+ });
+
+ test("tracks the span for the last match", () {
+ scanner.scan('fo');
+ scanner.scan('o\nba');
+
+ var span = scanner.lastSpan;
+ expect(span.start.offset, equals(startOffset + 2));
+ expect(span.start.line, equals(1));
+ expect(span.start.column, equals(10));
+ expect(span.start.sourceUrl, equals(Uri.parse('source')));
+
+ expect(span.end.offset, equals(startOffset + 6));
+ expect(span.end.line, equals(2));
+ expect(span.end.column, equals(2));
+ expect(span.start.sourceUrl, equals(Uri.parse('source')));
+
+ expect(span.text, equals('o\nba'));
+ });
+
+ test(".spanFrom() returns a span from a previous state", () {
+ scanner.scan('fo');
+ var state = scanner.state;
+ scanner.scan('o\nba');
+ scanner.scan('r\nba');
+
+ var span = scanner.spanFrom(state);
+ expect(span.text, equals('o\nbar\nba'));
+ });
+
+ test(".emptySpan returns an empty span at the current location", () {
+ scanner.scan('foo\nba');
+
+ var span = scanner.emptySpan;
+ expect(span.start.offset, equals(startOffset + 6));
+ expect(span.start.line, equals(2));
+ expect(span.start.column, equals(2));
+ expect(span.start.sourceUrl, equals(Uri.parse('source')));
+
+ expect(span.end.offset, equals(startOffset + 6));
+ expect(span.end.line, equals(2));
+ expect(span.end.column, equals(2));
+ expect(span.start.sourceUrl, equals(Uri.parse('source')));
+
+ expect(span.text, equals(''));
+ });
+
+ test(".error() uses an absolute span", () {
+ scanner.expect("foo");
+ expect(() => scanner.error('oh no!'),
+ throwsStringScannerException("foo"));
+ });
+
+ test(".isDone returns true at the end of the span", () {
+ scanner.expect("foo\nbar\nbaz");
+ expect(scanner.isDone, isTrue);
+ });
});
}
@@ -50,6 +137,15 @@ void testForImplementation(String name, SpanScanner create()) {
expect(span.text, equals('o\nbar\nba'));
});
+ test(".spanFrom() handles surrogate pairs correctly", () {
+ scanner = create('fo\u{12345}o');
+ scanner.scan('fo');
+ var state = scanner.state;
+ scanner.scan('\u{12345}o');
+ var span = scanner.spanFrom(state);
+ expect(span.text, equals('\u{12345}o'));
+ });
+
test(".emptySpan returns an empty span at the current location", () {
scanner.scan('foo\nba');
« no previous file with comments | « packages/string_scanner/test/line_scanner_test.dart ('k') | packages/string_scanner/test/string_scanner_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698