summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--share/server/render.js4
-rw-r--r--share/www/script/test/list_views.js2
-rw-r--r--share/www/script/test/show_documents.js16
-rw-r--r--src/couchdb/couch_httpd_external.erl2
4 files changed, 13 insertions, 11 deletions
diff --git a/share/server/render.js b/share/server/render.js
index 99541eab..b3a24bde 100644
--- a/share/server/render.js
+++ b/share/server/render.js
@@ -166,8 +166,8 @@ registerType = function() {
// http://dev.rubyonrails.org/svn/rails/trunk/actionpack/lib/action_controller/mime_types.rb
registerType("all", "*/*");
-registerType("text", "text/plain", "txt");
-registerType("html", "text/html");
+registerType("text", "text/plain; charset=utf-8", "txt");
+registerType("html", "text/html; charset=utf-8");
registerType("xhtml", "application/xhtml+xml", "xhtml");
registerType("xml", "application/xml", "text/xml", "application/x-xml");
registerType("js", "text/javascript", "application/javascript", "application/x-javascript");
diff --git a/share/www/script/test/list_views.js b/share/www/script/test/list_views.js
index 2b7e4cb3..bbe0814c 100644
--- a/share/www/script/test/list_views.js
+++ b/share/www/script/test/list_views.js
@@ -312,7 +312,7 @@ couchTests.list_views = function(debug) {
"Accept": 'text/html'
}
});
- T(xhr.getResponseHeader("Content-Type") == "text/html");
+ T(xhr.getResponseHeader("Content-Type") == "text/html; charset=utf-8");
T(xhr.responseText.match(/HTML/));
T(xhr.responseText.match(/Value/));
diff --git a/share/www/script/test/show_documents.js b/share/www/script/test/show_documents.js
index 18dcc0b3..64a6788f 100644
--- a/share/www/script/test/show_documents.js
+++ b/share/www/script/test/show_documents.js
@@ -143,10 +143,7 @@ couchTests.show_documents = function(debug) {
// hello template world
xhr = CouchDB.request("GET", "/test_suite_db/_design/template/_show/hello/"+docid);
T(xhr.responseText == "Hello World");
-//
-// };
-//
-// function foo() {
+ T(/charset=utf-8/.test(xhr.getResponseHeader("Content-Type")))
// Fix for COUCHDB-379
T(equals(xhr.getResponseHeader("Server").substr(0,7), "CouchDB"));
@@ -207,7 +204,8 @@ couchTests.show_documents = function(debug) {
xhr = CouchDB.request("GET", "/test_suite_db/_design/template/_show/accept-switch/"+docid, {
headers: {"Accept": "text/html;text/plain;*/*"}
});
- T("text/html" == xhr.getResponseHeader("Content-Type"));
+ var ct = xhr.getResponseHeader("Content-Type");
+ T(/text\/html/.test(ct))
T("Accept" == xhr.getResponseHeader("Vary"));
var etag = xhr.getResponseHeader("etag");
@@ -287,7 +285,9 @@ couchTests.show_documents = function(debug) {
"Accept": 'text/html,application/atom+xml; q=0.9'
}
});
- T(xhr.getResponseHeader("Content-Type") == "text/html");
+ var ct = xhr.getResponseHeader("Content-Type");
+ T(/charset=utf-8/.test(ct))
+ T(/text\/html/.test(ct))
T(xhr.responseText == "Ha ha, you said \"plankton\".");
// now with xml
@@ -315,7 +315,9 @@ couchTests.show_documents = function(debug) {
"Accept": 'text/html,application/atom+xml; q=0.9'
}
});
- T(xhr.getResponseHeader("Content-Type") == "text/html");
+ var ct = xhr.getResponseHeader("Content-Type");
+ T(/charset=utf-8/.test(ct))
+ T(/text\/html/.test(ct))
T(xhr.responseText == "Ha ha, you said \"plankton\".");
// test inclusion of conflict state
diff --git a/src/couchdb/couch_httpd_external.erl b/src/couchdb/couch_httpd_external.erl
index 82a5542b..949bd83a 100644
--- a/src/couchdb/couch_httpd_external.erl
+++ b/src/couchdb/couch_httpd_external.erl
@@ -117,7 +117,7 @@ parse_external_response({Response}) ->
data=?JSON_ENCODE(Value),
ctype="application/json"};
{<<"body">>, Value} ->
- Args#extern_resp_args{data=Value, ctype="text/html"};
+ Args#extern_resp_args{data=Value, ctype="text/html; charset=utf-8"};
{<<"base64">>, Value} ->
Args#extern_resp_args{
data=couch_util:decodeBase64(Value),