Author: damien
Date: Wed May 13 18:27:11 2009
New Revision: 774474
URL: http://svn.apache.org/viewvc?rev=774474&view=rev
Log:
Adding testing for GET /_changes?continuous=true by adding a GET /
_sleep?time=Msecs call, which allows the browser to process the
waiting data on the other async XHR request.
Modified:
couchdb/trunk/etc/couchdb/default.ini.tpl.in
couchdb/trunk/share/www/script/test/changes.js
couchdb/trunk/src/couchdb/couch_httpd_misc_handlers.erl
couchdb/trunk/src/couchdb/couch_query_servers.erl
Modified: couchdb/trunk/etc/couchdb/default.ini.tpl.in
URL:
http://svn.apache.org/viewvc/couchdb/trunk/etc/couchdb/default.ini.tpl.in?rev=774474&r1=774473&r2=774474&view=diff
=
=
=
=
=
=
=
=
=
=====================================================================
--- couchdb/trunk/etc/couchdb/default.ini.tpl.in (original)
+++ couchdb/trunk/etc/couchdb/default.ini.tpl.in Wed May 13
18:27:11 2009
@@ -60,6 +60,7 @@
_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}
Modified: couchdb/trunk/share/www/script/test/changes.js
URL:
http://svn.apache.org/viewvc/couchdb/trunk/share/www/script/test/changes.js?rev=774474&r1=774473&r2=774474&view=diff
=
=
=
=
=
=
=
=
=
=====================================================================
--- couchdb/trunk/share/www/script/test/changes.js (original)
+++ couchdb/trunk/share/www/script/test/changes.js Wed May 13
18:27:11 2009
@@ -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);
+ }
};
Modified: couchdb/trunk/src/couchdb/couch_httpd_misc_handlers.erl
URL:
http://svn.apache.org/viewvc/couchdb/trunk/src/couchdb/couch_httpd_misc_handlers.erl?rev=774474&r1=774473&r2=774474&view=diff
=
=
=
=
=
=
=
=
=
=====================================================================
--- couchdb/trunk/src/couchdb/couch_httpd_misc_handlers.erl
(original)
+++ couchdb/trunk/src/couchdb/couch_httpd_misc_handlers.erl Wed May
13 18:27:11 2009
@@ -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(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(),
Modified: couchdb/trunk/src/couchdb/couch_query_servers.erl
URL:
http://svn.apache.org/viewvc/couchdb/trunk/src/couchdb/couch_query_servers.erl?rev=774474&r1=774473&r2=774474&view=diff
=
=
=
=
=
=
=
=
=
=====================================================================
--- couchdb/trunk/src/couchdb/couch_query_servers.erl (original)
+++ couchdb/trunk/src/couchdb/couch_query_servers.erl Wed May 13
18:27:11 2009
@@ -278,7 +278,7 @@
[{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,