Chromium Code Reviews| Index: pkg/shelf/test/message_test.dart |
| diff --git a/pkg/shelf/test/request_test.dart b/pkg/shelf/test/message_test.dart |
| similarity index 66% |
| copy from pkg/shelf/test/request_test.dart |
| copy to pkg/shelf/test/message_test.dart |
| index ce592c7c28a85eeaec4f5d1be66abb2c456e16c2..2d7a01e5d17a3f6f02215d3d53c7a290abfa1a8a 100644 |
| --- a/pkg/shelf/test/request_test.dart |
| +++ b/pkg/shelf/test/message_test.dart |
| @@ -2,59 +2,38 @@ |
| // 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.request_test; |
| +library shelf.message_test; |
| import 'dart:async'; |
| import 'dart:convert'; |
| -import 'package:shelf/shelf.dart'; |
| +import 'package:shelf/src/message.dart'; |
| import 'package:unittest/unittest.dart'; |
| -Request _request([Map<String, String> headers, Stream<List<int>> body]) { |
| +Message _createMessage({Map<String, String> headers, Stream<List<int>> body}) { |
| + if (body == null) body = new Stream.fromIterable([]); |
| if (headers == null) headers = {}; |
| - return new Request("/", "", "GET", "", "1.1", Uri.parse('http://localhost/'), |
| - headers, body: body); |
| + return new Message(headers, body); |
|
nweiz
2014/04/08 20:23:09
It seems like Message should be an abstract class,
kevmoo
2014/04/08 21:41:13
Done.
|
| } |
| void main() { |
| - group("contentLength", () { |
| - test("is null without a content-length header", () { |
| - var request = _request(); |
| - expect(request.contentLength, isNull); |
| - }); |
| + test('message headers are case insensitive', () { |
| + var message = _createMessage(headers: { 'foo': 'bar' }); |
|
nweiz
2014/04/08 20:23:09
Nit: "{'foo': 'bar'}"
kevmoo
2014/04/08 21:41:13
Done.
|
| - test("comes from the content-length header", () { |
| - var request = _request({ |
| - 'content-length': '42' |
| - }); |
| - expect(request.contentLength, 42); |
| - }); |
| - }); |
| - |
| - group("ifModifiedSince", () { |
| - test("is null without an If-Modified-Since header", () { |
| - var request = _request(); |
| - expect(request.ifModifiedSince, isNull); |
| - }); |
| - |
| - test("comes from the Last-Modified header", () { |
| - var request = _request({ |
| - 'if-modified-since': 'Sun, 06 Nov 1994 08:49:37 GMT' |
| - }); |
| - expect(request.ifModifiedSince, |
| - equals(DateTime.parse("1994-11-06 08:49:37z"))); |
| - }); |
| + expect(message.headers, containsPair('foo', 'bar')); |
| + expect(message.headers, containsPair('Foo', 'bar')); |
| + expect(message.headers, containsPair('FOO', 'bar')); |
| }); |
| group("readAsString", () { |
| test("supports a null body", () { |
| - var request = _request(); |
| + var request = _createMessage(); |
| expect(request.readAsString(), completion(equals(""))); |
| }); |
| test("supports a Stream<List<int>> body", () { |
| var controller = new StreamController(); |
| - var request = _request({}, controller.stream); |
| + var request = _createMessage(body: controller.stream); |
| expect(request.readAsString(), completion(equals("hello, world"))); |
| controller.add([104, 101, 108, 108, 111, 44]); |
| @@ -66,32 +45,34 @@ void main() { |
| }); |
| test("defaults to UTF-8", () { |
| - var request = _request({}, new Stream.fromIterable([[195, 168]])); |
| + var request = _createMessage(body: new Stream.fromIterable([[195, 168]])); |
| expect(request.readAsString(), completion(equals("è"))); |
| }); |
| test("the content-type header overrides the default", () { |
| - var request = _request({'content-type': 'text/plain; charset=iso-8859-1'}, |
| - new Stream.fromIterable([[195, 168]])); |
| + var request = _createMessage( |
| + headers: {'content-type': 'text/plain; charset=iso-8859-1'}, |
| + body: new Stream.fromIterable([[195, 168]])); |
| expect(request.readAsString(), completion(equals("è"))); |
| }); |
| test("an explicit encoding overrides the content-type header", () { |
| - var request = _request({'content-type': 'text/plain; charset=iso-8859-1'}, |
| - new Stream.fromIterable([[195, 168]])); |
| + var request = _createMessage( |
| + headers: {'content-type': 'text/plain; charset=iso-8859-1'}, |
| + body: new Stream.fromIterable([[195, 168]])); |
| expect(request.readAsString(LATIN1), completion(equals("è"))); |
| }); |
| }); |
| group("read", () { |
| test("supports a null body", () { |
| - var request = _request(); |
| + var request = _createMessage(); |
| expect(request.read().toList(), completion(isEmpty)); |
| }); |
| test("supports a Stream<List<int>> body", () { |
| var controller = new StreamController(); |
| - var request = _request({}, controller.stream); |
| + var request = _createMessage(body: controller.stream); |
| expect(request.read().toList(), completion(equals([ |
| [104, 101, 108, 108, 111, 44], |
| [32, 119, 111, 114, 108, 100] |
| @@ -106,19 +87,33 @@ void main() { |
| }); |
| }); |
| + group("contentLength", () { |
| + test("is null without a content-length header", () { |
| + var request = _createMessage(); |
| + expect(request.contentLength, isNull); |
| + }); |
| + |
| + test("comes from the content-length header", () { |
| + var request = _createMessage(headers: { |
| + 'content-length': '42' |
| + }); |
| + expect(request.contentLength, 42); |
| + }); |
| + }); |
| + |
| group("mimeType", () { |
| test("is null without a content-type header", () { |
| - expect(_request().mimeType, isNull); |
| + expect(_createMessage().mimeType, isNull); |
| }); |
| test("comes from the content-type header", () { |
| - expect(_request({ |
| + expect(_createMessage(headers: { |
| 'content-type': 'text/plain' |
| }).mimeType, equals('text/plain')); |
| }); |
| test("doesn't include parameters", () { |
| - expect(_request({ |
| + expect(_createMessage(headers: { |
| 'content-type': 'text/plain; foo=bar; bar=baz' |
| }).mimeType, equals('text/plain')); |
| }); |
| @@ -126,23 +121,23 @@ void main() { |
| group("encoding", () { |
| test("is null without a content-type header", () { |
| - expect(_request().encoding, isNull); |
| + expect(_createMessage().encoding, isNull); |
| }); |
| test("is null without a charset parameter", () { |
| - expect(_request({ |
| + expect(_createMessage(headers: { |
| 'content-type': 'text/plain' |
| }).encoding, isNull); |
| }); |
| test("is null with an unrecognized charset parameter", () { |
| - expect(_request({ |
| + expect(_createMessage(headers: { |
| 'content-type': 'text/plain; charset=fblthp' |
| }).encoding, isNull); |
| }); |
| test("comes from the content-type charset parameter", () { |
| - expect(_request({ |
| + expect(_createMessage(headers: { |
| 'content-type': 'text/plain; charset=iso-8859-1' |
| }).encoding, equals(LATIN1)); |
| }); |