diff options
| -rw-r--r-- | share/www/script/couch_tests.js | 1 | ||||
| -rw-r--r-- | share/www/script/test/regression.js | 48 | ||||
| -rw-r--r-- | src/couchdb/couch_db.erl | 2 | 
3 files changed, 51 insertions, 0 deletions
| diff --git a/share/www/script/couch_tests.js b/share/www/script/couch_tests.js index eb573526..4c5c00d6 100644 --- a/share/www/script/couch_tests.js +++ b/share/www/script/couch_tests.js @@ -76,6 +76,7 @@ loadTest("reduce.js");  loadTest("reduce_builtin.js");  loadTest("reduce_false.js");  loadTest("reduce_false_temp.js"); +loadTest("regression.js");  loadTest("replication.js");  loadTest("replicator_db.js");  loadTest("rev_stemming.js"); diff --git a/share/www/script/test/regression.js b/share/www/script/test/regression.js new file mode 100644 index 00000000..abe42b40 --- /dev/null +++ b/share/www/script/test/regression.js @@ -0,0 +1,48 @@ +// 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.regression = function(debug) { +    var db = new CouchDB("test_suite_db", {"X-Couch-Full-Commit":"false"}); +    db.deleteDb(); +    db.createDb(); +    if (debug) debugger; + +    // COUCHDB-1178 +    { +        var r1 = {"_id":"doc","foo":"bar"}; +        var r2 = {"_id":"doc","foo":"baz","_rev":"1-4c6114c65e295552ab1019e2b046b10e"}; +        var r3 = {"_id":"doc","foo":"bam","_rev":"2-cfcd6781f13994bde69a1c3320bfdadb"}; +        var r4 = {"_id":"doc","foo":"bat","_rev":"3-cc2f3210d779aef595cd4738be0ef8ff"}; + +        T(db.save({"_id":"_design/couchdb-1178","validate_doc_update":"function(){}"}).ok); +        T(db.save(r1).ok); +        T(db.save(r2).ok); +        T(db.save(r3).ok); + +        T(db.compact().ok); +        while (db.info().compact_running) {}; + +        TEquals({"_id":"doc", +                 "_rev":"3-cc2f3210d779aef595cd4738be0ef8ff", +                 "foo":"bam", +                 "_revisions":{"start":3, +                               "ids":["cc2f3210d779aef595cd4738be0ef8ff", +                                      "cfcd6781f13994bde69a1c3320bfdadb", +                                      "4c6114c65e295552ab1019e2b046b10e"]}}, +                db.open("doc", {"revs": true})); + +        TEquals([], db.bulkSave([r4, r3, r2], {"new_edits":false}), "no failures"); +    } + +    // cleanup +    db.deleteDb(); +};
\ No newline at end of file diff --git a/src/couchdb/couch_db.erl b/src/couchdb/couch_db.erl index 1e7addaf..40d84618 100644 --- a/src/couchdb/couch_db.erl +++ b/src/couchdb/couch_db.erl @@ -733,6 +733,8 @@ update_docs(Db, Docs, Options, interactive_edit) ->  % for the doc.  make_first_doc_on_disk(_Db, _Id, _Pos, []) ->      nil; +make_first_doc_on_disk(Db, Id, Pos, [{_Rev, #doc{}} | RestPath]) -> +    make_first_doc_on_disk(Db, Id, Pos-1, RestPath);  make_first_doc_on_disk(Db, Id, Pos, [{_Rev, ?REV_MISSING}|RestPath]) ->      make_first_doc_on_disk(Db, Id, Pos - 1, RestPath);  make_first_doc_on_disk(Db, Id, Pos, [{_Rev, {IsDel, Sp, _Seq}} |_]=DocPath) -> | 
