Index: utils/tests/pub/path/path_windows_test.dart |
diff --git a/utils/tests/pub/path/path_windows_test.dart b/utils/tests/pub/path/path_windows_test.dart |
index 1861a675b981ccdf723b6bea0b375bf6db159b96..0d2d3f11e7bfad16b66c07d6c5b9953734ffa822 100644 |
--- a/utils/tests/pub/path/path_windows_test.dart |
+++ b/utils/tests/pub/path/path_windows_test.dart |
@@ -35,6 +35,35 @@ main() { |
expect(builder.extension(r'a.b/c'), r''); |
}); |
+ test('rootPrefix', () { |
+ expect(builder.rootPrefix(''), ''); |
+ expect(builder.rootPrefix('a'), ''); |
+ expect(builder.rootPrefix(r'a\b'), ''); |
+ expect(builder.rootPrefix(r'C:\a\c'), r'C:\'); |
+ expect(builder.rootPrefix('C:\\'), r'C:\'); |
+ expect(builder.rootPrefix('C:/'), 'C:/'); |
+ |
+ // TODO(nweiz): enable this once issue 7323 is fixed. |
+ // expect(builder.rootPrefix(r'\\server\a\b'), r'\\server\'); |
+ }); |
+ |
+ test('dirname', () { |
+ expect(builder.dirname(r''), '.'); |
+ expect(builder.dirname(r'a'), '.'); |
+ expect(builder.dirname(r'a\b'), 'a'); |
+ expect(builder.dirname(r'a\b\c'), r'a\b'); |
+ expect(builder.dirname(r'a\b.c'), 'a'); |
+ expect(builder.dirname(r'a\'), 'a'); |
+ expect(builder.dirname('a/'), 'a'); |
+ expect(builder.dirname(r'a\.'), 'a'); |
+ expect(builder.dirname(r'a\b/c'), r'a\b'); |
+ expect(builder.dirname(r'C:\a'), r'C:\'); |
+ expect(builder.dirname('C:\\'), r'C:\'); |
+ expect(builder.dirname(r'a\b\'), r'a\b'); |
+ expect(builder.dirname(r'a/b\c'), 'a/b'); |
+ expect(builder.dirname(r'a\\'), r'a\'); |
+ }); |
+ |
test('basename', () { |
expect(builder.basename(r''), ''); |
expect(builder.basename(r'a'), 'a'); |
@@ -45,6 +74,12 @@ main() { |
expect(builder.basename(r'a/'), ''); |
expect(builder.basename(r'a\.'), '.'); |
expect(builder.basename(r'a\b/c'), r'c'); |
+ expect(builder.basename(r'C:\a'), 'a'); |
+ // TODO(nweiz): this should actually return 'C:\' |
+ expect(builder.basename(r'C:\'), ''); |
+ expect(builder.basename(r'a\b\'), ''); |
+ expect(builder.basename(r'a/b\c'), 'c'); |
+ expect(builder.basename(r'a\\'), ''); |
}); |
test('basenameWithoutExtension', () { |
@@ -123,6 +158,43 @@ main() { |
expect(builder.join('a', r'c:\b', 'c', 'd'), r'c:\b\c\d'); |
expect(builder.join('a', r'\\b', r'\\c', 'd'), r'\\c\d'); |
}); |
+ |
+ test('ignores trailing nulls', () { |
+ expect(builder.join('a', null), equals('a')); |
+ expect(builder.join('a', 'b', 'c', null, null), equals(r'a\b\c')); |
+ }); |
+ |
+ test('disallows intermediate nulls', () { |
+ expect(() => builder.join('a', null, 'b'), throwsArgumentError); |
+ expect(() => builder.join(null, 'a'), throwsArgumentError); |
+ }); |
+ }); |
+ |
+ group('split', () { |
+ test('simple cases', () { |
+ expect(builder.split('foo'), equals(['foo'])); |
+ expect(builder.split(r'foo\bar'), equals(['foo', 'bar'])); |
+ expect(builder.split(r'foo\bar\baz'), equals(['foo', 'bar', 'baz'])); |
+ expect(builder.split(r'foo\..\bar\.\baz'), |
+ equals(['foo', '..', 'bar', '.', 'baz'])); |
+ expect(builder.split(r'foo\\bar\\\baz'), equals(['foo', 'bar', 'baz'])); |
+ expect(builder.split(r'foo\/\baz'), equals(['foo', 'baz'])); |
+ expect(builder.split('.'), equals(['.'])); |
+ expect(builder.split(''), equals([])); |
+ expect(builder.split('foo/'), equals(['foo'])); |
+ expect(builder.split(r'C:\'), equals([r'C:\'])); |
+ }); |
+ |
+ test('includes the root for absolute paths', () { |
+ expect(builder.split(r'C:\foo\bar\baz'), |
+ equals([r'C:\', 'foo', 'bar', 'baz'])); |
+ expect(builder.split(r'C:\\'), equals([r'C:\'])); |
+ |
+ // TODO(nweiz): enable these once issue 7323 is fixed. |
+ // expect(builder.split(r'\\server\foo\bar\baz'), |
+ // equals([r'\\server\', 'foo', 'bar', 'baz'])); |
+ // expect(builder.split(r'\\server\'), equals([r'\\server\'])); |
+ }); |
}); |
group('normalize', () { |
@@ -225,21 +297,10 @@ main() { |
group('from relative root', () { |
var r = new path.Builder(style: path.Style.windows, root: r'foo\bar'); |
- // These tests rely on the current working directory, so don't do the |
- // right thing if you run them on the wrong platform. |
- if (io.Platform.operatingSystem == 'windows') { |
- test('given absolute path', () { |
- var b = new path.Builder(style: path.Style.windows); |
- // TODO(rnystrom): Use a path method here to get the root prefix |
- // when one exists. |
- var drive = path.current.substring(0, 3); |
- expect(r.relative(drive), b.join(b.relative(drive), r'..\..')); |
- expect(r.relative(b.join(drive, r'a\b')), |
- b.join(b.relative(drive), r'..\..\a\b')); |
- |
- // TODO(rnystrom): Test behavior when drive letters differ. |
- }); |
- } |
+ test('given absolute path', () { |
+ expect(r.relative(r'C:\'), equals(r'C:\')); |
+ expect(r.relative(r'C:\a\b'), equals(r'C:\a\b')); |
+ }); |
test('given relative path', () { |
// The path is considered relative to the root, so it basically just |
@@ -259,6 +320,26 @@ main() { |
expect(r.relative(r'C:\dir.ext\file'), 'file'); |
}); |
+ test('with a root parameter', () { |
+ expect(builder.relative(r'C:\foo\bar\baz', from: r'C:\foo\bar'), |
+ equals('baz')); |
+ expect(builder.relative('..', from: r'C:\foo\bar'), |
+ equals(r'..\..\root')); |
+ expect(builder.relative('..', from: r'D:\foo\bar'), equals(r'C:\root')); |
+ expect(builder.relative(r'C:\foo\bar\baz', from: r'foo\bar'), |
+ equals(r'..\..\..\..\foo\bar\baz')); |
+ expect(builder.relative('..', from: r'foo\bar'), equals(r'..\..\..')); |
+ }); |
+ |
+ 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(r'C:\foo\bar\baz', from: r'foo\bar'), |
+ equals(r'C:\foo\bar\baz')); |
+ expect(r.relative('..', from: r'foo\bar'), equals(r'..\..\..')); |
+ }); |
+ |
test('given absolute with different root prefix', () { |
expect(builder.relative(r'D:\a\b'), r'D:\a\b'); |
expect(builder.relative(r'\\a\b'), r'\\a\b'); |