| OLD | NEW |
| 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 | 5 |
| 6 #import("dart:isolate"); | 6 #import("dart:isolate"); |
| 7 #import("dart:io"); | 7 #import("dart:io"); |
| 8 | 8 |
| 9 void test1(int totalConnections) { | 9 void test1(int totalConnections) { |
| 10 // Server which just closes immediately. | 10 // Server which just closes immediately. |
| 11 HttpServer server = new HttpServer(); | 11 HttpServer server = new HttpServer(); |
| 12 server.listen("127.0.0.1", 0, backlog: totalConnections); | 12 server.listen("127.0.0.1", 0, backlog: totalConnections); |
| 13 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { | 13 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { |
| 14 response.outputStream.close(); | 14 response.outputStream.close(); |
| 15 }; | 15 }; |
| 16 | 16 |
| 17 int count = 0; | 17 int count = 0; |
| 18 HttpClient client = new HttpClient(); | 18 HttpClient client = new HttpClient(); |
| 19 for (int i = 0; i < totalConnections; i++) { | 19 for (int i = 0; i < totalConnections; i++) { |
| 20 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); | 20 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); |
| 21 conn.onRequest = (HttpClientRequest request) { | 21 conn.onRequest = (HttpClientRequest request) { |
| 22 request.outputStream.close(); | 22 request.outputStream.close(); |
| 23 }; | 23 }; |
| 24 conn.onResponse = (HttpClientResponse response) { | 24 conn.onResponse = (HttpClientResponse response) { |
| 25 count++; | 25 response.inputStream.onClosed = () { |
| 26 if (count == totalConnections) { | 26 count++; |
| 27 client.shutdown(); | 27 if (count == totalConnections) { |
| 28 server.close(); | 28 client.shutdown(); |
| 29 } | 29 server.close(); |
| 30 } |
| 31 }; |
| 30 }; | 32 }; |
| 31 } | 33 } |
| 32 } | 34 } |
| 33 | 35 |
| 34 | 36 |
| 35 void test2(int totalConnections) { | 37 void test2(int totalConnections) { |
| 36 // Server which responds without waiting for request body. | 38 // Server which responds without waiting for request body. |
| 37 HttpServer server = new HttpServer(); | 39 HttpServer server = new HttpServer(); |
| 38 server.listen("127.0.0.1", 0, backlog: totalConnections); | 40 server.listen("127.0.0.1", 0, backlog: totalConnections); |
| 39 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { | 41 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { |
| 40 response.outputStream.writeString("!dlrow ,olleH"); | 42 response.outputStream.writeString("!dlrow ,olleH"); |
| 41 response.outputStream.close(); | 43 response.outputStream.close(); |
| 42 }; | 44 }; |
| 43 | 45 |
| 44 int count = 0; | 46 int count = 0; |
| 45 HttpClient client = new HttpClient(); | 47 HttpClient client = new HttpClient(); |
| 46 for (int i = 0; i < totalConnections; i++) { | 48 for (int i = 0; i < totalConnections; i++) { |
| 47 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); | 49 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); |
| 48 conn.onRequest = (HttpClientRequest request) { | 50 conn.onRequest = (HttpClientRequest request) { |
| 49 request.contentLength = -1; | 51 request.contentLength = -1; |
| 50 request.outputStream.writeString("Hello, world!"); | 52 request.outputStream.writeString("Hello, world!"); |
| 51 request.outputStream.close(); | 53 request.outputStream.close(); |
| 52 }; | 54 }; |
| 53 conn.onResponse = (HttpClientResponse response) { | 55 conn.onResponse = (HttpClientResponse response) { |
| 54 count++; | 56 response.inputStream.onData = response.inputStream.read; |
| 55 if (count == totalConnections) { | 57 response.inputStream.onClosed = () { |
| 56 client.shutdown(); | 58 count++; |
| 57 server.close(); | 59 if (count == totalConnections) { |
| 58 } | 60 client.shutdown(); |
| 61 server.close(); |
| 62 } |
| 63 }; |
| 59 }; | 64 }; |
| 60 } | 65 } |
| 61 } | 66 } |
| 62 | 67 |
| 63 | 68 |
| 64 void test3(int totalConnections) { | 69 void test3(int totalConnections) { |
| 65 // Server which responds when request body has been received. | 70 // Server which responds when request body has been received. |
| 66 HttpServer server = new HttpServer(); | 71 HttpServer server = new HttpServer(); |
| 67 server.listen("127.0.0.1", 0, backlog: totalConnections); | 72 server.listen("127.0.0.1", 0, backlog: totalConnections); |
| 68 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { | 73 server.defaultRequestHandler = (HttpRequest request, HttpResponse response) { |
| 69 request.inputStream.onData = () { | 74 request.inputStream.onData = () { |
| 70 request.inputStream.read(); | 75 request.inputStream.read(); |
| 71 }; | 76 }; |
| 72 request.inputStream.onClosed = () { | 77 request.inputStream.onClosed = () { |
| 73 response.outputStream.writeString("!dlrow ,olleH"); | 78 response.outputStream.writeString("!dlrow ,olleH"); |
| 74 response.outputStream.close(); | 79 response.outputStream.close(); |
| 75 }; | 80 }; |
| 76 }; | 81 }; |
| 77 | 82 |
| 78 int count = 0; | 83 int count = 0; |
| 79 HttpClient client = new HttpClient(); | 84 HttpClient client = new HttpClient(); |
| 80 for (int i = 0; i < totalConnections; i++) { | 85 for (int i = 0; i < totalConnections; i++) { |
| 81 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); | 86 HttpClientConnection conn = client.get("127.0.0.1", server.port, "/"); |
| 82 conn.onRequest = (HttpClientRequest request) { | 87 conn.onRequest = (HttpClientRequest request) { |
| 83 request.contentLength = -1; | 88 request.contentLength = -1; |
| 84 request.outputStream.writeString("Hello, world!"); | 89 request.outputStream.writeString("Hello, world!"); |
| 85 request.outputStream.close(); | 90 request.outputStream.close(); |
| 86 }; | 91 }; |
| 87 conn.onResponse = (HttpClientResponse response) { | 92 conn.onResponse = (HttpClientResponse response) { |
| 88 count++; | 93 response.inputStream.onData = response.inputStream.read; |
| 89 if (count == totalConnections) { | 94 response.inputStream.onClosed = () { |
| 90 client.shutdown(); | 95 count++; |
| 91 server.close(); | 96 if (count == totalConnections) { |
| 92 } | 97 client.shutdown(); |
| 98 server.close(); |
| 99 } |
| 100 }; |
| 93 }; | 101 }; |
| 94 } | 102 } |
| 95 } | 103 } |
| 96 | 104 |
| 97 | 105 |
| 98 void test4() { | 106 void test4() { |
| 99 var server = new HttpServer(); | 107 var server = new HttpServer(); |
| 100 server.listen("127.0.0.1", 0); | 108 server.listen("127.0.0.1", 0); |
| 101 server.defaultRequestHandler = (var request, var response) { | 109 server.defaultRequestHandler = (var request, var response) { |
| 102 request.inputStream.onClosed = () { | 110 request.inputStream.onClosed = () { |
| 103 new Timer.repeating(100, (timer) { | 111 new Timer.repeating(100, (timer) { |
| 104 if (server.connectionsInfo().total == 0) { | 112 if (server.connectionsInfo().total == 0) { |
| 105 server.close(); | 113 server.close(); |
| 106 timer.cancel(); | 114 timer.cancel(); |
| 107 } | 115 } |
| 108 }); | 116 }); |
| 109 response.outputStream.close(); | 117 response.outputStream.close(); |
| 110 }; | 118 }; |
| 111 }; | 119 }; |
| 112 | 120 |
| 113 var client= new HttpClient(); | 121 var client= new HttpClient(); |
| 114 var conn = client.get("127.0.0.1", server.port, "/"); | 122 var conn = client.get("127.0.0.1", server.port, "/"); |
| 115 conn.onResponse = (var response) { | 123 conn.onResponse = (var response) { |
| 124 response.inputStream.onData = response.inputStream.read; |
| 116 response.inputStream.onClosed = () { | 125 response.inputStream.onClosed = () { |
| 117 client.shutdown(); | 126 client.shutdown(); |
| 118 }; | 127 }; |
| 119 }; | 128 }; |
| 120 } | 129 } |
| 121 | 130 |
| 122 | 131 |
| 123 void test5(int totalConnections) { | 132 void test5(int totalConnections) { |
| 124 var server = new HttpServer(); | 133 var server = new HttpServer(); |
| 125 server.listen("127.0.0.1", 0, backlog: totalConnections); | 134 server.listen("127.0.0.1", 0, backlog: totalConnections); |
| 126 server.defaultRequestHandler = (var request, var response) { | 135 server.defaultRequestHandler = (var request, var response) { |
| 127 request.inputStream.onClosed = () { | 136 request.inputStream.onClosed = () { |
| 128 response.outputStream.close(); | 137 response.outputStream.close(); |
| 129 }; | 138 }; |
| 130 }; | 139 }; |
| 131 server.onError = (e) => { }; | 140 server.onError = (e) => { }; |
| 132 | 141 |
| 133 // Create a number of client requests and keep then active. Then | 142 // Create a number of client requests and keep then active. Then |
| 134 // close the client and wait for the server to lose all active | 143 // close the client and wait for the server to lose all active |
| 135 // connections. | 144 // connections. |
| 136 var client= new HttpClient(); | 145 var client= new HttpClient(); |
| 137 for (int i = 0; i < totalConnections; i++) { | 146 for (int i = 0; i < totalConnections; i++) { |
| 138 var conn = client.post("127.0.0.1", server.port, "/"); | 147 var conn = client.post("127.0.0.1", server.port, "/"); |
| 139 conn.onRequest = (req) { req.outputStream.write([0]); }; | 148 conn.onRequest = (req) { req.outputStream.write([0]); }; |
| 149 conn.onError = (e) => Expect.isTrue(e is HttpException); |
| 140 } | 150 } |
| 141 bool clientClosed = false; | 151 bool clientClosed = false; |
| 142 new Timer.repeating(100, (timer) { | 152 new Timer.repeating(100, (timer) { |
| 143 if (!clientClosed) { | 153 if (!clientClosed) { |
| 144 if (server.connectionsInfo().total == totalConnections) { | 154 if (server.connectionsInfo().total == totalConnections) { |
| 145 clientClosed = true; | 155 clientClosed = true; |
| 146 client.shutdown(); | 156 client.shutdown(force: true); |
| 147 } | 157 } |
| 148 } else { | 158 } else { |
| 149 if (server.connectionsInfo().total == 0) { | 159 if (server.connectionsInfo().total == 0) { |
| 150 server.close(); | 160 server.close(); |
| 151 timer.cancel(); | 161 timer.cancel(); |
| 152 } | 162 } |
| 153 } | 163 } |
| 154 }); | 164 }); |
| 155 } | 165 } |
| 156 | 166 |
| 157 | 167 |
| 158 void main() { | 168 void main() { |
| 159 test1(1); | 169 test1(1); |
| 160 test1(10); | 170 test1(10); |
| 161 test2(1); | 171 test2(1); |
| 162 test2(10); | 172 test2(10); |
| 163 test3(1); | 173 test3(1); |
| 164 test3(10); | 174 test3(10); |
| 165 test4(); | 175 test4(); |
| 166 test5(1); | 176 test5(1); |
| 167 test5(10); | 177 test5(10); |
| 168 } | 178 } |
| OLD | NEW |