| Index: mojo/public/dart/third_party/shelf/test/request_test.dart
|
| diff --git a/mojo/public/dart/third_party/shelf/test/request_test.dart b/mojo/public/dart/third_party/shelf/test/request_test.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d7d20311911ddac05075ad2592946b431dea9833
|
| --- /dev/null
|
| +++ b/mojo/public/dart/third_party/shelf/test/request_test.dart
|
| @@ -0,0 +1,308 @@
|
| +// 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.request_test;
|
| +
|
| +import 'dart:async';
|
| +import 'dart:convert';
|
| +
|
| +import 'package:shelf/shelf.dart';
|
| +import 'package:test/test.dart';
|
| +
|
| +import 'test_util.dart';
|
| +
|
| +Request _request({Map<String, String> headers, body, Encoding encoding}) {
|
| + return new Request("GET", LOCALHOST_URI,
|
| + headers: headers, body: body, encoding: encoding);
|
| +}
|
| +
|
| +void main() {
|
| + group('constructor', () {
|
| + test('protocolVersion defaults to "1.1"', () {
|
| + var request = new Request('GET', LOCALHOST_URI);
|
| + expect(request.protocolVersion, '1.1');
|
| + });
|
| +
|
| + test('provide non-default protocolVersion', () {
|
| + var request = new Request('GET', LOCALHOST_URI, protocolVersion: '1.0');
|
| + expect(request.protocolVersion, '1.0');
|
| + });
|
| +
|
| + group("url", () {
|
| + test("defaults to the requestedUri's relativized path and query", () {
|
| + var request =
|
| + new Request('GET', Uri.parse("http://localhost/foo/bar?q=1"));
|
| + expect(request.url, equals(Uri.parse("foo/bar?q=1")));
|
| + });
|
| +
|
| + test("is inferred from handlerPath if possible", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + handlerPath: '/foo/');
|
| + expect(request.url, equals(Uri.parse("bar?q=1")));
|
| + });
|
| +
|
| + test("uses the given value if passed", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + url: Uri.parse("bar?q=1"));
|
| + expect(request.url, equals(Uri.parse("bar?q=1")));
|
| + });
|
| +
|
| + test("may be empty", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar"),
|
| + url: Uri.parse(""));
|
| + expect(request.url, equals(Uri.parse("")));
|
| + });
|
| + });
|
| +
|
| + group("handlerPath", () {
|
| + test("defaults to '/'", () {
|
| + var request = new Request('GET', Uri.parse("http://localhost/foo/bar"));
|
| + expect(request.handlerPath, equals('/'));
|
| + });
|
| +
|
| + test("is inferred from url if possible", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + url: Uri.parse("bar?q=1"));
|
| + expect(request.handlerPath, equals("/foo/"));
|
| + });
|
| +
|
| + test("uses the given value if passed", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + handlerPath: '/foo/');
|
| + expect(request.handlerPath, equals("/foo/"));
|
| + });
|
| +
|
| + test("adds a trailing slash to the given value if necessary", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + handlerPath: '/foo');
|
| + expect(request.handlerPath, equals("/foo/"));
|
| + expect(request.url, equals(Uri.parse("bar?q=1")));
|
| + });
|
| +
|
| + test("may be a single slash", () {
|
| + var request = new Request(
|
| + 'GET', Uri.parse("http://localhost/foo/bar?q=1"),
|
| + handlerPath: '/');
|
| + expect(request.handlerPath, equals("/"));
|
| + expect(request.url, equals(Uri.parse("foo/bar?q=1")));
|
| + });
|
| + });
|
| +
|
| + group("errors", () {
|
| + group('requestedUri', () {
|
| + test('must be absolute', () {
|
| + expect(() => new Request('GET', Uri.parse('/path')),
|
| + throwsArgumentError);
|
| + });
|
| +
|
| + test('may not have a fragment', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/#fragment'));
|
| + }, throwsArgumentError);
|
| + });
|
| + });
|
| +
|
| + group('url', () {
|
| + test('must be relative', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test'),
|
| + url: Uri.parse('http://localhost/test'));
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('may not be root-relative', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test'),
|
| + url: Uri.parse('/test'));
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('may not have a fragment', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test'),
|
| + url: Uri.parse('test#fragment'));
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('must be a suffix of requestedUri', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/dir/test'),
|
| + url: Uri.parse('dir'));
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('must have the same query parameters as requestedUri', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test?q=1&r=2'),
|
| + url: Uri.parse('test?q=2&r=1'));
|
| + }, throwsArgumentError);
|
| +
|
| + // Order matters for query parameters.
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test?q=1&r=2'),
|
| + url: Uri.parse('test?r=2&q=1'));
|
| + }, throwsArgumentError);
|
| + });
|
| + });
|
| +
|
| + group('handlerPath', () {
|
| + test('must be a prefix of requestedUri', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/dir/test'),
|
| + handlerPath: '/test');
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('must start with "/"', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test'),
|
| + handlerPath: 'test');
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('must be the requestedUri path if url is empty', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/test'),
|
| + handlerPath: '/',
|
| + url: Uri.parse(''));
|
| + }, throwsArgumentError);
|
| + });
|
| + });
|
| +
|
| + group('handlerPath + url must', () {
|
| + test('be requestedUrl path', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/foo/bar/baz'),
|
| + handlerPath: '/foo/', url: Uri.parse('baz'));
|
| + }, throwsArgumentError);
|
| + });
|
| +
|
| + test('be on a path boundary', () {
|
| + expect(() {
|
| + new Request('GET', Uri.parse('http://localhost/foo/bar/baz'),
|
| + handlerPath: '/foo/ba', url: Uri.parse('r/baz'));
|
| + }, throwsArgumentError);
|
| + });
|
| + });
|
| + });
|
| + });
|
| +
|
| + 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(
|
| + headers: {'if-modified-since': 'Sun, 06 Nov 1994 08:49:37 GMT'});
|
| + expect(request.ifModifiedSince,
|
| + equals(DateTime.parse("1994-11-06 08:49:37z")));
|
| + });
|
| + });
|
| +
|
| + group('change', () {
|
| + test('with no arguments returns instance with equal values', () {
|
| + var controller = new StreamController();
|
| +
|
| + var uri = Uri.parse('https://test.example.com/static/file.html');
|
| +
|
| + var request = new Request('GET', uri,
|
| + protocolVersion: '2.0',
|
| + headers: {'header1': 'header value 1'},
|
| + url: Uri.parse('file.html'),
|
| + handlerPath: '/static/',
|
| + body: controller.stream,
|
| + context: {'context1': 'context value 1'});
|
| +
|
| + var copy = request.change();
|
| +
|
| + expect(copy.method, request.method);
|
| + expect(copy.requestedUri, request.requestedUri);
|
| + expect(copy.protocolVersion, request.protocolVersion);
|
| + expect(copy.headers, same(request.headers));
|
| + expect(copy.url, request.url);
|
| + expect(copy.handlerPath, request.handlerPath);
|
| + expect(copy.context, same(request.context));
|
| + expect(copy.readAsString(), completion('hello, world'));
|
| +
|
| + controller.add(HELLO_BYTES);
|
| + return new Future(() {
|
| + controller
|
| + ..add(WORLD_BYTES)
|
| + ..close();
|
| + });
|
| + });
|
| +
|
| + group('with path', () {
|
| + test('updates handlerPath and url', () {
|
| + var uri = Uri.parse('https://test.example.com/static/dir/file.html');
|
| + var request = new Request('GET', uri,
|
| + handlerPath: '/static/', url: Uri.parse('dir/file.html'));
|
| + var copy = request.change(path: 'dir');
|
| +
|
| + expect(copy.handlerPath, '/static/dir/');
|
| + expect(copy.url, Uri.parse('file.html'));
|
| + });
|
| +
|
| + test('allows a trailing slash', () {
|
| + var uri = Uri.parse('https://test.example.com/static/dir/file.html');
|
| + var request = new Request('GET', uri,
|
| + handlerPath: '/static/', url: Uri.parse('dir/file.html'));
|
| + var copy = request.change(path: 'dir/');
|
| +
|
| + expect(copy.handlerPath, '/static/dir/');
|
| + expect(copy.url, Uri.parse('file.html'));
|
| + });
|
| +
|
| + test('throws if path does not match existing uri', () {
|
| + var uri = Uri.parse('https://test.example.com/static/dir/file.html');
|
| + var request = new Request('GET', uri,
|
| + handlerPath: '/static/', url: Uri.parse('dir/file.html'));
|
| +
|
| + expect(() => request.change(path: 'wrong'), throwsArgumentError);
|
| + });
|
| +
|
| + test("throws if path isn't a path boundary", () {
|
| + var uri = Uri.parse('https://test.example.com/static/dir/file.html');
|
| + var request = new Request('GET', uri,
|
| + handlerPath: '/static/', url: Uri.parse('dir/file.html'));
|
| +
|
| + expect(() => request.change(path: 'di'), throwsArgumentError);
|
| + });
|
| + });
|
| +
|
| + test("allows the original request to be read", () {
|
| + var request = _request();
|
| + var changed = request.change();
|
| +
|
| + expect(request.read().toList(), completion(isEmpty));
|
| + expect(changed.read, throwsStateError);
|
| + });
|
| +
|
| + test("allows the changed request to be read", () {
|
| + var request = _request();
|
| + var changed = request.change();
|
| +
|
| + expect(changed.read().toList(), completion(isEmpty));
|
| + expect(request.read, throwsStateError);
|
| + });
|
| +
|
| + test("allows another changed request to be read", () {
|
| + var request = _request();
|
| + var changed1 = request.change();
|
| + var changed2 = request.change();
|
| +
|
| + expect(changed2.read().toList(), completion(isEmpty));
|
| + expect(changed1.read, throwsStateError);
|
| + expect(request.read, throwsStateError);
|
| + });
|
| + });
|
| +}
|
|
|