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

Unified Diff: test/span_scanner_test.dart

Issue 2039163002: Add SpanScanner.within(). (Closed) Base URL: git@github.com:dart-lang/string_scanner@master
Patch Set: Code review changes Created 4 years, 6 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
« no previous file with comments | « pubspec.yaml ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: test/span_scanner_test.dart
diff --git a/test/span_scanner_test.dart b/test/span_scanner_test.dart
index b078f6e1a10d559c1e7b336d6a25bc69ec378204..84d7b94ee083db6c80bca97c6caf46d19184f05e 100644
--- a/test/span_scanner_test.dart
+++ b/test/span_scanner_test.dart
@@ -2,9 +2,12 @@
// 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: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');
@@ -13,6 +16,91 @@ void main() {
testForImplementation("eager", () {
return new SpanScanner.eager('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(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);
+ });
+ });
}
void testForImplementation(String name, SpanScanner create()) {
« no previous file with comments | « pubspec.yaml ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698