blob: 7c7f6f8948932a69d95461e2108f79766985b272 [file] [log] [blame]
// 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.view_multi_key_all_docs = function(debug) {
var db = new CouchDB("test_suite_db", {"X-Couch-Full-Commit":"false"});
db.deleteDb();
db.createDb();
if (debug) debugger;
var docs = makeDocs(0, 100);
db.bulkSave(docs);
var keys = ["10","15","30","37","50"];
var rows = db.allDocs({},keys).rows;
T(rows.length == keys.length);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[i]);
// keys in GET parameters
rows = db.allDocs({keys:keys}, null).rows;
T(rows.length == keys.length);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[i]);
rows = db.allDocs({limit: 1}, keys).rows;
T(rows.length == 1);
T(rows[0].id == keys[0]);
// keys in GET parameters
rows = db.allDocs({limit: 1, keys: keys}, null).rows;
T(rows.length == 1);
T(rows[0].id == keys[0]);
rows = db.allDocs({skip: 2}, keys).rows;
T(rows.length == 3);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[i+2]);
// keys in GET parameters
rows = db.allDocs({skip: 2, keys: keys}, null).rows;
T(rows.length == 3);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[i+2]);
rows = db.allDocs({descending: "true"}, keys).rows;
T(rows.length == keys.length);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[keys.length-i-1]);
// keys in GET parameters
rows = db.allDocs({descending: "true", keys: keys}, null).rows;
T(rows.length == keys.length);
for(var i=0; i<rows.length; i++)
T(rows[i].id == keys[keys.length-i-1]);
rows = db.allDocs({descending: "true", skip: 3, limit:1}, keys).rows;
T(rows.length == 1);
T(rows[0].id == keys[1]);
// keys in GET parameters
rows = db.allDocs({descending: "true", skip: 3, limit:1, keys: keys}, null).rows;
T(rows.length == 1);
T(rows[0].id == keys[1]);
// Check we get invalid rows when the key doesn't exist
rows = db.allDocs({}, [1, "i_dont_exist", "0"]).rows;
T(rows.length == 3);
T(rows[0].error == "not_found");
T(!rows[0].id);
T(rows[1].error == "not_found");
T(!rows[1].id);
T(rows[2].id == rows[2].key && rows[2].key == "0");
// keys in GET parameters
rows = db.allDocs({keys: [1, "i_dont_exist", "0"]}, null).rows;
T(rows.length == 3);
T(rows[0].error == "not_found");
T(!rows[0].id);
T(rows[1].error == "not_found");
T(!rows[1].id);
T(rows[2].id == rows[2].key && rows[2].key == "0");
// empty keys
rows = db.allDocs({keys: []}, null).rows;
T(rows.length == 0);
};