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

Side by Side Diff: sdk/lib/_internal/pub/test/test_pub.dart

Issue 15883003: Remove ProcessOptions and make the options named arguments. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 7 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
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, 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 /// Test infrastructure for testing pub. Unlike typical unit tests, most pub 5 /// Test infrastructure for testing pub. Unlike typical unit tests, most pub
6 /// tests are integration tests that stage some stuff on the file system, run 6 /// tests are integration tests that stage some stuff on the file system, run
7 /// pub, and then validate the results. This library provides an API to build 7 /// pub, and then validate the results. This library provides an API to build
8 /// tests like that. 8 /// tests like that.
9 library test_pub; 9 library test_pub;
10 10
(...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after
364 } 364 }
365 365
366 // Find the main pub entrypoint. 366 // Find the main pub entrypoint.
367 var pubPath = path.join(testDirectory, '..', 'bin', 'pub.dart'); 367 var pubPath = path.join(testDirectory, '..', 'bin', 'pub.dart');
368 368
369 var dartArgs = ['--package-root=$_packageRoot/', '--checked', pubPath, 369 var dartArgs = ['--package-root=$_packageRoot/', '--checked', pubPath,
370 '--verbose']; 370 '--verbose'];
371 dartArgs.addAll(args); 371 dartArgs.addAll(args);
372 372
373 if (tokenEndpoint == null) tokenEndpoint = new Future.value(); 373 if (tokenEndpoint == null) tokenEndpoint = new Future.value();
374 var optionsFuture = tokenEndpoint.then((tokenEndpoint) { 374 var environmentFuture = tokenEndpoint.then((tokenEndpoint) {
375 var options = new ProcessOptions();
376 options.workingDirectory = pathInSandbox(appPath);
377 // TODO(nweiz): remove this when issue 9294 is fixed. 375 // TODO(nweiz): remove this when issue 9294 is fixed.
378 options.environment = new Map.from(Platform.environment); 376 var environment = new Map.from(Platform.environment);
379 options.environment['_PUB_TESTING'] = 'true'; 377 environment['_PUB_TESTING'] = 'true';
380 options.environment['PUB_CACHE'] = pathInSandbox(cachePath); 378 environment['PUB_CACHE'] = pathInSandbox(cachePath);
381 options.environment['DART_SDK'] = pathInSandbox(sdkPath); 379 environment['DART_SDK'] = pathInSandbox(sdkPath);
382 if (tokenEndpoint != null) { 380 if (tokenEndpoint != null) {
383 options.environment['_PUB_TEST_TOKEN_ENDPOINT'] = 381 environment['_PUB_TEST_TOKEN_ENDPOINT'] =
384 tokenEndpoint.toString(); 382 tokenEndpoint.toString();
385 } 383 }
386 return options; 384 return environment;
387 }); 385 });
388 386
389 return new PubProcess.start(dartBin, dartArgs, options: optionsFuture, 387 return new PubProcess.start(dartBin, dartArgs, environment: environmentFuture,
388 workingDirectory: pathInSandbox(appPath),
390 description: args.isEmpty ? 'pub' : 'pub ${args.first}'); 389 description: args.isEmpty ? 'pub' : 'pub ${args.first}');
391 } 390 }
392 391
393 /// A subclass of [ScheduledProcess] that parses pub's verbose logging output 392 /// A subclass of [ScheduledProcess] that parses pub's verbose logging output
394 /// and makes [nextLine], [nextErrLine], [remainingStdout], and 393 /// and makes [nextLine], [nextErrLine], [remainingStdout], and
395 /// [remainingStderr] work as though pub weren't running in verbose mode. 394 /// [remainingStderr] work as though pub weren't running in verbose mode.
396 class PubProcess extends ScheduledProcess { 395 class PubProcess extends ScheduledProcess {
397 Stream<Pair<log.Level, String>> _log; 396 Stream<Pair<log.Level, String>> _log;
398 Stream<String> _stdout; 397 Stream<String> _stdout;
399 Stream<String> _stderr; 398 Stream<String> _stderr;
400 399
401 PubProcess.start(executable, arguments, 400 PubProcess.start(executable, arguments,
402 {options, String description, Encoding encoding: Encoding.UTF_8}) 401 {workingDirectory, environment, String description,
402 Encoding encoding: Encoding.UTF_8})
403 : super.start(executable, arguments, 403 : super.start(executable, arguments,
404 options: options, 404 workingDirectory: workingDirectory,
405 environment: environment,
405 description: description, 406 description: description,
406 encoding: encoding); 407 encoding: encoding);
407 408
408 Stream<Pair<log.Level, String>> _logStream() { 409 Stream<Pair<log.Level, String>> _logStream() {
409 if (_log == null) { 410 if (_log == null) {
410 _log = mergeStreams( 411 _log = mergeStreams(
411 _outputToLog(super.stdoutStream(), log.Level.MESSAGE), 412 _outputToLog(super.stdoutStream(), log.Level.MESSAGE),
412 _outputToLog(super.stderrStream(), log.Level.ERROR)); 413 _outputToLog(super.stderrStream(), log.Level.ERROR));
413 } 414 }
414 415
(...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after
682 bool matches(item, MatchState matchState) { 683 bool matches(item, MatchState matchState) {
683 if (item is! Pair) return false; 684 if (item is! Pair) return false;
684 return _firstMatcher.matches(item.first, matchState) && 685 return _firstMatcher.matches(item.first, matchState) &&
685 _lastMatcher.matches(item.last, matchState); 686 _lastMatcher.matches(item.last, matchState);
686 } 687 }
687 688
688 Description describe(Description description) { 689 Description describe(Description description) {
689 description.addAll("(", ", ", ")", [_firstMatcher, _lastMatcher]); 690 description.addAll("(", ", ", ")", [_firstMatcher, _lastMatcher]);
690 } 691 }
691 } 692 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698