blob: bc15b03d2f5e7802f7dd25dc339c0de56c7d3705 [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.elixir = true;
couchTests.replicator_db_by_doc_id = function(debug) {
//return console.log('TODO');
if (debug) debugger;
var populate_db = replicator_db.populate_db;
var docs1 = replicator_db.docs1;
// TODO: dice DBs (at least target)
var dbA = replicator_db.dbA;
var dbB = replicator_db.dbB;
//var repDb = replicator_db.repDb;
var replDb = new CouchDB("_replicator");
var wait = replicator_db.wait;
var waitForRep = replicator_db.waitForRep;
var waitForSeq = replicator_db.waitForSeq;
function by_doc_ids_replication() {
// to test that we can replicate docs with slashes in their IDs
var docs2 = docs1.concat([
{
_id: "_design/mydesign",
language : "javascript"
}
]);
populate_db(dbA, docs2);
populate_db(dbB, []);
var repDoc = {
_id: "foo_cont_rep_doc",
source: "http://" + CouchDB.host + "/" + dbA.name,
// TODO: fix DB name issue and remove absolute URL again
target: 'http://localhost:15984/' + dbB.name,
doc_ids: ["foo666", "foo3", "_design/mydesign", "foo999", "foo1"]
};
T(replDb.save(repDoc).ok);
waitForRep(replDb, repDoc, "completed");
var copy = dbB.open("foo1");
T(copy !== null);
T(copy.value === 11);
copy = dbB.open("foo2");
T(copy === null);
copy = dbB.open("foo3");
T(copy !== null);
T(copy.value === 33);
copy = dbB.open("foo666");
T(copy === null);
copy = dbB.open("foo999");
T(copy === null);
copy = dbB.open("_design/mydesign");
// TODO: recheck - but I believe this should be in the target! (see also #written below)
T(copy !== null);
repDoc = replDb.open(repDoc._id);
T(typeof repDoc._replication_stats === "object", "doc has stats");
var stats = repDoc._replication_stats;
TEquals(3, stats.revisions_checked, "right # of revisions_checked");
TEquals(3, stats.missing_revisions_found, "right # of missing_revisions_found");
TEquals(3, stats.docs_read, "right # of docs_read");
TEquals(3, stats.docs_written, "right # of docs_written");
TEquals(0, stats.doc_write_failures, "right # of doc_write_failures");
// sequences are no more meaningful in a cluster
//TEquals(dbA.info().update_seq, stats.checkpointed_source_seq, "right checkpointed_source_seq");
}
/*var server_config = [
{
section: "couch_httpd_auth",
key: "iterations",
value: "1"
},
{
section: "replicator",
key: "db",
value: repDb.name
}
];*/
//repDb.deleteDb();
// don't run on modified server as it would be strange on cluster
// but use "normal" replication DB, create a doc, reliably clear after run
// on delete fail, the next tests would all fail
function handleReplDoc(show) {
var replDoc = replDb.open("foo_cont_rep_doc");
if(replDoc!=null) {
if(show) {
//console.log(JSON.stringify(replDoc));
}
replDb.deleteDoc(replDoc);
}
}
handleReplDoc();
try {
by_doc_ids_replication();
} finally {
// cleanup or log
try {
handleReplDoc(true);
} catch (e2) {
console.log("Error during cleanup " + e2);
}
}
//run_on_modified_server(server_config, by_doc_ids_replication);
// cleanup
//repDb.deleteDb();
dbA.deleteDb();
dbB.deleteDb();
}