| Index: pkg/shelf/test/log_middleware_test.dart
|
| diff --git a/pkg/shelf/test/log_middleware_test.dart b/pkg/shelf/test/log_middleware_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d8da8fa028b60533084c87770483a3aaf5786c77
|
| --- /dev/null
|
| +++ b/pkg/shelf/test/log_middleware_test.dart
|
| @@ -0,0 +1,61 @@
|
| +// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +
|
| +library shelf.log_middleware_test;
|
| +
|
| +import 'package:shelf/shelf.dart';
|
| +import 'package:unittest/unittest.dart';
|
| +
|
| +import 'test_util.dart';
|
| +
|
| +void main() {
|
| + bool gotLog;
|
| +
|
| + setUp(() {
|
| + gotLog = false;
|
| + });
|
| +
|
| + var logger = (msg, isError) {
|
| + expect(gotLog, isFalse);
|
| + gotLog = true;
|
| + expect(isError, isFalse);
|
| + expect(msg, contains('GET'));
|
| + expect(msg, contains('[200]'));
|
| + };
|
| +
|
| + test('logs a request with a synchronous response', () {
|
| + var handler = const Stack()
|
| + .addMiddleware(logRequests(logger: logger))
|
| + .addHandler(syncHandler);
|
| +
|
| + return makeSimpleRequest(handler).then((response) {
|
| + expect(gotLog, isTrue);
|
| + });
|
| + });
|
| +
|
| + test('logs a request with an asynchronous response', () {
|
| + var handler = const Stack()
|
| + .addMiddleware(logRequests(logger: logger))
|
| + .addHandler(asyncHandler);
|
| +
|
| + return makeSimpleRequest(handler).then((response) {
|
| + expect(gotLog, isTrue);
|
| + });
|
| + });
|
| +
|
| + test('logs a request with an asynchronous response', () {
|
| + var handler = const Stack()
|
| + .addMiddleware(logRequests(logger: (msg, isError) {
|
| + expect(gotLog, isFalse);
|
| + gotLog = true;
|
| + expect(isError, isTrue);
|
| + expect(msg, contains('\tGET\t/'));
|
| + expect(msg, contains('testing logging throw'));
|
| + })).addHandler((request) {
|
| + throw 'testing logging throw';
|
| + });
|
| +
|
| + expect(makeSimpleRequest(handler), throwsA('testing logging throw'));
|
| + });
|
| +}
|
|
|