diff options
-rw-r--r-- | etc/couchdb/default.ini.tpl.in | 1 | ||||
-rw-r--r-- | share/www/script/test/changes.js | 76 | ||||
-rw-r--r-- | src/couchdb/couch_httpd_misc_handlers.erl | 8 | ||||
-rw-r--r-- | src/couchdb/couch_query_servers.erl | 2 |
4 files changed, 75 insertions, 12 deletions
diff --git a/etc/couchdb/default.ini.tpl.in b/etc/couchdb/default.ini.tpl.in index 3caaf597..02aea96b 100644 --- a/etc/couchdb/default.ini.tpl.in +++ b/etc/couchdb/default.ini.tpl.in @@ -60,6 +60,7 @@ _uuids = {couch_httpd_misc_handlers, handle_uuids_req} _restart = {couch_httpd_misc_handlers, handle_restart_req} _stats = {couch_httpd_stats_handlers, handle_stats_req} _log = {couch_httpd_misc_handlers, handle_log_req} +_sleep = {couch_httpd_misc_handlers, handle_sleep_req} [httpd_db_handlers] _compact = {couch_httpd_db, handle_compact_req} diff --git a/share/www/script/test/changes.js b/share/www/script/test/changes.js index fef2bcca..fe8a1cd5 100644 --- a/share/www/script/test/changes.js +++ b/share/www/script/test/changes.js @@ -10,29 +10,85 @@ // License for the specific language governing permissions and limitations under // the License. + couchTests.changes = function(debug) { var db = new CouchDB("test_suite_db"); db.deleteDb(); db.createDb(); if (debug) debugger; - - var req = CouchDB.newXhr(); - - req.open("GET", "/test_suite_db/_changes", false); - req.send(""); + var req = CouchDB.request("GET", "/test_suite_db/_changes"); var resp = JSON.parse(req.responseText); T(resp.results.length == 0 && resp.last_seq==0) - var doc = {_id:"foo", bar:1}; - db.save(doc); + var docFoo = {_id:"foo", bar:1}; + db.save(docFoo); - req.open("GET", "/test_suite_db/_changes", false); - req.send(""); + req = CouchDB.request("GET", "/test_suite_db/_changes"); var resp = JSON.parse(req.responseText); T(resp.results.length == 1 && resp.last_seq==1) - T(resp.results[0].changes[0].rev == doc._rev) + T(resp.results[0].changes[0].rev == docFoo._rev) + + var xhr; + + try { + xhr = CouchDB.newXhr(); + } catch (err) { + } + + if (xhr) { + // Only test the continuous stuff if we have a real XHR object + // with real async support. + + var sleep = function(msecs) { + // by making a slow sync request, weallows the waiting XHR request data + // to be received. + var req = CouchDB.request("GET", "/_sleep?time=" + msecs); + T(JSON.parse(req.responseText).ok == true); + } + + var parse_changes_line = function(line) { + if (line.charAt(line.length-1) == ",") { + line = line.substring(0, line.length-1); + } + return JSON.parse(line); + } + + xhr.open("GET", "/test_suite_db/_changes?continuous=true", true); + xhr.send(""); + + var docBar = {_id:"bar", bar:1}; + db.save(docBar); + + sleep(100); + var lines = xhr.responseText.split("\n"); + + T(lines[0]='{"results":['); + + var change = parse_changes_line(lines[1]); + + T(change.seq == 1) + T(change.id == "foo") + + change = parse_changes_line(lines[2]); + + T(change.seq == 2) + T(change.id == "bar") + T(change.changes[0].rev == docBar._rev) + + var docBaz = {_id:"baz", baz:1}; + db.save(docBaz); + + sleep(100); + var lines = xhr.responseText.split("\n"); + + change = parse_changes_line(lines[3]); + + T(change.seq == 3); + T(change.id == "baz"); + T(change.changes[0].rev == docBaz._rev); + } }; diff --git a/src/couchdb/couch_httpd_misc_handlers.erl b/src/couchdb/couch_httpd_misc_handlers.erl index 5daeeeea..36dfa0ac 100644 --- a/src/couchdb/couch_httpd_misc_handlers.erl +++ b/src/couchdb/couch_httpd_misc_handlers.erl @@ -15,7 +15,7 @@ -export([handle_welcome_req/2,handle_favicon_req/2,handle_utils_dir_req/2, handle_all_dbs_req/1,handle_replicate_req/1,handle_restart_req/1, handle_uuids_req/1,handle_config_req/1,handle_log_req/1, - handle_task_status_req/1]). + handle_task_status_req/1,handle_sleep_req/1]). -export([increment_update_seq_req/2]). @@ -56,6 +56,12 @@ handle_utils_dir_req(#httpd{method='GET'}=Req, DocumentRoot) -> handle_utils_dir_req(Req, _) -> send_method_not_allowed(Req, "GET,HEAD"). +handle_sleep_req(#httpd{method='GET'}=Req) -> + Time = list_to_integer(couch_httpd:qs_value(Req, "time")), + receive snicklefart -> ok after Time -> ok end, + send_json(Req, {[{ok, true}]}); +handle_sleep_req(Req) -> + send_method_not_allowed(Req, "GET,HEAD"). handle_all_dbs_req(#httpd{method='GET'}=Req) -> {ok, DbNames} = couch_server:all_databases(), diff --git a/src/couchdb/couch_query_servers.erl b/src/couchdb/couch_query_servers.erl index 734baade..7c82abe7 100644 --- a/src/couchdb/couch_query_servers.erl +++ b/src/couchdb/couch_query_servers.erl @@ -278,7 +278,7 @@ handle_info({'EXIT', Pid, Status}, {Langs, PidLangs, Pids, InUse}) -> [{Pid, Lang}] -> case Status of normal -> ok; - _ -> ?LOG_DEBUG("Linked process died abnromally: ~p (reason: ~p)", [Pid, Status]) + _ -> ?LOG_DEBUG("Linked process died abnormally: ~p (reason: ~p)", [Pid, Status]) end, {ok, { Langs, |