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

Unified Diff: pkg/path/test/windows_test.dart

Issue 59483008: Add isWithin to pkg/path. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: code review Created 7 years, 1 month 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 | « pkg/path/test/utils.dart ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: pkg/path/test/windows_test.dart
diff --git a/pkg/path/test/windows_test.dart b/pkg/path/test/windows_test.dart
index 5d4fd04dfd80579938741b2155d5660875026647..f1a2395edb897d74aca761af67ffb59a60d71714 100644
--- a/pkg/path/test/windows_test.dart
+++ b/pkg/path/test/windows_test.dart
@@ -7,6 +7,8 @@ library path.test.windows_test;
import 'package:unittest/unittest.dart';
import 'package:path/path.dart' as path;
+import 'utils.dart';
+
main() {
var builder = new path.Builder(style: path.Style.windows,
root: r'C:\root\path');
@@ -47,6 +49,10 @@ main() {
expect(builder.rootPrefix('C:\\'), r'C:\');
expect(builder.rootPrefix('C:/'), 'C:/');
expect(builder.rootPrefix(r'\\server\share\a\b'), r'\\server\share');
+ expect(builder.rootPrefix(r'\a\b'), r'\');
+ expect(builder.rootPrefix(r'/a/b'), r'/');
+ expect(builder.rootPrefix(r'\'), r'\');
+ expect(builder.rootPrefix(r'/'), r'/');
});
test('dirname', () {
@@ -71,6 +77,10 @@ main() {
expect(builder.dirname(r'foo bar\gule fisk'), 'foo bar');
expect(builder.dirname(r'\\server\share'), r'\\server\share');
expect(builder.dirname(r'\\server\share\dir'), r'\\server\share');
+ expect(builder.dirname(r'\a'), r'\');
+ expect(builder.dirname(r'/a'), r'/');
+ expect(builder.dirname(r'\'), r'\');
+ expect(builder.dirname(r'/'), r'/');
});
test('basename', () {
@@ -97,6 +107,10 @@ main() {
expect(builder.basename(r'a\fisk hest.ma pa'), 'fisk hest.ma pa');
expect(builder.basename(r'\\server\share'), r'\\server\share');
expect(builder.basename(r'\\server\share\dir'), r'dir');
+ expect(builder.basename(r'\a'), r'a');
+ expect(builder.basename(r'/a'), r'a');
+ expect(builder.basename(r'\'), r'\');
+ expect(builder.basename(r'/'), r'/');
});
test('basenameWithoutExtension', () {
@@ -127,8 +141,10 @@ main() {
expect(builder.isAbsolute('..'), false);
expect(builder.isAbsolute('a'), false);
expect(builder.isAbsolute(r'a\b'), false);
- expect(builder.isAbsolute(r'\a'), false);
- expect(builder.isAbsolute(r'\a\b'), false);
+ expect(builder.isAbsolute(r'\a\b'), true);
+ expect(builder.isAbsolute(r'\'), true);
+ expect(builder.isAbsolute(r'/a/b'), true);
+ expect(builder.isAbsolute(r'/'), true);
expect(builder.isAbsolute('~'), false);
expect(builder.isAbsolute('.'), false);
expect(builder.isAbsolute(r'..\a'), false);
@@ -148,8 +164,10 @@ main() {
expect(builder.isRelative('..'), true);
expect(builder.isRelative('a'), true);
expect(builder.isRelative(r'a\b'), true);
- expect(builder.isRelative(r'\a'), true);
- expect(builder.isRelative(r'\a\b'), true);
+ expect(builder.isRelative(r'\a\b'), false);
+ expect(builder.isRelative(r'\'), false);
+ expect(builder.isRelative(r'/a/b'), false);
+ expect(builder.isRelative(r'/'), false);
expect(builder.isRelative('~'), true);
expect(builder.isRelative('.'), true);
expect(builder.isRelative(r'..\a'), true);
@@ -163,6 +181,29 @@ main() {
expect(builder.isRelative(r'\\server\share\path'), false);
});
+ test('isRootRelative', () {
+ expect(builder.isRootRelative(''), false);
+ expect(builder.isRootRelative('.'), false);
+ expect(builder.isRootRelative('..'), false);
+ expect(builder.isRootRelative('a'), false);
+ expect(builder.isRootRelative(r'a\b'), false);
+ expect(builder.isRootRelative(r'\a\b'), true);
+ expect(builder.isRootRelative(r'\'), true);
+ expect(builder.isRootRelative(r'/a/b'), true);
+ expect(builder.isRootRelative(r'/'), true);
+ expect(builder.isRootRelative('~'), false);
+ expect(builder.isRootRelative('.'), false);
+ expect(builder.isRootRelative(r'..\a'), false);
+ expect(builder.isRootRelative(r'a:/a\b'), false);
+ expect(builder.isRootRelative(r'D:/a/b'), false);
+ expect(builder.isRootRelative(r'c:\'), false);
+ expect(builder.isRootRelative(r'B:\'), false);
+ expect(builder.isRootRelative(r'c:\a'), false);
+ expect(builder.isRootRelative(r'C:\a'), false);
+ expect(builder.isRootRelative(r'\\server\share'), false);
+ expect(builder.isRootRelative(r'\\server\share\path'), false);
+ });
+
group('join', () {
test('allows up to eight parts', () {
expect(builder.join('a'), 'a');
@@ -179,14 +220,15 @@ main() {
test('does not add separator if a part ends or begins in one', () {
expect(builder.join(r'a\', 'b', r'c\', 'd'), r'a\b\c\d');
expect(builder.join('a/', 'b'), r'a/b');
- expect(builder.join('a', '/b'), 'a/b');
- expect(builder.join('a', r'\b'), r'a\b');
});
test('ignores parts before an absolute path', () {
- expect(builder.join('a', '/b', '/c', 'd'), r'a/b/c\d');
+ expect(builder.join('a', r'\b', r'\c', 'd'), r'\c\d');
+ expect(builder.join('a', '/b', '/c', 'd'), r'/c\d');
expect(builder.join('a', r'c:\b', 'c', 'd'), r'c:\b\c\d');
expect(builder.join('a', r'\\b\c', r'\\d\e', 'f'), r'\\d\e\f');
+ expect(builder.join('a', r'c:\b', r'\c', 'd'), r'c:\c\d');
+ expect(builder.join('a', r'\\b\c\d', r'\e', 'f'), r'\\b\c\e\f');
});
test('ignores trailing nulls', () {
@@ -225,14 +267,15 @@ main() {
test('does not add separator if a part ends or begins in one', () {
expect(builder.joinAll([r'a\', 'b', r'c\', 'd']), r'a\b\c\d');
expect(builder.joinAll(['a/', 'b']), r'a/b');
- expect(builder.joinAll(['a', '/b']), 'a/b');
- expect(builder.joinAll(['a', r'\b']), r'a\b');
});
test('ignores parts before an absolute path', () {
- expect(builder.joinAll(['a', '/b', '/c', 'd']), r'a/b/c\d');
+ expect(builder.joinAll(['a', r'\b', r'\c', 'd']), r'\c\d');
+ expect(builder.joinAll(['a', '/b', '/c', 'd']), r'/c\d');
expect(builder.joinAll(['a', r'c:\b', 'c', 'd']), r'c:\b\c\d');
expect(builder.joinAll(['a', r'\\b\c', r'\\d\e', 'f']), r'\\d\e\f');
+ expect(builder.joinAll(['a', r'c:\b', r'\c', 'd']), r'c:\c\d');
+ expect(builder.joinAll(['a', r'\\b\c\d', r'\e', 'f']), r'\\b\c\e\f');
});
});
@@ -262,6 +305,10 @@ main() {
expect(builder.split(r'\\server\share\foo\bar\baz'),
equals([r'\\server\share', 'foo', 'bar', 'baz']));
expect(builder.split(r'\\server\share'), equals([r'\\server\share']));
+
+ expect(builder.split(r'\foo\bar\baz'),
+ equals([r'\', 'foo', 'bar', 'baz']));
+ expect(builder.split(r'\'), equals([r'\']));
});
});
@@ -271,8 +318,10 @@ main() {
expect(builder.normalize('.'), '.');
expect(builder.normalize('..'), '..');
expect(builder.normalize('a'), 'a');
- expect(builder.normalize(r'\'), '.');
- expect(builder.normalize('/'), r'.');
+ expect(builder.normalize('/a/b'), r'\a\b');
+ expect(builder.normalize(r'\'), r'\');
+ expect(builder.normalize(r'\a\b'), r'\a\b');
+ expect(builder.normalize('/'), r'\');
expect(builder.normalize('C:/'), r'C:\');
expect(builder.normalize(r'C:\'), r'C:\');
expect(builder.normalize(r'\\server\share'), r'\\server\share');
@@ -296,6 +345,8 @@ main() {
expect(builder.normalize(r'a\./.\b\.\c'), r'a\b\c');
expect(builder.normalize(r'.\./a'), 'a');
expect(builder.normalize(r'a/.\.'), 'a');
+ expect(builder.normalize(r'\.'), r'\');
+ expect(builder.normalize('/.'), r'\');
});
test('eliminates ".." parts', () {
@@ -313,8 +364,7 @@ main() {
expect(builder.normalize(r'a\..'), '.');
expect(builder.normalize(r'..\a'), r'..\a');
expect(builder.normalize(r'c:\..\a'), r'c:\a');
- // A path starting with '\' is not an absolute path on Windows.
- expect(builder.normalize(r'\..\a'), r'..\a');
+ expect(builder.normalize(r'\..\a'), r'\a');
expect(builder.normalize(r'a\b\..'), 'a');
expect(builder.normalize(r'..\a\b\..'), r'..\a');
expect(builder.normalize(r'a\..\b'), 'b');
@@ -342,8 +392,11 @@ main() {
test('given absolute path in root', () {
expect(builder.relative(r'C:\'), r'..\..');
expect(builder.relative(r'C:\root'), '..');
+ expect(builder.relative(r'\root'), '..');
expect(builder.relative(r'C:\root\path'), '.');
+ expect(builder.relative(r'\root\path'), '.');
expect(builder.relative(r'C:\root\path\a'), 'a');
+ expect(builder.relative(r'\root\path\a'), 'a');
expect(builder.relative(r'C:\root\path\a\b.txt'), r'a\b.txt');
expect(builder.relative(r'C:\root\a\b.txt'), r'..\a\b.txt');
expect(builder.relative(r'C:/'), r'..\..');
@@ -354,6 +407,7 @@ main() {
test('given absolute path outside of root', () {
expect(builder.relative(r'C:\a\b'), r'..\..\a\b');
+ expect(builder.relative(r'\a\b'), r'..\..\a\b');
expect(builder.relative(r'C:\root\path\a'), 'a');
expect(builder.relative(r'C:\root\path\a\b.txt'), r'a\b.txt');
expect(builder.relative(r'C:\root\a\b.txt'), r'..\a\b.txt');
@@ -391,6 +445,33 @@ main() {
test('given absolute path', () {
expect(r.relative(r'C:\'), equals(r'C:\'));
expect(r.relative(r'C:\a\b'), equals(r'C:\a\b'));
+ expect(r.relative(r'\'), equals(r'\'));
+ expect(r.relative(r'\a\b'), equals(r'\a\b'));
+ });
+
+ test('given relative path', () {
+ // The path is considered relative to the root, so it basically just
+ // normalizes.
+ expect(r.relative(''), '.');
+ expect(r.relative('.'), '.');
+ expect(r.relative('..'), '..');
+ expect(r.relative('a'), 'a');
+ expect(r.relative(r'a\b.txt'), r'a\b.txt');
+ expect(r.relative(r'..\a/b.txt'), r'..\a\b.txt');
+ expect(r.relative(r'a\./b\../c.txt'), r'a\c.txt');
+ });
+ });
+
+ group('from root-relative root', () {
+ var r = new path.Builder(style: path.Style.windows, root: r'\foo\bar');
+
+ test('given absolute path', () {
+ expect(r.relative(r'C:\'), equals(r'C:\'));
+ expect(r.relative(r'C:\a\b'), equals(r'C:\a\b'));
+ expect(r.relative(r'\'), equals(r'..\..'));
+ expect(r.relative(r'\a\b'), equals(r'..\..\a\b'));
+ expect(r.relative('/'), equals(r'..\..'));
+ expect(r.relative('/a/b'), equals(r'..\..\a\b'));
});
test('given relative path', () {
@@ -425,7 +506,7 @@ main() {
test('with a root parameter and a relative root', () {
var r = new path.Builder(style: path.Style.windows, root: r'relative\root');
expect(r.relative(r'C:\foo\bar\baz', from: r'C:\foo\bar'), equals('baz'));
- expect(() => r.relative('..', from: r'C:\foo\bar'), throwsArgumentError);
+ expect(() => r.relative('..', from: r'C:\foo\bar'), throwsPathException);
expect(r.relative(r'C:\foo\bar\baz', from: r'foo\bar'),
equals(r'C:\foo\bar\baz'));
expect(r.relative('..', from: r'foo\bar'), equals(r'..\..\..'));
@@ -440,6 +521,32 @@ main() {
var r = new path.Builder(style: path.Style.windows, root: '.');
expect(r.relative(r'C:\foo\bar\baz'), equals(r'C:\foo\bar\baz'));
expect(r.relative(r'foo\bar\baz'), equals(r'foo\bar\baz'));
+ expect(r.relative(r'\foo\bar\baz'), equals(r'\foo\bar\baz'));
+ });
+ });
+
+ group('isWithin', () {
+ test('simple cases', () {
+ expect(builder.isWithin(r'foo\bar', r'foo\bar'), isFalse);
+ expect(builder.isWithin(r'foo\bar', r'foo\bar\baz'), isTrue);
+ expect(builder.isWithin(r'foo\bar', r'foo\baz'), isFalse);
+ expect(builder.isWithin(r'foo\bar', r'..\path\foo\bar\baz'), isTrue);
+ expect(builder.isWithin(r'C:\', r'C:\foo\bar'), isTrue);
+ expect(builder.isWithin(r'C:\', r'D:\foo\bar'), isFalse);
+ expect(builder.isWithin(r'C:\', r'\foo\bar'), isTrue);
+ expect(builder.isWithin(r'C:\foo', r'\foo\bar'), isTrue);
+ expect(builder.isWithin(r'C:\foo', r'\bar\baz'), isFalse);
+ expect(builder.isWithin(r'baz', r'C:\root\path\baz\bang'), isTrue);
+ expect(builder.isWithin(r'baz', r'C:\root\path\bang\baz'), isFalse);
+ });
+
+ test('from a relative root', () {
+ var r = new path.Builder(style: path.Style.windows, root: r'foo\bar');
+ expect(builder.isWithin('.', r'a\b\c'), isTrue);
+ expect(builder.isWithin('.', r'..\a\b\c'), isFalse);
+ expect(builder.isWithin('.', r'..\..\a\foo\b\c'), isFalse);
+ expect(builder.isWithin(r'C:\', r'C:\baz\bang'), isTrue);
+ expect(builder.isWithin('.', r'C:\baz\bang'), isFalse);
});
});
@@ -463,7 +570,8 @@ main() {
});
test('ignores parts before an absolute path', () {
- expect(builder.resolve('a', '/b', '/c', 'd'), r'C:\root\path\a/b/c\d');
+ expect(builder.resolve('a', '/b', '/c', 'd'), r'C:\c\d');
+ expect(builder.resolve('a', r'\b', r'\c', 'd'), r'C:\c\d');
expect(builder.resolve('a', r'c:\b', 'c', 'd'), r'c:\b\c\d');
expect(builder.resolve('a', r'\\b\c', r'\\d\e', 'f'), r'\\d\e\f');
});
« no previous file with comments | « pkg/path/test/utils.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698