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

Side by Side Diff: pkg/http_multi_server/test/http_multi_server_test.dart

Issue 311233004: Add an http_multi_server package. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 6 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
(Empty)
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
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.
4
5 library http_multi_server.test;
6
7 import 'dart:async';
8 import 'dart:io';
9
10 import 'package:http/http.dart' as http;
11 import 'package:http_multi_server/http_multi_server.dart';
12 import 'package:http_multi_server/src/utils.dart';
13 import 'package:unittest/unittest.dart';
14
15 void main() {
16 group("with multiple HttpServers", () {
17 var multiServer;
18 var subServer1;
19 var subServer2;
20 var subServer3;
21 setUp(() {
22 return Future.wait([
23 HttpServer.bind("127.0.0.1", 0).then((server) {
24 subServer1 = server;
25 return server;
26 }),
Bob Nystrom 2014/06/04 23:58:17 You could just do: .then((server) => subServer1 =
nweiz 2014/06/05 00:36:09 Done.
27 HttpServer.bind("127.0.0.1", 0).then((server) {
28 subServer2 = server;
29 return server;
30 }),
31 HttpServer.bind("127.0.0.1", 0).then((server) {
32 subServer3 = server;
33 return server;
34 })
35 ]).then((servers) => multiServer = new HttpMultiServer(servers));
36 });
37
38 tearDown(() => multiServer.close());
39
40 test("listen listens to all servers", () {
41 multiServer.listen((request) {
42 request.response.write("got request");
43 request.response.close();
44 });
45
46 expect(_read(subServer1), completion(equals("got request")));
47 expect(_read(subServer2), completion(equals("got request")));
48 expect(_read(subServer3), completion(equals("got request")));
49 });
50
51 test("serverHeader= sets the value for all servers", () {
52 multiServer.serverHeader = "http_multi_server test";
53
54 multiServer.listen((request) {
55 request.response.write("got request");
56 request.response.close();
57 });
58
59 expect(_get(subServer1).then((response) {
60 expect(response.headers['server'], equals("http_multi_server test"));
61 }), completes);
62
63 expect(_get(subServer2).then((response) {
64 expect(response.headers['server'], equals("http_multi_server test"));
65 }), completes);
66
67 expect(_get(subServer3).then((response) {
68 expect(response.headers['server'], equals("http_multi_server test"));
69 }), completes);
70 });
71
72 test("connectionsInfo sums the values for all servers", () {
73 var pendingRequests = 0;
74 var awaitingResponseCompleter = new Completer();
75 var sendResponseCompleter = new Completer();
76 multiServer.listen((request) {
77 sendResponseCompleter.future.then((_) {
78 request.response.write("got request");
79 request.response.close();
80 });
81
82 pendingRequests++;
83 if (pendingRequests == 2) awaitingResponseCompleter.complete();
84 });
85
86 // Queue up some requests, then wait to make sure they're
Bob Nystrom 2014/06/04 23:58:17 Don't leave me hanging!
nweiz 2014/06/05 00:36:09 Done.
87 expect(_get(subServer1), completes);
88 expect(_get(subServer2), completes);
89
90 return awaitingResponseCompleter.future.then((_) {
91 var info = multiServer.connectionsInfo();
92 expect(info.total, equals(2));
93 expect(info.active, equals(2));
94 expect(info.idle, equals(0));
95 expect(info.closing, equals(0));
96
97 sendResponseCompleter.complete();
98 });
99 });
100 });
101
102 group("HttpMultiServer.loopback", () {
103 var server;
104 setUp(() {
105 return HttpMultiServer.loopback(0).then((server_) => server = server_);
106 });
107
108 tearDown(() => server.close());
109
110 test("listens on all localhost interfaces", () {
111 server.listen((request) {
112 request.response.write("got request");
113 request.response.close();
114 });
115
116 expect(http.read("http://127.0.0.1:${server.port}/"),
117 completion(equals("got request")));
118
119 return supportsIpV6.then((supportsIpV6) {
Bob Nystrom 2014/06/04 23:58:17 I'm iffy about this check. It's possible for us to
nweiz 2014/06/05 00:36:09 I really don't want to be in the business of maint
120 if (!supportsIpV6) return;
121 expect(http.read("http://[::1]:${server.port}/"),
122 completion(equals("got request")));
123 });
124 });
125 });
126 }
127
128 /// Makes a GET request to the root of [server] and returns the response.
129 Future<http.Response> _get(HttpServer server) => http.get(_urlFor(server));
130
131 /// Makes a GET request to the root of [server] and returns the response body.
132 Future<String> _read(HttpServer server) => http.read(_urlFor(server));
133
134 /// Returns the URL for the root of [server].
135 String _urlFor(HttpServer server) =>
136 "http://${server.address.host}:${server.port}/";
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698