| commit | 70118d20b3c76b78f3da571b54e89bf65f10e014 | [log] [tgz] | 
|---|---|---|
| author | Kevin Moore <kevmoo@google.com> | Tue Jun 26 09:47:52 2018 -0700 | 
| committer | Kevin Moore <kevmoo@users.noreply.github.com> | Tue Jun 26 10:04:54 2018 -0700 | 
| tree | 0e79753dd3b33ad549ec106f018747fb8fbf2099 | |
| parent | b192781e1f056c93592540f1477292b852f114d9 [diff] | 
misc: support lastest pkg:test in dev_dependencies
Contains utilities for the Dart VM's dart:io.
NOTE: Due to the changing nature of the Dart SDK (towards 2.0.0), running
dartfmtrequires the local executable:
$ pub run dart_style:format
io.dartisExecutableReturns whether a provided file path is considered executable on the host operating system.
ExitCodeAn enum-like class that contains known exit codes.
ProcessManagerA higher-level service for spawning and communicating with processes.
spawn to create a process with std[in|out|err] forwarded by default/// Runs `dartfmt` commands and `pub publish`. Future<Null> main() async { final manager = new ProcessManager(); // Runs dartfmt --version and outputs the result via stdout. print('Running dartfmt --version'); var spawn = await manager.spawn('dartfmt', ['--version']); await spawn.exitCode; // Runs dartfmt -n . and outputs the result via stdout. print('Running dartfmt -n .'); spawn = await manager.spawn('dartfmt', ['-n', '.']); await spawn.exitCode; // Runs pub publish. Upon hitting a blocking stdin state, you may directly // output to the processes's stdin via your own, similar to how a bash or // shell script would spawn a process. print('Running pub publish'); spawn = await manager.spawn('pub', ['publish']); await spawn.exitCode; // Closes stdin for the entire program. await sharedStdIn.terminate(); }
sharedStdInA safer version of the default stdin stream from dart:io that allows a subscriber to cancel their subscription, and then allows a new subscriber to start listening. This differs from the default behavior where only a single listener is ever allowed in the application lifecycle:
test('should allow multiple subscribers', () async { final logs = <String>[]; final asUtf8 = sharedStdIn.transform(UTF8.decoder); // Wait for input for the user. logs.add(await asUtf8.first); // Wait for more input for the user. logs.add(await asUtf8.first); expect(logs, ['Hello World', 'Goodbye World']); });
For testing, an instance of SharedStdIn may be created directly.
ansi.dartimport 'dart:io' as io; import 'package:io/ansi.dart'; void main() { // To use one style, call the `wrap` method on one of the provided top-level // values. io.stderr.writeln(red.wrap("Bad error!")); // To use multiple styles, call `wrapWith`. print(wrapWith('** Important **', [red, styleBold, styleUnderlined])); // The wrap functions will simply return the provided value unchanged if // `ansiOutputEnabled` is false. // // You can override the value `ansiOutputEnabled` by wrapping code in // `overrideAnsiOutput`. overrideAnsiOutput(false, () { assert('Normal text' == green.wrap('Normal text')); }); }