| 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 57%
|
| copy from pkg/shelf/test/request_test.dart
|
| copy to pkg/shelf/test/message_test.dart
|
| index ce592c7c28a85eeaec4f5d1be66abb2c456e16c2..57f32c4afe0258ed661063219b4e06ed04cac819 100644
|
| --- a/pkg/shelf/test/request_test.dart
|
| +++ b/pkg/shelf/test/message_test.dart
|
| @@ -2,59 +2,56 @@
|
| // 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]) {
|
| - if (headers == null) headers = {};
|
| - return new Request("/", "", "GET", "", "1.1", Uri.parse('http://localhost/'),
|
| - headers, body: body);
|
| +class _TestMessage extends Message {
|
| + _TestMessage(Map<String, String> headers, Stream<List<int>> body)
|
| + : super(body, headers: headers);
|
| +}
|
| +
|
| +Message _createMessage({Map<String, String> headers, Stream<List<int>> body}) {
|
| + if (body == null) body = new Stream.fromIterable([]);
|
| + return new _TestMessage(headers, body);
|
| }
|
|
|
| void main() {
|
| - group("contentLength", () {
|
| - test("is null without a content-length header", () {
|
| - var request = _request();
|
| - expect(request.contentLength, isNull);
|
| - });
|
| + group('headers', () {
|
| + test('message headers are case insensitive', () {
|
| + var message = _createMessage(headers: {'foo': 'bar'});
|
|
|
| - test("comes from the content-length header", () {
|
| - var request = _request({
|
| - 'content-length': '42'
|
| - });
|
| - expect(request.contentLength, 42);
|
| + expect(message.headers, containsPair('foo', 'bar'));
|
| + expect(message.headers, containsPair('Foo', 'bar'));
|
| + expect(message.headers, containsPair('FOO', 'bar'));
|
| });
|
| - });
|
|
|
| - group("ifModifiedSince", () {
|
| - test("is null without an If-Modified-Since header", () {
|
| - var request = _request();
|
| - expect(request.ifModifiedSince, isNull);
|
| + test('null header value becomes empty, immutable', () {
|
| + var message = _createMessage();
|
| + expect(message.headers, isEmpty);
|
| + expect(() => message.headers['h1'] = 'value1', throwsUnsupportedError);
|
| });
|
|
|
| - 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")));
|
| + test('headers are immutable', () {
|
| + var message = _createMessage(headers: {'h1': 'value1'});
|
| + expect(() => message.headers['h1'] = 'value1', throwsUnsupportedError);
|
| + expect(() => message.headers['h1'] = 'value2', throwsUnsupportedError);
|
| + expect(() => message.headers['h2'] = 'value2', throwsUnsupportedError);
|
| });
|
| });
|
| -
|
| 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 +63,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 +105,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 +139,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));
|
| });
|
|
|