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

Side by Side Diff: tests/standalone/io/process_stderr_test.dart

Issue 12316036: Merge IO v2 branch to bleeding edge (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Rebased to r18818 Created 7 years, 10 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) 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 // Process test program to test process communication. 5 // Process test program to test process communication.
6 // 6 //
7 // VMOptions= 7 // VMOptions=
8 // VMOptions=--short_socket_read 8 // VMOptions=--short_socket_read
9 // VMOptions=--short_socket_write 9 // VMOptions=--short_socket_write
10 // VMOptions=--short_socket_read --short_socket_write 10 // VMOptions=--short_socket_read --short_socket_write
11 11
12 import 'dart:async'; 12 import 'dart:async';
13 import 'dart:io'; 13 import 'dart:io';
14 import 'dart:math'; 14 import 'dart:math';
15 15
16 import "process_test_util.dart"; 16 import "process_test_util.dart";
17 17
18 void test(Future<Process> future, int expectedExitCode) { 18 void test(Future<Process> future, int expectedExitCode) {
19 future.then((process) { 19 future.then((process) {
20 process.onExit = (exitCode) { 20 process.exitCode.then((exitCode) {
21 Expect.equals(expectedExitCode, exitCode); 21 Expect.equals(expectedExitCode, exitCode);
22 }; 22 });
23 23
24 List<int> data = "ABCDEFGHI\n".charCodes; 24 List<int> data = "ABCDEFGHI\n".charCodes;
25 final int dataSize = data.length; 25 final int dataSize = data.length;
26 26
27 InputStream err = process.stderr;
28
29 int received = 0; 27 int received = 0;
30 List<int> buffer = []; 28 List<int> buffer = [];
31 29
32 void readData() { 30 void readData(data) {
33 buffer.addAll(err.read()); 31 buffer.addAll(data);
34 for (int i = received; 32 for (int i = received;
35 i < min(data.length, buffer.length) - 1; 33 i < min(data.length, buffer.length) - 1;
36 i++) { 34 i++) {
37 Expect.equals(data[i], buffer[i]); 35 Expect.equals(data[i], buffer[i]);
38 } 36 }
39 received = buffer.length; 37 received = buffer.length;
40 if (received >= dataSize) { 38 if (received >= dataSize) {
41 // We expect an extra character on windows due to carriage return. 39 // We expect an extra character on windows due to carriage return.
42 if (13 == buffer[dataSize - 1] && dataSize + 1 == received) { 40 if (13 == buffer[dataSize - 1] && dataSize + 1 == received) {
43 Expect.equals(13, buffer[dataSize - 1]); 41 Expect.equals(13, buffer[dataSize - 1]);
44 Expect.equals(10, buffer[dataSize]); 42 Expect.equals(10, buffer[dataSize]);
45 buffer.removeLast(); 43 buffer.removeLast();
46 } 44 }
47 } 45 }
48 } 46 }
49 47
50 process.stdout.onData = process.stdout.read; 48 process.stdout.listen((_) {});
51 process.stdin.write(data); 49 process.stdin.add(data);
52 process.stdin.close(); 50 process.stdin.close();
53 err.onData = readData; 51 process.stderr.listen(readData);
54 }); 52 });
55 } 53 }
56 54
57 main() { 55 main() {
58 // Run the test using the process_test binary. 56 // Run the test using the process_test binary.
59 test(Process.start(getProcessTestFileName(), 57 test(Process.start(getProcessTestFileName(),
60 const ["1", "1", "99", "0"]), 99); 58 const ["1", "1", "99", "0"]), 99);
61 59
62 // Run the test using the dart binary with an echo script. 60 // Run the test using the dart binary with an echo script.
63 // The test runner can be run from either the root or from runtime. 61 // The test runner can be run from either the root or from runtime.
64 var scriptFile = new File("tests/standalone/io/process_std_io_script.dart"); 62 var scriptFile = new File("tests/standalone/io/process_std_io_script.dart");
65 if (!scriptFile.existsSync()) { 63 if (!scriptFile.existsSync()) {
66 scriptFile = new File("../tests/standalone/io/process_std_io_script.dart"); 64 scriptFile = new File("../tests/standalone/io/process_std_io_script.dart");
67 } 65 }
68 Expect.isTrue(scriptFile.existsSync()); 66 Expect.isTrue(scriptFile.existsSync());
69 test(Process.start(new Options().executable, [scriptFile.name, "1"]), 0); 67 test(Process.start(new Options().executable, [scriptFile.name, "1"]), 0);
70 } 68 }
OLDNEW
« no previous file with comments | « tests/standalone/io/process_std_io_script2.dart ('k') | tests/standalone/io/process_stdout_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698