summaryrefslogtreecommitdiff
path: root/share/www/script/test/all_docs.js
diff options
context:
space:
mode:
Diffstat (limited to 'share/www/script/test/all_docs.js')
-rw-r--r--share/www/script/test/all_docs.js136
1 files changed, 0 insertions, 136 deletions
diff --git a/share/www/script/test/all_docs.js b/share/www/script/test/all_docs.js
deleted file mode 100644
index 1d83aa95..00000000
--- a/share/www/script/test/all_docs.js
+++ /dev/null
@@ -1,136 +0,0 @@
-// Licensed under the Apache License, Version 2.0 (the "License"); you may not
-// use this file except in compliance with the License. You may obtain a copy of
-// the License at
-//
-// http://www.apache.org/licenses/LICENSE-2.0
-//
-// Unless required by applicable law or agreed to in writing, software
-// distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
-// WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
-// License for the specific language governing permissions and limitations under
-// the License.
-
-couchTests.all_docs = function(debug) {
- var db = new CouchDB("test_suite_db", {"X-Couch-Full-Commit":"false"});
- db.deleteDb();
- db.createDb();
- if (debug) debugger;
-
- // Create some more documents.
- // Notice the use of the ok member on the return result.
- T(db.save({_id:"0",a:1,b:1}).ok);
- T(db.save({_id:"3",a:4,b:16}).ok);
- T(db.save({_id:"1",a:2,b:4}).ok);
- T(db.save({_id:"2",a:3,b:9}).ok);
-
- // Check the all docs
- var results = db.allDocs();
- var rows = results.rows;
-
- T(results.total_rows == results.rows.length);
-
- for(var i=0; i < rows.length; i++) {
- T(rows[i].id >= "0" && rows[i].id <= "4");
- }
-
- // Check _all_docs with descending=true
- var desc = db.allDocs({descending:true});
- T(desc.total_rows == desc.rows.length);
-
- // Check _all_docs offset
- var all = db.allDocs({startkey:"2"});
- T(all.offset == 2);
-
- // check that the docs show up in the seq view in the order they were created
- var changes = db.changes();
- var ids = ["0","3","1","2"];
- for (var i=0; i < changes.results.length; i++) {
- var row = changes.results[i];
- T(row.id == ids[i], "seq order");
- };
-
- // it should work in reverse as well
- changes = db.changes({descending:true});
- ids = ["2","1","3","0"];
- for (var i=0; i < changes.results.length; i++) {
- var row = changes.results[i];
- T(row.id == ids[i], "descending=true");
- };
-
- // check that deletions also show up right
- var doc1 = db.open("1");
- var deleted = db.deleteDoc(doc1);
- T(deleted.ok);
- changes = db.changes();
- // the deletion should make doc id 1 have the last seq num
- T(changes.results.length == 4);
- T(changes.results[3].id == "1");
- T(changes.results[3].deleted);
-
- // do an update
- var doc2 = db.open("3");
- doc2.updated = "totally";
- db.save(doc2);
- changes = db.changes();
-
- // the update should make doc id 3 have the last seq num
- T(changes.results.length == 4);
- T(changes.results[3].id == "3");
-
- // ok now lets see what happens with include docs
- changes = db.changes({include_docs: true});
- T(changes.results.length == 4);
- T(changes.results[3].id == "3");
- T(changes.results[3].doc.updated == "totally");
-
- T(changes.results[2].doc);
- T(changes.results[2].doc._deleted);
-
- rows = db.allDocs({include_docs: true}, ["1"]).rows;
- TEquals(1, rows.length);
- TEquals("1", rows[0].key);
- TEquals("1", rows[0].id);
- TEquals(true, rows[0].value.deleted);
- TEquals(null, rows[0].doc);
-
- // add conflicts
- var conflictDoc1 = {
- _id: "3", _rev: "2-aa01552213fafa022e6167113ed01087", value: "X"
- };
- var conflictDoc2 = {
- _id: "3", _rev: "2-ff01552213fafa022e6167113ed01087", value: "Z"
- };
- T(db.save(conflictDoc1, {new_edits: false}));
- T(db.save(conflictDoc2, {new_edits: false}));
-
- var winRev = db.open("3");
-
- changes = db.changes({include_docs: true, conflicts: true, style: "all_docs"});
- TEquals("3", changes.results[3].id);
- TEquals(3, changes.results[3].changes.length);
- TEquals(winRev._rev, changes.results[3].changes[0].rev);
- TEquals("3", changes.results[3].doc._id);
- TEquals(winRev._rev, changes.results[3].doc._rev);
- TEquals(true, changes.results[3].doc._conflicts instanceof Array);
- TEquals(2, changes.results[3].doc._conflicts.length);
-
- rows = db.allDocs({include_docs: true, conflicts: true}).rows;
- TEquals(3, rows.length);
- TEquals("3", rows[2].key);
- TEquals("3", rows[2].id);
- TEquals(winRev._rev, rows[2].value.rev);
- TEquals(winRev._rev, rows[2].doc._rev);
- TEquals("3", rows[2].doc._id);
- TEquals(true, rows[2].doc._conflicts instanceof Array);
- TEquals(2, rows[2].doc._conflicts.length);
-
- // test the all docs collates sanely
- db.save({_id: "Z", foo: "Z"});
- db.save({_id: "a", foo: "a"});
-
- var rows = db.allDocs({startkey: "Z", endkey: "Z"}).rows;
- T(rows.length == 1);
-
- // cleanup
- db.deleteDb();
-};