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

Side by Side Diff: utils/tests/pub/version_solver_test.dart

Issue 10938003: Don't extract the name of a package from its description. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Code review changes Created 8 years, 3 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « utils/tests/pub/test_pub.dart ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #library('pub_update_test'); 5 #library('pub_update_test');
6 6
7 #import('dart:io'); 7 #import('dart:io');
8 #import('dart:isolate'); 8 #import('dart:isolate');
9 9
10 #import('../../pub/lock_file.dart'); 10 #import('../../pub/lock_file.dart');
(...skipping 308 matching lines...) Expand 10 before | Expand all | Expand 10 after
319 if (result != null) { 319 if (result != null) {
320 result.forEach((name, version) { 320 result.forEach((name, version) {
321 result[name] = new Version.parse(version); 321 result[name] = new Version.parse(version);
322 }); 322 });
323 } 323 }
324 324
325 var realLockFile = new LockFile.empty(); 325 var realLockFile = new LockFile.empty();
326 if (lockfile != null) { 326 if (lockfile != null) {
327 lockfile.forEach((name, version) { 327 lockfile.forEach((name, version) {
328 version = new Version.parse(version); 328 version = new Version.parse(version);
329 realLockFile.packages[name] = new PackageId(source1, version, name); 329 realLockFile.packages[name] =
330 new PackageId(name, source1, version, name);
330 }); 331 });
331 } 332 }
332 333
333 // Resolve the versions. 334 // Resolve the versions.
334 var future = resolveVersions(sources, root, realLockFile); 335 var future = resolveVersions(sources, root, realLockFile);
335 336
336 if (result != null) { 337 if (result != null) {
337 expect(future, completion(predicate((actualResult) { 338 expect(future, completion(predicate((actualResult) {
338 for (var id in actualResult) { 339 for (var id in actualResult) {
339 if (!result.containsKey(id.description)) return false; 340 if (!result.containsKey(id.description)) return false;
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after
376 */ 377 */
377 class MockSource extends Source { 378 class MockSource extends Source {
378 final Map<String, Map<Version, Package>> _packages; 379 final Map<String, Map<Version, Package>> _packages;
379 380
380 final String name; 381 final String name;
381 bool get shouldCache => true; 382 bool get shouldCache => true;
382 383
383 MockSource(this.name) 384 MockSource(this.name)
384 : _packages = <String, Map<Version, Package>>{}; 385 : _packages = <String, Map<Version, Package>>{};
385 386
386 Future<List<Version>> getVersions(String name) { 387 Future<List<Version>> getVersions(String name, String description) {
387 return fakeAsync(() => _packages[name].getKeys()); 388 return fakeAsync(() => _packages[description].getKeys());
388 } 389 }
389 390
390 Future<Pubspec> describe(PackageId id) { 391 Future<Pubspec> describe(PackageId id) {
391 return fakeAsync(() { 392 return fakeAsync(() {
392 return _packages[id.name][id.version].pubspec; 393 return _packages[id.name][id.version].pubspec;
393 }); 394 });
394 } 395 }
395 396
396 Future<bool> install(PackageId id, String path) { 397 Future<bool> install(PackageId id, String path) {
397 throw 'no'; 398 throw 'no';
398 } 399 }
399 400
400 Package mockPackage(String description, String version, 401 Package mockPackage(String description, String version,
401 Map dependencyStrings) { 402 Map dependencyStrings) {
402 // Build the pubspec dependencies. 403 // Build the pubspec dependencies.
403 var dependencies = <PackageRef>[]; 404 var dependencies = <PackageRef>[];
404 dependencyStrings.forEach((name, constraint) { 405 dependencyStrings.forEach((name, constraint) {
405 var parsed = parseSource(name); 406 var parsed = parseSource(name);
406 dependencies.add(new PackageRef( 407 var description = parsed.first;
407 parsed.last, new VersionConstraint.parse(constraint), parsed.first)); 408 var packageName = description.replaceFirst(new RegExp(@"-[^-]+$"), "");
409 dependencies.add(new PackageRef(packageName, parsed.last,
410 new VersionConstraint.parse(constraint), description));
408 }); 411 });
409 412
410 var pubspec = new Pubspec( 413 var pubspec = new Pubspec(
411 description, new Version.parse(version), dependencies); 414 description, new Version.parse(version), dependencies);
412 return new Package.inMemory(pubspec); 415 return new Package.inMemory(pubspec);
413 } 416 }
414 417
415 void addPackage(Package package) { 418 void addPackage(Package package) {
416 _packages.putIfAbsent(package.name, () => new Map<Version, Package>()); 419 _packages.putIfAbsent(package.name, () => new Map<Version, Package>());
417 _packages[package.name][package.version] = package; 420 _packages[package.name][package.version] = package;
418 } 421 }
419
420 String packageName(String description) =>
421 description.replaceFirst(new RegExp(@"-[^-]+$"), "");
422 } 422 }
423 423
424 /** 424 /**
425 * A source used for testing that doesn't natively understand versioning, 425 * A source used for testing that doesn't natively understand versioning,
426 * similar to how the Git and SDK sources work. 426 * similar to how the Git and SDK sources work.
427 */ 427 */
428 class MockVersionlessSource extends Source { 428 class MockVersionlessSource extends Source {
429 final Map<String, Package> _packages; 429 final Map<String, Package> _packages;
430 430
431 final String name = 'versionless'; 431 final String name = 'versionless';
(...skipping 27 matching lines...) Expand all
459 Pair<String, Source> parseSource(String name) { 459 Pair<String, Source> parseSource(String name) {
460 var match = new RegExp(@"(.*) from (.*)").firstMatch(name); 460 var match = new RegExp(@"(.*) from (.*)").firstMatch(name);
461 if (match == null) return new Pair<String, Source>(name, source1); 461 if (match == null) return new Pair<String, Source>(name, source1);
462 switch (match[2]) { 462 switch (match[2]) {
463 case 'mock1': return new Pair<String, Source>(match[1], source1); 463 case 'mock1': return new Pair<String, Source>(match[1], source1);
464 case 'mock2': return new Pair<String, Source>(match[1], source2); 464 case 'mock2': return new Pair<String, Source>(match[1], source2);
465 case 'versionless': 465 case 'versionless':
466 return new Pair<String, Source>(match[1], versionlessSource); 466 return new Pair<String, Source>(match[1], versionlessSource);
467 } 467 }
468 } 468 }
OLDNEW
« no previous file with comments | « utils/tests/pub/test_pub.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698