Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 library scheduled_test.scheduled_server; | 5 library scheduled_test.scheduled_server; |
| 6 | 6 |
| 7 import 'dart:async'; | 7 import 'dart:async'; |
| 8 import 'dart:collection'; | 8 import 'dart:collection'; |
| 9 import 'dart:io'; | 9 import 'dart:io'; |
| 10 | 10 |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 84 }, "'$description' waiting for $method $path"); | 84 }, "'$description' waiting for $method $path"); |
| 85 } | 85 } |
| 86 | 86 |
| 87 /// The handler for incoming [HttpRequest]s to this server. This dispatches | 87 /// The handler for incoming [HttpRequest]s to this server. This dispatches |
| 88 /// the request to the first handler in the queue. It's that handler's | 88 /// the request to the first handler in the queue. It's that handler's |
| 89 /// responsibility to check that the method/path are correct and that it's | 89 /// responsibility to check that the method/path are correct and that it's |
| 90 /// being run at the correct time. | 90 /// being run at the correct time. |
| 91 void _handleRequest(HttpRequest request) { | 91 void _handleRequest(HttpRequest request) { |
| 92 wrapFuture(new Future.sync(() { | 92 wrapFuture(new Future.sync(() { |
| 93 if (_handlers.isEmpty) { | 93 if (_handlers.isEmpty) { |
| 94 throw "'$description' received ${request.method} ${request.uri.path} " | 94 throw new ScheduledServerError( |
| 95 "when no more requests were expected."; | 95 "'$description' received ${request.method} ${request.uri.path} " |
| 96 "when no more requests were expected."); | |
| 96 } | 97 } |
| 97 return _handlers.removeFirst().fn(request); | 98 return _handlers.removeFirst().fn(request); |
| 98 }).catchError((e) { | 99 }).catchError((e) { |
| 99 // Close the server so that we don't leave a dangling request. | 100 // Close the server so that we don't leave a dangling request. |
| 100 _server.then((s) => s.close()); | 101 _server.then((s) => s.close()); |
| 101 throw e; | 102 throw e; |
| 102 }), 'receiving ${request.method} ${request.uri}'); | 103 }), 'receiving ${request.method} ${request.uri}'); |
| 103 } | 104 } |
| 104 } | 105 } |
| 106 | |
| 107 | |
| 108 class ScheduledServerError extends Error { | |
|
nweiz
2013/09/19 19:56:14
I'm not a fan of using a custom error class here.
Bill Hesse
2013/09/20 13:30:20
Done.
| |
| 109 final String message; | |
| 110 | |
| 111 ScheduledServerError(String this.message); | |
| 112 | |
| 113 String toString() => 'ScheduledServerError: $message'; | |
| 114 } | |
| OLD | NEW |