 Chromium Code Reviews
 Chromium Code Reviews Issue 1228093003:
  Fix several package spec bugs.  (Closed) 
  Base URL: git@github.com:dart-lang/pub.git@master
    
  
    Issue 1228093003:
  Fix several package spec bugs.  (Closed) 
  Base URL: git@github.com:dart-lang/pub.git@master| Index: test/descriptor/packages.dart | 
| diff --git a/test/descriptor/packages.dart b/test/descriptor/packages.dart | 
| index 9d857c0671fadd13758effee3e7adffba1bc6e7a..a70b483a1f4a3c986a249cb326bca4390af4d026 100644 | 
| --- a/test/descriptor/packages.dart | 
| +++ b/test/descriptor/packages.dart | 
| @@ -44,8 +44,8 @@ class PackagesFileDescriptor extends Descriptor { | 
| // If it's a semver, it's a cache reference. | 
| packagePath = p.join(cachePath, "$package-$version"); | 
| } else { | 
| - // Otherwise it's a path relative to the .pubspec file, | 
| - // which is also the relative path wrt. the .packages file. | 
| + // Otherwise it's a path relative to the pubspec file, | 
| + // which is also relative to the .packages file. | 
| packagePath = p.fromUri(version); | 
| } | 
| mapping[package] = p.toUri(p.join(packagePath, "lib", "")); | 
| @@ -74,8 +74,11 @@ class PackagesFileDescriptor extends Descriptor { | 
| /// A function that throws an error if [binaryContents] doesn't match the | 
| /// expected contents of the descriptor. | 
| void _validateNow(List<int> binaryContents, String fullPath) { | 
| - var fileUri = p.toUri(fullPath); | 
| - var map = packages_file.parse(binaryContents, fileUri); | 
| + // Resolve against a dummy URL so that we can test whether the URLs in | 
| + // the package file are themselves relative. We can't resolve against just | 
| + // "." due to sdk#23809. | 
| 
Lasse Reichstein Nielsen
2015/07/13 07:15:37
sdk#23809 could be http://dartbug.com/23809 ?
 
nweiz
2015/07/13 20:03:44
I'd rather use a more GitHub-like convention. This
 
Lasse Reichstein Nielsen
2015/07/16 14:51:58
But it also means that there is no direct way for
 | 
| + var base = "/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p"; | 
| + var map = packages_file.parse(binaryContents, Uri.parse(base)); | 
| for (var package in _dependencies.keys) { | 
| if (!map.containsKey(package)) { | 
| @@ -89,14 +92,12 @@ class PackagesFileDescriptor extends Descriptor { | 
| "Expected $description, found location: ${map[package]}."); | 
| } | 
| } else { | 
| - var expected = p.normalize(p.join( | 
| - p.dirname(fullPath), p.fromUri(description), 'lib')); | 
| - expected = new File(expected).resolveSymbolicLinksSync(); | 
| - var actual = new File(p.normalize(p.absolute(p.fromUri(map[package])))) | 
| - .resolveSymbolicLinksSync(); | 
| + var expected = p.normalize(p.join(p.fromUri(description), 'lib')); | 
| + var actual = p.normalize(p.fromUri( | 
| + p.url.relative(map[package].toString(), from: p.dirname(base)))); | 
| if (expected != actual) { | 
| - fail("Relative path: Expected $description, found ${map[package]}"); | 
| + fail("Relative path: Expected $expected, found $actual"); | 
| } | 
| } | 
| } |