Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(76)

Unified Diff: tests/standalone/io/http_test.dart

Issue 10407002: Add special handling of the content type HTTP header (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Removed the content type caching to simplify. Created 8 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tests/standalone/io/http_headers_test.dart ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tests/standalone/io/http_test.dart
diff --git a/tests/standalone/io/http_test.dart b/tests/standalone/io/http_test.dart
index eab4b858265ca558e8a6a1ad46d4533e6648d1bf..866d58e2e5647fe03bd447a1d4d09caa48c964fa 100644
--- a/tests/standalone/io/http_test.dart
+++ b/tests/standalone/io/http_test.dart
@@ -154,6 +154,29 @@ class TestServer extends Isolate {
response.outputStream.close();
}
+ void _contentType1Handler(HttpRequest request, HttpResponse response) {
+ Expect.equals("text/html", request.headers.contentType.value);
+ Expect.equals("text", request.headers.contentType.primaryType);
+ Expect.equals("html", request.headers.contentType.subType);
+ Expect.equals("utf-8", request.headers.contentType.parameters["charset"]);
+
+ ContentType contentType = new ContentType("text", "html");
+ contentType.parameters["charset"] = "utf-8";
+ response.headers.contentType = contentType;
+ response.outputStream.close();
+ }
+
+ void _contentType2Handler(HttpRequest request, HttpResponse response) {
+ Expect.equals("text/html", request.headers.contentType.value);
+ Expect.equals("text", request.headers.contentType.primaryType);
+ Expect.equals("html", request.headers.contentType.subType);
+ Expect.equals("utf-8", request.headers.contentType.parameters["charset"]);
+
+ response.headers.set(HttpHeaders.CONTENT_TYPE,
+ "text/html; charset = utf-8");
+ response.outputStream.close();
+ }
+
void main() {
// Setup request handlers.
_requestHandlers = new Map();
@@ -180,6 +203,14 @@ class TestServer extends Isolate {
(HttpRequest request, HttpResponse response) {
_expires2Handler(request, response);
};
+ _requestHandlers["/contenttype1"] =
+ (HttpRequest request, HttpResponse response) {
+ _contentType1Handler(request, response);
+ };
+ _requestHandlers["/contenttype2"] =
+ (HttpRequest request, HttpResponse response) {
+ _contentType2Handler(request, response);
+ };
this.port.receive((var message, SendPort replyTo) {
if (message.isStart) {
@@ -514,6 +545,54 @@ void testExpires() {
testServerMain.start();
}
+void testContentType() {
+ TestServerMain testServerMain = new TestServerMain();
+ testServerMain.setServerStartedHandler((int port) {
+ int responses = 0;
+ HttpClient httpClient = new HttpClient();
+
+ void processResponse(HttpClientResponse response) {
+ Expect.equals(HttpStatus.OK, response.statusCode);
+ Expect.equals("text/html; charset=utf-8",
+ response.headers.contentType.toString());
+ Expect.equals("text/html", response.headers.contentType.value);
+ Expect.equals("text", response.headers.contentType.primaryType);
+ Expect.equals("html", response.headers.contentType.subType);
+ Expect.equals("utf-8",
+ response.headers.contentType.parameters["charset"]);
+ responses++;
+ if (responses == 2) {
+ httpClient.shutdown();
+ testServerMain.shutdown();
+ }
+ }
+
+ HttpClientConnection conn1 =
+ httpClient.get("127.0.0.1", port, "/contenttype1");
+ conn1.onRequest = (HttpClientRequest request) {
+ ContentType contentType = new ContentType();
+ contentType.value = "text/html";
+ contentType.parameters["charset"] = "utf-8";
+ request.headers.contentType = contentType;
+ request.outputStream.close();
+ };
+ conn1.onResponse = (HttpClientResponse response) {
+ processResponse(response);
+ };
+ HttpClientConnection conn2 =
+ httpClient.get("127.0.0.1", port, "/contenttype2");
+ conn2.onRequest = (HttpClientRequest request) {
+ request.headers.set(HttpHeaders.CONTENT_TYPE,
+ "text/html; charset = utf-8");
+ request.outputStream.close();
+ };
+ conn2.onResponse = (HttpClientResponse response) {
+ processResponse(response);
+ };
+ });
+ testServerMain.start();
+}
+
void main() {
testStartStop();
@@ -528,4 +607,5 @@ void main() {
testReasonPhrase();
testHost();
testExpires();
+ testContentType();
}
« no previous file with comments | « tests/standalone/io/http_headers_test.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698