OLD | NEW |
---|---|
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 // Regression test for http://dartbug.com/7191. | 5 // Regression test for http://dartbug.com/7191. |
6 | 6 |
7 // Starts a sub-process which in turn starts another sub-process and then closes | 7 // Starts a sub-process which in turn starts another sub-process and then closes |
8 // its standard output. If handles are incorrectly inherited on Windows, this | 8 // its standard output. If handles are incorrectly inherited on Windows, this |
9 // will lead to a situation where the stdout of the first sub-process is never | 9 // will lead to a situation where the stdout of the first sub-process is never |
10 // closed which will make this test hang. | 10 // closed which will make this test hang. |
11 | 11 |
12 import 'dart:io'; | 12 import 'dart:io'; |
13 import 'dart:isolate'; | 13 import 'dart:isolate'; |
14 | 14 |
15 main() { | 15 main() { |
16 var port = new ReceivePort(); | 16 var port = new ReceivePort(); |
17 var options = new Options(); | 17 var options = new Options(); |
18 var executable = options.executable; | 18 var executable = options.executable; |
19 var scriptDir = new Path(options.script).directoryPath; | 19 var scriptDir = new Path(options.script).directoryPath; |
20 var script = scriptDir.append('regress_7191_script.dart').toNativePath(); | 20 var script = scriptDir.append('regress_7191_script.dart').toNativePath(); |
21 Process.start(executable, [script]).then((process) { | 21 Process.start(executable, [script]).then((process) { |
22 process.stdin.writeBytes([0]); | 22 process.stdin.writeBytes([0]); |
23 process.stdout.listen((_) { }, | 23 process.stdout.listen((_) { }, |
24 onDone: () { process.stdin.writeBytes([0]); }); | 24 onDone: () { process.stdin.writeBytes([0]); }); |
25 process.stderr.listen((_) { }); | 25 process.stderr.listen((_) { }); |
26 process.exitCode.then((exitCode) => port.close()); | 26 process.exitCode.then((exitCode) => port.close()); |
Mads Ager (google)
2013/04/10 06:10:38
We should add verification of the exitCode here. T
Anders Johnsen
2013/04/10 11:41:32
Yep, done in https://codereview.chromium.org/13851
| |
27 }); | 27 }); |
28 } | 28 } |
OLD | NEW |