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

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

Issue 11783009: Big merge from experimental to bleeding edge. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 11 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 // Echo server test program for testing sockets. 5 // Echo server test program for testing sockets.
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
(...skipping 12 matching lines...) Expand all
23 23
24 class EchoServerGame { 24 class EchoServerGame {
25 25
26 static const MSGSIZE = 10; 26 static const MSGSIZE = 10;
27 static const MESSAGES = 100; 27 static const MESSAGES = 100;
28 static const FIRSTCHAR = 65; 28 static const FIRSTCHAR = 65;
29 29
30 EchoServerGame.start() 30 EchoServerGame.start()
31 : _receivePort = new ReceivePort(), 31 : _receivePort = new ReceivePort(),
32 _sendPort = null, 32 _sendPort = null,
33 _buffer = new List<int>(MSGSIZE), 33 _buffer = new List<int>.fixedLength(MSGSIZE),
34 _messages = 0 { 34 _messages = 0 {
35 for (int i = 0; i < MSGSIZE; i++) { 35 for (int i = 0; i < MSGSIZE; i++) {
36 _buffer[i] = FIRSTCHAR + i; 36 _buffer[i] = FIRSTCHAR + i;
37 } 37 }
38 _sendPort = spawnFunction(startEchoServer); 38 _sendPort = spawnFunction(startEchoServer);
39 initialize(); 39 initialize();
40 } 40 }
41 41
42 void sendData() { 42 void sendData() {
43 Socket _socket; 43 Socket _socket;
44 44
45 void messageHandler() { 45 void messageHandler() {
46 46
47 List<int> bufferReceived = new List<int>(MSGSIZE); 47 List<int> bufferReceived = new List<int>.fixedLength(MSGSIZE);
48 int bytesRead = 0; 48 int bytesRead = 0;
49 49
50 void handleRead() { 50 void handleRead() {
51 bytesRead += _socket.readList( 51 bytesRead += _socket.readList(
52 bufferReceived, bytesRead, MSGSIZE - bytesRead); 52 bufferReceived, bytesRead, MSGSIZE - bytesRead);
53 if (bytesRead < MSGSIZE) { 53 if (bytesRead < MSGSIZE) {
54 // We check every time the whole buffer to verify data integrity. 54 // We check every time the whole buffer to verify data integrity.
55 for (int i = 0; i < bytesRead; i++) { 55 for (int i = 0; i < bytesRead; i++) {
56 Expect.equals(FIRSTCHAR + i, bufferReceived[i]); 56 Expect.equals(FIRSTCHAR + i, bufferReceived[i]);
57 } 57 }
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after
134 } 134 }
135 135
136 class EchoServer extends TestingServer { 136 class EchoServer extends TestingServer {
137 137
138 static const msgSize = EchoServerGame.MSGSIZE; 138 static const msgSize = EchoServerGame.MSGSIZE;
139 139
140 void onConnection(Socket connection) { 140 void onConnection(Socket connection) {
141 141
142 void messageHandler() { 142 void messageHandler() {
143 143
144 List<int> buffer = new List<int>(msgSize); 144 List<int> buffer = new List<int>.fixedLength(msgSize);
145 int bytesRead = 0; 145 int bytesRead = 0;
146 146
147 void handleRead() { 147 void handleRead() {
148 int read = connection.readList(buffer, bytesRead, msgSize - bytesRead); 148 int read = connection.readList(buffer, bytesRead, msgSize - bytesRead);
149 if (read > 0) { 149 if (read > 0) {
150 bytesRead += read; 150 bytesRead += read;
151 if (bytesRead < msgSize) { 151 if (bytesRead < msgSize) {
152 // We check every time the whole buffer to verify data integrity. 152 // We check every time the whole buffer to verify data integrity.
153 for (int i = 0; i < bytesRead; i++) { 153 for (int i = 0; i < bytesRead; i++) {
154 Expect.equals(EchoServerGame.FIRSTCHAR + i, buffer[i]); 154 Expect.equals(EchoServerGame.FIRSTCHAR + i, buffer[i]);
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after
194 194
195 connection.onData = messageHandler; 195 connection.onData = messageHandler;
196 connection.onClosed = closeHandler; 196 connection.onClosed = closeHandler;
197 connection.onError = errorHandler; 197 connection.onError = errorHandler;
198 } 198 }
199 } 199 }
200 200
201 main() { 201 main() {
202 EchoServerTest.testMain(); 202 EchoServerTest.testMain();
203 } 203 }
OLDNEW
« no previous file with comments | « tests/standalone/io/echo_server_stream_test.dart ('k') | tests/standalone/io/file_error_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698