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

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

Issue 14150002: Remove StreamSink(replaced by EventSink) and make IOSink extend EventSink. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 8 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 // VMOptions= 5 // VMOptions=
6 // VMOptions=--short_socket_read 6 // VMOptions=--short_socket_read
7 // VMOptions=--short_socket_write 7 // VMOptions=--short_socket_write
8 // VMOptions=--short_socket_read --short_socket_write 8 // VMOptions=--short_socket_read --short_socket_write
9 9
10 import "package:expect/expect.dart"; 10 import "package:expect/expect.dart";
11 import "dart:async"; 11 import "dart:async";
12 import "dart:io"; 12 import "dart:io";
13 import "dart:isolate"; 13 import "dart:isolate";
14 14
15 const SERVER_ADDRESS = "127.0.0.1"; 15 const SERVER_ADDRESS = "127.0.0.1";
16 const HOST_NAME = "localhost"; 16 const HOST_NAME = "localhost";
17 const CERTIFICATE = "localhost_cert"; 17 const CERTIFICATE = "localhost_cert";
18 Future<SecureServerSocket> startServer() { 18 Future<SecureServerSocket> startServer() {
19 return SecureServerSocket.bind(SERVER_ADDRESS, 19 return SecureServerSocket.bind(SERVER_ADDRESS,
20 0, 20 0,
21 5, 21 5,
22 CERTIFICATE).then((server) { 22 CERTIFICATE).then((server) {
23 server.listen((SecureSocket client) { 23 server.listen((SecureSocket client) {
24 client.fold(<int>[], (message, data) => message..addAll(data)) 24 client.fold(<int>[], (message, data) => message..addAll(data))
25 .then((message) { 25 .then((message) {
26 String received = new String.fromCharCodes(message); 26 String received = new String.fromCharCodes(message);
27 Expect.isTrue(received.contains("Hello from client ")); 27 Expect.isTrue(received.contains("Hello from client "));
28 String name = received.substring(received.indexOf("client ") + 7); 28 String name = received.substring(received.indexOf("client ") + 7);
29 client.writeBytes("Welcome, client $name".codeUnits); 29 client.add("Welcome, client $name".codeUnits);
30 client.close(); 30 client.close();
31 }); 31 });
32 }); 32 });
33 return server; 33 return server;
34 }); 34 });
35 } 35 }
36 36
37 Future testClient(server, name) { 37 Future testClient(server, name) {
38 return SecureSocket.connect(HOST_NAME, server.port).then((socket) { 38 return SecureSocket.connect(HOST_NAME, server.port).then((socket) {
39 socket.writeBytes("Hello from client $name".codeUnits); 39 socket.add("Hello from client $name".codeUnits);
40 socket.close(); 40 socket.close();
41 return socket.fold(<int>[], (message, data) => message..addAll(data)) 41 return socket.fold(<int>[], (message, data) => message..addAll(data))
42 .then((message) { 42 .then((message) {
43 Expect.listEquals("Welcome, client $name".codeUnits, message); 43 Expect.listEquals("Welcome, client $name".codeUnits, message);
44 return server; 44 return server;
45 }); 45 });
46 }); 46 });
47 } 47 }
48 48
49 void main() { 49 void main() {
50 Path scriptDir = new Path(new Options().script).directoryPath; 50 Path scriptDir = new Path(new Options().script).directoryPath;
51 Path certificateDatabase = scriptDir.append('pkcert'); 51 Path certificateDatabase = scriptDir.append('pkcert');
52 SecureSocket.initialize(database: certificateDatabase.toNativePath(), 52 SecureSocket.initialize(database: certificateDatabase.toNativePath(),
53 password: 'dartdart'); 53 password: 'dartdart');
54 54
55 startServer() 55 startServer()
56 .then((server) => Future.wait( 56 .then((server) => Future.wait(
57 ['able', 'baker', 'charlie', 'dozen', 'elapse'] 57 ['able', 'baker', 'charlie', 'dozen', 'elapse']
58 .map((name) => testClient(server, name)))) 58 .map((name) => testClient(server, name))))
59 .then((servers) => servers.first.close()); 59 .then((servers) => servers.first.close());
60 } 60 }
OLDNEW
« no previous file with comments | « tests/standalone/io/secure_client_server_test.dart ('k') | tests/standalone/io/secure_server_socket_test.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698