mirror of https://gitee.com/bigwinds/arangodb
467 lines
13 KiB
JavaScript
467 lines
13 KiB
JavaScript
/*jshint globalstrict:false, strict:false */
|
|
/*global assertEqual, assertTrue, assertEqual, assertTypeOf, assertNotEqual, fail */
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test the collection interface
|
|
///
|
|
/// @file
|
|
///
|
|
/// DISCLAIMER
|
|
///
|
|
/// Copyright 2010-2012 triagens GmbH, Cologne, Germany
|
|
///
|
|
/// 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.
|
|
///
|
|
/// Copyright holder is triAGENS GmbH, Cologne, Germany
|
|
///
|
|
/// @author Dr. Frank Celler
|
|
/// @author Copyright 2012, triAGENS GmbH, Cologne, Germany
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
var jsunity = require("jsunity");
|
|
var arangodb = require("@arangodb");
|
|
var ArangoCollection = arangodb.ArangoCollection;
|
|
var testHelper = require("@arangodb/test-helper").Helper;
|
|
var db = arangodb.db;
|
|
var ERRORS = arangodb.errors;
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test suite: collection
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
function CollectionSuite () {
|
|
'use strict';
|
|
return {
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief rotate
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testRotate : function () {
|
|
var cn = "example";
|
|
|
|
db._drop(cn);
|
|
var c1 = db._create(cn);
|
|
|
|
c1.save({ _key: "test1" });
|
|
var f = c1.figures();
|
|
assertEqual(0, f.datafiles.count);
|
|
|
|
testHelper.rotate(c1);
|
|
|
|
f = c1.figures();
|
|
assertEqual(1, f.datafiles.count);
|
|
|
|
c1.save({ _key: "test2" });
|
|
testHelper.rotate(c1);
|
|
|
|
f = c1.figures();
|
|
// we may have one or two datafiles, depending on the compaction
|
|
assertTrue(f.datafiles.count >= 1);
|
|
|
|
c1.unload();
|
|
|
|
db._drop(cn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief rotate w/o journal
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testRotateNoJournal : function () {
|
|
var cn = "example";
|
|
|
|
db._drop(cn);
|
|
var c1 = db._create(cn);
|
|
|
|
try {
|
|
testHelper.rotate(c1);
|
|
fail();
|
|
}
|
|
catch (err) {
|
|
assertEqual(ERRORS.ERROR_ARANGO_NO_JOURNAL.code, err.errorNum);
|
|
}
|
|
|
|
db._drop(cn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief rename loaded collection
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testRenameLoaded : function () {
|
|
var cn = "example";
|
|
var nn = "example2";
|
|
|
|
db._drop(cn);
|
|
db._drop(nn);
|
|
var c1 = db._create(cn);
|
|
|
|
c1.save({ a : 1 });
|
|
|
|
assertTypeOf("string", c1._id);
|
|
assertEqual(cn, c1.name());
|
|
assertTypeOf("number", c1.status());
|
|
assertEqual(ArangoCollection.TYPE_DOCUMENT, c1.type());
|
|
assertTypeOf("number", c1.type());
|
|
|
|
var id = c1._id;
|
|
|
|
c1.rename(nn);
|
|
|
|
assertEqual(id, c1._id);
|
|
assertEqual(nn, c1.name());
|
|
assertTypeOf("number", c1.status());
|
|
assertEqual(ArangoCollection.TYPE_DOCUMENT, c1.type());
|
|
assertTypeOf("number", c1.type());
|
|
|
|
var c2 = db._collection(cn);
|
|
|
|
assertEqual(null, c2);
|
|
|
|
db._drop(nn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief rename unloaded collection
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testRenameUnloaded : function () {
|
|
var cn = "example";
|
|
var nn = "example2";
|
|
|
|
db._drop(cn);
|
|
db._drop(nn);
|
|
var c1 = db._create(cn);
|
|
|
|
c1.save({ a : 1 });
|
|
c1.unload();
|
|
|
|
assertTypeOf("string", c1._id);
|
|
assertEqual(cn, c1.name());
|
|
assertTypeOf("number", c1.status());
|
|
assertEqual(ArangoCollection.TYPE_DOCUMENT, c1.type());
|
|
assertTypeOf("number", c1.type());
|
|
|
|
var id = c1._id;
|
|
|
|
c1.rename(nn);
|
|
|
|
assertEqual(id, c1._id);
|
|
assertEqual(nn, c1.name());
|
|
assertTypeOf("number", c1.status());
|
|
assertEqual(ArangoCollection.TYPE_DOCUMENT, c1.type());
|
|
assertTypeOf("number", c1.type());
|
|
|
|
var c2 = db._collection(cn);
|
|
|
|
assertEqual(null, c2);
|
|
|
|
db._drop(nn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief rename a collection to an already existing collection
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testRenameExisting : function () {
|
|
var cn1 = "example";
|
|
var cn2 = "example2";
|
|
|
|
db._drop(cn1);
|
|
db._drop(cn2);
|
|
var c1 = db._create(cn1);
|
|
db._create(cn2);
|
|
|
|
try {
|
|
c1.rename(cn2);
|
|
}
|
|
catch (err) {
|
|
assertEqual(ERRORS.ERROR_ARANGO_DUPLICATE_NAME.code, err.errorNum);
|
|
}
|
|
db._drop(cn1);
|
|
db._drop(cn2);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test checksum
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testChecksum : function () {
|
|
var cn = "example";
|
|
|
|
db._drop(cn);
|
|
var c1 = db._create(cn);
|
|
|
|
// empty collection, checksum should be 0
|
|
var r1 = c1.checksum(true);
|
|
assertTypeOf("string", r1.revision);
|
|
assertTrue(r1.revision !== "");
|
|
assertTrue(r1.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r1.checksum);
|
|
assertEqual(0, r1.checksum);
|
|
|
|
// inserting a doc, checksum should change
|
|
c1.save({ a : 1 });
|
|
var r2 = c1.checksum(true);
|
|
assertNotEqual(r1.revision, r2.revision);
|
|
assertTypeOf("string", r2.revision);
|
|
assertTrue(r2.revision !== "");
|
|
assertTrue(r2.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r2.checksum);
|
|
assertNotEqual(0, r2.checksum);
|
|
|
|
// inserting another doc, checksum should change
|
|
c1.save({ a : 2 });
|
|
var r3 = c1.checksum(true);
|
|
assertNotEqual(r1.revision, r3.revision);
|
|
assertNotEqual(r2.revision, r3.revision);
|
|
assertTypeOf("string", r3.revision);
|
|
assertTrue(r3.revision !== "");
|
|
assertTrue(r3.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r3.checksum);
|
|
assertNotEqual(0, r3.checksum);
|
|
assertNotEqual(r2.checksum, r3.checksum);
|
|
|
|
// test after unloading
|
|
c1.unload();
|
|
var r4 = c1.checksum(true);
|
|
assertTypeOf("string", r4.revision);
|
|
assertEqual(r3.revision, r4.revision);
|
|
assertTypeOf("number", r4.checksum);
|
|
assertNotEqual(0, r4.checksum);
|
|
assertEqual(r3.checksum, r4.checksum);
|
|
|
|
// test withData
|
|
var r5 = c1.checksum(true, true);
|
|
assertTypeOf("string", r5.revision);
|
|
assertEqual(r4.revision, r5.revision);
|
|
assertTypeOf("number", r5.checksum);
|
|
assertNotEqual(0, r5.checksum);
|
|
assertNotEqual(r4.checksum, r5.checksum);
|
|
|
|
// test after truncation
|
|
c1.truncate();
|
|
var r6 = c1.checksum(true);
|
|
assertTypeOf("string", r6.revision);
|
|
assertNotEqual(r4.revision, r6.revision);
|
|
assertNotEqual(r5.revision, r6.revision);
|
|
assertTypeOf("number", r6.checksum);
|
|
assertEqual(0, r6.checksum);
|
|
|
|
db._drop(cn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test checksum
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testChecksumEdge : function () {
|
|
var cn = "example";
|
|
var vn = "example2";
|
|
|
|
db._drop(cn);
|
|
db._drop(vn);
|
|
db._create(vn);
|
|
var c1 = db._createEdgeCollection(cn);
|
|
|
|
var r1 = c1.checksum(true);
|
|
assertTypeOf("string", r1.revision);
|
|
assertTrue(r1.revision !== "");
|
|
assertTrue(r1.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r1.checksum);
|
|
assertEqual(0, r1.checksum);
|
|
|
|
c1.save(vn + "/1", vn + "/2", { a : 1 });
|
|
var r2 = c1.checksum(true);
|
|
assertNotEqual(r1.revision, r2.revision);
|
|
assertTypeOf("string", r2.revision);
|
|
assertTrue(r2.revision !== "");
|
|
assertTrue(r2.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r2.checksum);
|
|
assertNotEqual(0, r2.checksum);
|
|
|
|
c1.save(vn + "/1", vn + "/2", { a : 2 });
|
|
var r3 = c1.checksum(true);
|
|
assertNotEqual(r1.revision, r3.revision);
|
|
assertNotEqual(r2.revision, r3.revision);
|
|
assertTypeOf("string", r3.revision);
|
|
assertTrue(r3.revision !== "");
|
|
assertTrue(r3.revision.match(/^[0-9]+$/));
|
|
assertTypeOf("number", r3.checksum);
|
|
assertNotEqual(0, r3.checksum);
|
|
assertNotEqual(r2.checksum, r3.checksum);
|
|
|
|
c1.unload();
|
|
var r4 = c1.checksum(true);
|
|
assertTypeOf("string", r4.revision);
|
|
assertEqual(r3.revision, r4.revision);
|
|
assertTypeOf("number", r4.checksum);
|
|
assertEqual(r3.checksum, r4.checksum);
|
|
|
|
// test withData
|
|
var r5 = c1.checksum(true, true);
|
|
assertTypeOf("string", r5.revision);
|
|
assertEqual(r4.revision, r5.revision);
|
|
assertTypeOf("number", r5.checksum);
|
|
assertNotEqual(0, r5.checksum);
|
|
assertNotEqual(r4.checksum, r5.checksum);
|
|
|
|
// test after truncation
|
|
c1.truncate();
|
|
var r6 = c1.checksum(true);
|
|
assertTypeOf("string", r6.revision);
|
|
assertNotEqual(r4.revision, r6.revision);
|
|
assertNotEqual(r5.revision, r6.revision);
|
|
assertTypeOf("number", r6.checksum);
|
|
assertEqual(0, r6.checksum);
|
|
|
|
db._drop(cn);
|
|
db._drop(vn);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test checksum two different collections
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testChecksumDifferent : function () {
|
|
var cn1 = "example";
|
|
var cn2 = "example2";
|
|
|
|
db._drop(cn1);
|
|
db._drop(cn2);
|
|
var c1 = db._create(cn1);
|
|
var c2 = db._create(cn2);
|
|
|
|
// collections are empty, checksums are identical
|
|
var cs1 = c1.checksum().checksum;
|
|
var cs2 = c2.checksum().checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
c1.save({ _key: "foobar", value: 123 });
|
|
c2.save({ _key: "foobar", value: 123 });
|
|
|
|
// keys are the same
|
|
cs1 = c1.checksum().checksum;
|
|
cs2 = c2.checksum().checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
// data is the same
|
|
cs1 = c1.checksum(false, true).checksum;
|
|
cs2 = c2.checksum(false, true).checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
// revisions are different
|
|
cs1 = c1.checksum(true, false).checksum;
|
|
cs2 = c2.checksum(true, false).checksum;
|
|
|
|
assertNotEqual(cs1, cs2);
|
|
|
|
// revisions are still different
|
|
cs1 = c1.checksum(true, true).checksum;
|
|
cs2 = c2.checksum(true, true).checksum;
|
|
|
|
assertNotEqual(cs1, cs2);
|
|
|
|
// update document in c1, keep data
|
|
c1.replace("foobar", { value: 123 });
|
|
|
|
// keys are still the same
|
|
cs1 = c1.checksum().checksum;
|
|
cs2 = c2.checksum().checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
// data is still the same
|
|
cs1 = c1.checksum(false, true).checksum;
|
|
cs2 = c2.checksum(false, true).checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
// revisions are still different
|
|
cs1 = c1.checksum(true, false).checksum;
|
|
cs2 = c2.checksum(true, false).checksum;
|
|
|
|
// update document in c1, changing data
|
|
c1.replace("foobar", { value: 124 });
|
|
|
|
// keys are still the same
|
|
cs1 = c1.checksum().checksum;
|
|
cs2 = c2.checksum().checksum;
|
|
|
|
assertEqual(cs1, cs2);
|
|
|
|
// data is not the same
|
|
cs1 = c1.checksum(false, true).checksum;
|
|
cs2 = c2.checksum(false, true).checksum;
|
|
|
|
assertNotEqual(cs1, cs2);
|
|
|
|
// revisions are still different
|
|
cs1 = c1.checksum(true, false).checksum;
|
|
cs2 = c2.checksum(true, false).checksum;
|
|
|
|
db._drop(cn1);
|
|
db._drop(cn2);
|
|
},
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief test system collection dropping / renaming / unloading
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
testSystemSpecial : function () {
|
|
var cn = "_users";
|
|
var c = db._collection(cn);
|
|
|
|
// drop
|
|
try {
|
|
c.drop();
|
|
fail();
|
|
}
|
|
catch (err1) {
|
|
assertEqual(ERRORS.ERROR_FORBIDDEN.code, err1.errorNum);
|
|
}
|
|
|
|
// rename
|
|
var cn1 = "example";
|
|
db._drop(cn1);
|
|
|
|
try {
|
|
c.rename(cn1);
|
|
fail();
|
|
}
|
|
catch (err2) {
|
|
assertEqual(ERRORS.ERROR_FORBIDDEN.code, err2.errorNum);
|
|
}
|
|
|
|
// unload is allowed
|
|
c.unload();
|
|
}
|
|
|
|
};
|
|
}
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
/// @brief executes the test suites
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
|
|
jsunity.run(CollectionSuite);
|
|
|
|
return jsunity.done();
|
|
|