// 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); // 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); };