1
0
Fork 0
arangodb/js/server/tests/aql-modify-noncluster.js

2423 lines
100 KiB
JavaScript

/*jshint strict: false, sub: true, maxlen: 500 */
/*global require, assertEqual, assertFalse, assertNull, assertTrue, fail, AQL_EXECUTE */
////////////////////////////////////////////////////////////////////////////////
/// @brief tests for query language, bind parameters
///
/// @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 Jan Steemann
/// @author Copyright 2012, triAGENS GmbH, Cologne, Germany
////////////////////////////////////////////////////////////////////////////////
var internal = require("internal");
var db = require("org/arangodb").db;
var jsunity = require("jsunity");
var helper = require("org/arangodb/aql-helper");
var cluster = require("org/arangodb/cluster");
var getModifyQueryResults = helper.getModifyQueryResults;
var getModifyQueryResultsRaw = helper.getModifyQueryResultsRaw;
var isEqual = helper.isEqual;
var assertQueryError = helper.assertQueryError;
var errors = internal.errors;
var sanitizeStats = function (stats) {
// remove these members from the stats because they don't matter
// for the comparisons
delete stats.scannedFull;
delete stats.scannedIndex;
delete stats.filtered;
return stats;
};
////////////////////////////////////////////////////////////////////////////////
/// @brief
////////////////////////////////////////////////////////////////////////////////
var validateDocuments = function (documents, isEdgeCollection) {
var index;
for (index in documents) {
if (documents.hasOwnProperty(index)) {
assertTrue(documents[index].hasOwnProperty('_id'));
assertTrue(documents[index].hasOwnProperty('_key'));
assertTrue(documents[index].hasOwnProperty('_rev'));
if (isEdgeCollection) {
assertTrue(documents[index].hasOwnProperty('_from'));
assertTrue(documents[index].hasOwnProperty('_to'));
}
}
}
};
////////////////////////////////////////////////////////////////////////////////
/// @brief check whether the documents inserted are equal on the db.
////////////////////////////////////////////////////////////////////////////////
var validateModifyResultInsert = function (collection, results) {
var index;
for (index in results) {
if (results.hasOwnProperty(index)){
assertTrue(isEqual(collection.document(results[index]._key), results[index]));
}
}
};
////////////////////////////////////////////////////////////////////////////////
/// @brief check whether the documents reported deleted are really gone
////////////////////////////////////////////////////////////////////////////////
var validateDeleteGone = function (collection, results) {
var index;
for (index in results) {
if (results.hasOwnProperty(index)){
try {
assertEqual(collection.document(results[index]._key), {});
fail();
}
catch (e) {
assertTrue(e.errorNum !== undefined, "unexpected error format while calling checking for deleted entry");
assertEqual(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, e.errorNum, "unexpected error code (" + e.errorMessage + "): ");
}
}
}
};
////////////////////////////////////////////////////////////////////////////////
/// @brief convert flat document database to an associative array with the keys
/// as object
////////////////////////////////////////////////////////////////////////////////
var wrapToKeys = function (results) {
var keyArray = {};
var index;
for (index in results) {
if (results.hasOwnProperty(index)){
keyArray[results[index]._key] = results[index];
}
}
return keyArray;
};
////////////////////////////////////////////////////////////////////////////////
/// @brief test suite
////////////////////////////////////////////////////////////////////////////////
function ahuacatlModifySuite () {
var errors = internal.errors;
var cn1 = "UnitTestsAhuacatlModify1";
var cn2 = "UnitTestsAhuacatlModify2";
var c1, c2;
return {
////////////////////////////////////////////////////////////////////////////////
/// @brief set up
////////////////////////////////////////////////////////////////////////////////
setUp : function () {
db._drop(cn1);
db._drop(cn2);
c1 = db._create(cn1);
c2 = db._create(cn2);
c1.save({ _key: "foo", a: 1 });
c2.save({ _key: "foo", b: 1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief tear down
////////////////////////////////////////////////////////////////////////////////
tearDown : function () {
db._drop(cn1);
db._drop(cn2);
c1 = null;
c2 = null;
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testRemoveInSubquery : function () {
assertQueryError(errors.ERROR_QUERY_MODIFY_IN_SUBQUERY.code, "FOR d IN @@cn LET x = (REMOVE d.foobar IN @@cn) RETURN d", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testInsertInSubquery : function () {
assertQueryError(errors.ERROR_QUERY_MODIFY_IN_SUBQUERY.code, "FOR d IN @@cn LET x = (INSERT { _key: 'test' } IN @@cn) RETURN d", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testUpdateInSubquery : function () {
assertQueryError(errors.ERROR_QUERY_MODIFY_IN_SUBQUERY.code, "FOR d IN @@cn LET x = (UPDATE { _key: 'test' } IN @@cn) RETURN d", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testReplaceInSubquery : function () {
assertQueryError(errors.ERROR_QUERY_MODIFY_IN_SUBQUERY.code, "FOR d IN @@cn LET x = (REPLACE { _key: 'test' } IN @@cn) RETURN d", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testReplaceInSubquery2 : function () {
assertQueryError(errors.ERROR_QUERY_MODIFY_IN_SUBQUERY.code, "FOR d IN @@cn LET x = (FOR i IN 1..2 REPLACE { _key: 'test' } IN @@cn) RETURN d", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testMultiModify : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "FOR d IN @@cn1 REMOVE d IN @@cn1 FOR e IN @@cn2 REMOVE e IN @@cn2", { "@cn1": cn1, "@cn2": cn2 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testMultiModify2 : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "FOR d IN @@cn1 FOR e IN @@cn2 REMOVE d IN @@cn1 REMOVE e IN @@cn2", { "@cn1": cn1, "@cn2": cn2 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testDynamicOptions1 : function () {
assertQueryError(errors.ERROR_QUERY_COMPILE_TIME_OPTIONS.code, "FOR d IN @@cn REMOVE d IN @@cn OPTIONS { foo: d }", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testDynamicOptions2 : function () {
assertQueryError(errors.ERROR_QUERY_COMPILE_TIME_OPTIONS.code, "FOR d IN @@cn REMOVE d IN @@cn OPTIONS { foo: MERGE(d, { }) }", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test subquery
////////////////////////////////////////////////////////////////////////////////
testInvalidOptions : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "FOR d IN @@cn REMOVE d IN @@cn OPTIONS 'foo'", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test usage of OLD
////////////////////////////////////////////////////////////////////////////////
testInvalidUsageOfNew : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "REMOVE 'abc' IN @@cn LET removed = NEW RETURN removed", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test usage of NEW
////////////////////////////////////////////////////////////////////////////////
testInvalidUsageOfOld : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "INSERT { } IN @@cn LET inserted = OLD RETURN inserted", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test variable names
////////////////////////////////////////////////////////////////////////////////
testInvalidVariableNames1 : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "REMOVE 'abc' IN @@cn LET removed1 = OLD RETURN removed2", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test variable names
////////////////////////////////////////////////////////////////////////////////
testInvalidVariableNames2 : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "UPDATE 'abc' WITH { } IN @@cn LET updated = NEW RETURN foo", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test variable names
////////////////////////////////////////////////////////////////////////////////
testInvalidVariableNames3 : function () {
assertQueryError(errors.ERROR_QUERY_PARSE.code, "FOR i IN 1..1 UPDATE 'abc' WITH { } IN @@cn LET updated = NEW RETURN i", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test empty results
////////////////////////////////////////////////////////////////////////////////
testEmptyResultRemove : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = AQL_EXECUTE("FOR d IN " + cn1 + " REMOVE d IN " + cn1, {});
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual([ ], actual.json);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test empty results
////////////////////////////////////////////////////////////////////////////////
testEmptyResultInsert : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = AQL_EXECUTE("INSERT { _key: 'baz' } IN " + cn1, {});
assertEqual(2, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual([ ], actual.json);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test empty results
////////////////////////////////////////////////////////////////////////////////
testEmptyResultUpdate : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = AQL_EXECUTE("UPDATE { _key: 'foo' } WITH { baz: true } IN " + cn1, {});
assertEqual(1, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual([ ], actual.json);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test empty results
////////////////////////////////////////////////////////////////////////////////
testEmptyResultReplace : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = AQL_EXECUTE("REPLACE { _key: 'foo' } WITH { baz: true } IN " + cn1, {});
assertEqual(1, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual([ ], actual.json);
}
};
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test suite
////////////////////////////////////////////////////////////////////////////////
function ahuacatlRemoveSuite () {
var errors = internal.errors;
var cn1 = "UnitTestsAhuacatlRemove1";
var cn2 = "UnitTestsAhuacatlRemove2";
var c1;
var c2;
return {
////////////////////////////////////////////////////////////////////////////////
/// @brief set up
////////////////////////////////////////////////////////////////////////////////
setUp : function () {
var i;
db._drop(cn1);
db._drop(cn2);
c1 = db._create(cn1);
c2 = db._create(cn2);
for (i = 0; i < 100; ++i) {
c1.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
for (i = 0; i < 50; ++i) {
c2.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief tear down
////////////////////////////////////////////////////////////////////////////////
tearDown : function () {
db._drop(cn1);
db._drop(cn2);
c1 = null;
c2 = null;
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveNothing : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN " + cn1 + " FILTER d.value1 < 0 REMOVE d IN " + cn1, {});
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveNothingWhat : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN " + cn1 + " FILTER d.value1 < 0 REMOVE d IN " + cn1 + " LET removed = OLD RETURN removed", {});
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveNothingBind : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d.value1 < 0 REMOVE d IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveNothingBindWhat : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d.value1 < 0 REMOVE d IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveInvalid1 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn REMOVE d.foobar IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveInvalid1What : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn REMOVE d.foobar IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveInvalid2 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_KEY_MISSING.code, "FOR d IN @@cn REMOVE { } IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveInvalid3 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "FOR d IN @@cn REMOVE 'foobar' IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveInvalid4 : function () {
if (cluster.isCluster()) {
// skip test in cluster as there are no distributed transactions yet
return;
}
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "FOR i iN 0..100 REMOVE CONCAT('test', TO_STRING(i)) IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveIgnore1 : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE 'foo' IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveIgnore1What : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE 'foo' IN @@cn OPTIONS { ignoreErrors: true } LET removed = OLD RETURN removed", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveIgnore2 : function () {
var expected = { writesExecuted: 100, writesIgnored: 101 };
var actual = getModifyQueryResults("FOR i IN 0..200 REMOVE CONCAT('test', TO_STRING(i)) IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveIgnore2What : function () {
var expected = { writesExecuted: 100, writesIgnored: 101 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..200 REMOVE CONCAT('test', TO_STRING(i)) IN @@cn OPTIONS { ignoreErrors: true } LET removed = OLD RETURN removed ", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll1 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE d IN @@cn", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveAll1What : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REMOVE d IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll2 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE d._key IN @@cn", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveAll2What : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REMOVE d._key IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll3 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE { _key: d._key } IN @@cn", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveAll3What : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REMOVE { _key: d._key } IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll4 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 0..99 REMOVE { _key: CONCAT('test', TO_STRING(i)) } IN @@cn", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveAll4What : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..99 REMOVE { _key: CONCAT('test', TO_STRING(i)) } IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll5 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE d INTO @@cn", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveAll5What : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REMOVE d INTO @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveHalf : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 0..99 FILTER i % 2 == 0 REMOVE { _key: CONCAT('test', TO_STRING(i)) } IN @@cn", { "@cn": cn1 });
assertEqual(50, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveHalfWhat : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..99 FILTER i % 2 == 0 REMOVE { _key: CONCAT('test', TO_STRING(i)) } IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(50, actual.json.length);
assertEqual(50, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testSingleNotFound : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "REMOVE 'foobar' IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testSingleNotFoundWhat : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "REMOVE 'foobar' IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testSingle : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("REMOVE 'test0' IN @@cn", { "@cn": cn1 });
assertEqual(99, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testSingleWhat : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("REMOVE 'test0' IN @@cn LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(1, actual.json.length);
assertEqual(99, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsNotFound : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "FOR d IN @@cn1 REMOVE { _key: d._key } IN @@cn2", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(50, c2.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsNotFoundWhat : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "FOR d IN @@cn1 REMOVE { _key: d._key } IN @@cn2 LET removed = OLD RETURN removed", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(50, c2.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsJoin1 : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn1 FILTER d.value1 < 50 REMOVE { _key: d._key } IN @@cn2", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(0, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsJoin1What : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn1 FILTER d.value1 < 50 REMOVE { _key: d._key } IN @@cn2 LET removed = OLD RETURN removed", { "@cn1": cn1, "@cn2": cn2 });
validateDocuments(actual.json, false);
validateDeleteGone(c2, actual.json);
assertEqual(50, actual.json.length);
assertEqual(100, c1.count());
assertEqual(0, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsJoin2 : function () {
var expected = { writesExecuted: 48, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn1 FILTER d.value1 >= 2 && d.value1 < 50 REMOVE { _key: d._key } IN @@cn2", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(2, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsJoin2What : function () {
var expected = { writesExecuted: 48, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn1 FILTER d.value1 >= 2 && d.value1 < 50 REMOVE { _key: d._key } IN @@cn2 LET removed = OLD RETURN removed", { "@cn1": cn1, "@cn2": cn2 });
validateDocuments(actual.json, false);
validateDeleteGone(c2, actual.json);
assertEqual(48, actual.json.length);
assertEqual(100, c1.count());
assertEqual(2, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsIgnoreErrors1 : function () {
var expected = { writesExecuted: 50, writesIgnored: 50 };
var actual = getModifyQueryResults("FOR d IN @@cn1 REMOVE { _key: d._key } IN @@cn2 OPTIONS { ignoreErrors: true }", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(0, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsIgnoreErrors1What : function () {
var expected = { writesExecuted: 50, writesIgnored: 50 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn1 REMOVE { _key: d._key } IN @@cn2 OPTIONS { ignoreErrors: true } LET removed = OLD RETURN removed", { "@cn1": cn1, "@cn2": cn2 });
validateDocuments(actual.json, false);
validateDeleteGone(c2, actual.json);
assertEqual(50, actual.json.length);
assertEqual(100, c1.count());
assertEqual(0, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsIgnoreErrors2 : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResults("FOR d IN @@cn1 REMOVE { _key: CONCAT('foo', d._key) } IN @@cn2 OPTIONS { ignoreErrors: true }", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(100, c1.count());
assertEqual(50, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testTwoCollectionsIgnoreErrors2What : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn1 REMOVE { _key: CONCAT('foo', d._key) } IN @@cn2 OPTIONS { ignoreErrors: true } LET removed = OLD RETURN removed", { "@cn1": cn1, "@cn2": cn2 });
assertEqual(0, actual.json.length);
assertEqual(100, c1.count());
assertEqual(50, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveWaitForSync : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn REMOVE d IN @@cn OPTIONS { waitForSync: true }", { "@cn": cn1 });
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveWaitForSyncWhat : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REMOVE d IN @@cn OPTIONS { waitForSync: true } LET removed = OLD RETURN removed", { "@cn": cn1 });
validateDocuments(actual.json, false);
validateDeleteGone(c1, actual.json);
assertEqual(100, actual.json.length);
assertEqual(0, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove
////////////////////////////////////////////////////////////////////////////////
testRemoveEdge : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
for (var i = 0; i < 100; ++i) {
edge.save("UnitTestsAhuacatlRemove1/foo" + i, "UnitTestsAhuacatlRemove2/bar", { what: i, _key: "test" + i });
}
var expected = { writesExecuted: 10, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 0..9 REMOVE CONCAT('test', TO_STRING(i)) IN @@cn", { "@cn": edge.name() });
assertEqual(100, c1.count());
assertEqual(90, edge.count());
assertEqual(expected, sanitizeStats(actual));
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test remove - return what
////////////////////////////////////////////////////////////////////////////////
testRemoveEdgeWhat : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
for (var i = 0; i < 100; ++i) {
edge.save("UnitTestsAhuacatlRemove1/foo" + i, "UnitTestsAhuacatlRemove2/bar", { what: i, _key: "test" + i });
}
var expected = { writesExecuted: 10, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..9 REMOVE CONCAT('test', TO_STRING(i)) IN @@cn LET removed = OLD RETURN removed", { "@cn": edge.name() });
validateDocuments(actual.json, true);
validateDeleteGone(edge, actual.json);
assertEqual(10, actual.json.length);
assertEqual(100, c1.count());
assertEqual(90, edge.count());
assertEqual(expected, sanitizeStats(actual.stats));
db._drop("UnitTestsAhuacatlEdge");
}
};
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test suite
////////////////////////////////////////////////////////////////////////////////
function ahuacatlInsertSuite () {
var errors = internal.errors;
var cn1 = "UnitTestsAhuacatlInsert1";
var cn2 = "UnitTestsAhuacatlInsert2";
var c1;
var c2;
return {
////////////////////////////////////////////////////////////////////////////////
/// @brief set up
////////////////////////////////////////////////////////////////////////////////
setUp : function () {
var i;
db._drop(cn1);
db._drop(cn2);
c1 = db._create(cn1);
c2 = db._create(cn2);
for (i = 0; i < 100; ++i) {
c1.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
for (i = 0; i < 50; ++i) {
c2.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief tear down
////////////////////////////////////////////////////////////////////////////////
tearDown : function () {
db._drop(cn1);
db._drop(cn2);
c1 = null;
c2 = null;
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertNothing : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN " + cn1 + " FILTER d.value1 < 0 INSERT { foxx: true } IN " + cn1, {});
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertNothingWhat : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN " + cn1 + " FILTER d.value1 < 0 INSERT { foxx: true } IN " + cn1 + " LET inserted = NEW RETURN inserted", {});
assertEqual(0, actual.json.length);
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertNothingBind : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d.value1 < 0 INSERT { foxx: true } IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertNothingBindWhat : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d.value1 < 0 INSERT { foxx: true } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(0, actual.json.length);
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid1 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT d.foobar IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid1What : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT d.foobar IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid2 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT [ ] IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid2What : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT [ ] IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid3 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT 'foo' IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertInvalid3What : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn INSERT 'foo' IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint1 : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR d IN @@cn INSERT d IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint1What : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR d IN @@cn INSERT d IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint2 : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR i IN 0..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn", { "@cn": cn2 });
assertEqual(50, c2.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint2What : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR i IN 0..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn2 });
assertEqual(50, c2.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint3 : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR i IN 0..50 INSERT { _key: 'foo' } IN @@cn", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertUniqueConstraint3What : function () {
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR i IN 0..50 INSERT { _key: 'foo' } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(100, c1.count());
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore1 : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResults("FOR d IN @@cn INSERT d IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore1What : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn INSERT d IN @@cn OPTIONS { ignoreErrors: true } LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(0, actual.json.length);
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore2 : function () {
var expected = { writesExecuted: 1, writesIgnored: 50 };
var actual = getModifyQueryResults("FOR i IN 50..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(101, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore2What : function () {
var expected = { writesExecuted: 1, writesIgnored: 50 };
var actual = getModifyQueryResultsRaw("FOR i IN 50..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true } LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(1, actual.json.length);
validateModifyResultInsert(c1, actual.json);
validateDocuments(actual.json, false);
assertEqual(101, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore3 : function () {
var expected = { writesExecuted: 51, writesIgnored: 50 };
var actual = getModifyQueryResults("FOR i IN 0..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn2 });
assertEqual(101, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore3What : function () {
var expected = { writesExecuted: 51, writesIgnored: 50 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..100 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true } LET inserted = NEW RETURN inserted", { "@cn": cn2 });
validateModifyResultInsert(c2, actual.json);
validateDocuments(actual.json, false);
assertEqual(51, actual.json.length);
assertEqual(101, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore4 : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResults("FOR i IN 0..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore4What : function () {
var expected = { writesExecuted: 0, writesIgnored: 100 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true } LET inserted = NEW RETURN inserted", { "@cn": cn1 });
assertEqual(0, actual.json.length);
assertEqual(100, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore5 : function () {
var expected = { writesExecuted: 50, writesIgnored: 50 };
var actual = getModifyQueryResults("FOR i IN 0..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn2 });
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertIgnore5What : function () {
var expected = { writesExecuted: 50, writesIgnored: 50 };
var actual = getModifyQueryResultsRaw("FOR i IN 0..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn OPTIONS { ignoreErrors: true } LET inserted = NEW RETURN inserted", { "@cn": cn2 });
validateModifyResultInsert(c2, actual.json);
validateDocuments(actual.json, false);
assertEqual(50, actual.json.length);
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEmpty : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn INSERT { } IN @@cn", { "@cn": cn1 });
assertEqual(200, c1.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEmptyWhat : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn INSERT { } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
validateModifyResultInsert(c1, actual.json);
validateDocuments(actual.json, false);
assertEqual(100, actual.json.length);
assertEqual(200, c1.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertCopy : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 50..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn", { "@cn": cn2 });
assertEqual(100, c1.count());
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertCopyWhat : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 50..99 INSERT { _key: CONCAT('test', TO_STRING(i)) } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn2 });
validateModifyResultInsert(c2, actual.json);
validateDocuments(actual.json, false);
assertEqual(50, actual.json.length);
assertEqual(100, c1.count());
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testSingle : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("INSERT { value: 'foobar', _key: 'test' } IN @@cn", { "@cn": cn1 });
assertEqual(101, c1.count());
assertEqual("foobar", c1.document("test").value);
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testSingleWhat : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("INSERT { value: 'foobar', _key: 'test' } IN @@cn LET inserted = NEW RETURN inserted", { "@cn": cn1 });
validateModifyResultInsert(c1, actual.json);
validateDocuments(actual.json, false);
assertEqual(1, actual.json.length);
assertEqual(101, c1.count());
assertEqual("foobar", c1.document("test").value);
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertWaitForSync : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 1..50 INSERT { value: i } INTO @@cn OPTIONS { waitForSync: true }", { "@cn": cn2 });
assertEqual(100, c1.count());
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertWaitForSyncWhat : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 1..50 INSERT { value: i } INTO @@cn OPTIONS { waitForSync: true } LET inserted = NEW RETURN inserted", { "@cn": cn2 });
validateModifyResultInsert(c2, actual.json);
validateDocuments(actual.json, false);
assertEqual(50, actual.json.length);
assertEqual(100, c1.count());
assertEqual(100, c2.count());
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeInvalid : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { } INTO @@cn", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeInvalidWhat : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { } INTO @@cn LET inserted = NEW RETURN inserted", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeNoFrom : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { _to: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)) } INTO @@cn", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeNoFromWhat : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { _to: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)) } INTO @@cn LET inserted = NEW RETURN inserted", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeNoTo : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { _from: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)) } INTO @@cn", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeNoToWhat : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_HANDLE_BAD.code, "FOR i IN 1..50 INSERT { _from: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)) } INTO @@cn LET inserted = NEW RETURN inserted", { "@cn": edge.name() });
assertEqual(0, edge.count());
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdge : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 1..50 INSERT { _key: CONCAT('test', TO_STRING(i)), _from: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)), _to: CONCAT('UnitTestsAhuacatlInsert2/', TO_STRING(i)), value: [ i ], sub: { foo: 'bar' } } INTO @@cn", { "@cn": edge.name() });
assertEqual(expected, sanitizeStats(actual));
assertEqual(50, edge.count());
for (var i = 1; i <= 50; ++i) {
var doc = edge.document("test" + i);
assertEqual("UnitTestsAhuacatlInsert1/" + i, doc._from);
assertEqual("UnitTestsAhuacatlInsert2/" + i, doc._to);
assertEqual([ i ], doc.value);
assertEqual({ foo: "bar" }, doc.sub);
}
db._drop("UnitTestsAhuacatlEdge");
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test insert
////////////////////////////////////////////////////////////////////////////////
testInsertEdgeWhat : function () {
db._drop("UnitTestsAhuacatlEdge");
var edge = db._createEdgeCollection("UnitTestsAhuacatlEdge");
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 1..50 INSERT { _key: CONCAT('test', TO_STRING(i)), _from: CONCAT('UnitTestsAhuacatlInsert1/', TO_STRING(i)), _to: CONCAT('UnitTestsAhuacatlInsert2/', TO_STRING(i)), value: [ i ], sub: { foo: 'bar' } } INTO @@cn LET inserted = NEW RETURN inserted", { "@cn": edge.name() });
validateModifyResultInsert(edge, actual.json);
validateDocuments(actual.json, true);
assertEqual(50, actual.json.length);
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(50, edge.count());
for (var i = 1; i <= 50; ++i) {
var doc = edge.document("test" + i);
assertEqual("UnitTestsAhuacatlInsert1/" + i, doc._from);
assertEqual("UnitTestsAhuacatlInsert2/" + i, doc._to);
assertEqual([ i ], doc.value);
assertEqual({ foo: "bar" }, doc.sub);
}
db._drop("UnitTestsAhuacatlEdge");
}
};
}
////////////////////////////////////////////////////////////////////////////////
/// @brief test suite
////////////////////////////////////////////////////////////////////////////////
function ahuacatlUpdateSuite () {
var errors = internal.errors;
var cn1 = "UnitTestsAhuacatlUpdate1";
var cn2 = "UnitTestsAhuacatlUpdate2";
var c1;
var c2;
return {
////////////////////////////////////////////////////////////////////////////////
/// @brief set up
////////////////////////////////////////////////////////////////////////////////
setUp : function () {
var i;
db._drop(cn1);
db._drop(cn2);
c1 = db._create(cn1);
c2 = db._create(cn2);
for (i = 0; i < 100; ++i) {
c1.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
for (i = 0; i < 50; ++i) {
c2.save({ _key: "test" + i, value1: i, value2: "test" + i });
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief tear down
////////////////////////////////////////////////////////////////////////////////
tearDown : function () {
db._drop(cn1);
db._drop(cn2);
c1 = null;
c2 = null;
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateNothing : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN " + cn1 + " FILTER d.value1 < 0 UPDATE { foxx: true } IN " + cn1, {});
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateNothingBind : function () {
var expected = { writesExecuted: 0, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d.value1 < 0 UPDATE { foxx: true } IN @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateInvalid1 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn UPDATE d.foobar IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateInvalid2 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn UPDATE [ ] IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateInvalid3 : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_TYPE_INVALID.code, "FOR d IN @@cn UPDATE 'foo' IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateUniqueConstraint1 : function () {
c1.ensureUniqueConstraint("value1");
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR d IN @@cn UPDATE d._key WITH { value1: 1 } IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateUniqueConstraint2 : function () {
c1.ensureUniqueConstraint("value3", { sparse: true });
assertQueryError(errors.ERROR_ARANGO_UNIQUE_CONSTRAINT_VIOLATED.code, "FOR d IN @@cn UPDATE d._key WITH { value3: 1 } IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateIgnore1 : function () {
c1.ensureUniqueConstraint("value3", { sparse: true });
var expected = { writesExecuted: 1, writesIgnored: 99 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d WITH { value3: 1 } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateIgnore2 : function () {
c1.ensureUniqueConstraint("value1", { sparse: true });
var expected = { writesExecuted: 0, writesIgnored: 51 };
var actual = getModifyQueryResults("FOR i IN 50..100 UPDATE { _key: CONCAT('test', TO_STRING(i)), value1: 1 } IN @@cn OPTIONS { ignoreErrors: true }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateEmpty1 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE { _key: d._key } IN @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateEmpty1WhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE { _key: d._key } IN @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value2);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateEmpty2 : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d IN @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateEmpty2WhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d IN @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value2);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testSingleNotFound : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "UPDATE { _key: 'foobar' } WITH { value1: 1 } IN @@cn", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testSingleNotFoundWhatNew : function () {
assertQueryError(errors.ERROR_ARANGO_DOCUMENT_NOT_FOUND.code, "UPDATE { _key: 'foobar' } WITH { value1: 1 } IN @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testSingle : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("UPDATE { value: 'foobar', _key: 'test17' } IN @@cn", { "@cn": cn1 });
assertEqual("foobar", c1.document("test17").value);
assertEqual(expected, sanitizeStats(actual));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testSingleWhatNew : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("UPDATE { value: 'foobar', _key: 'test17' } IN @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual("foobar", c1.document("test17").value);
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testSingleWhatOld : function () {
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("UPDATE { value: 'foobar', _key: 'test17' } IN @@cn LET old = OLD RETURN old", { "@cn": cn1 });
assertFalse(actual.json[0].hasOwnProperty('foobar'));
assertEqual("test17", actual.json[0]._key);
assertEqual(17, actual.json[0].value1);
assertEqual("foobar", c1.document("test17").value);
assertEqual(17, c1.document("test17").value1);
assertEqual(expected, sanitizeStats(actual.stats));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateOldValue : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE { _key: d._key, value1: d.value2, value2: d.value1, value3: d.value1 + 5 } IN @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual("test" + i, doc.value1);
assertEqual(i, doc.value2);
assertEqual(i + 5, doc.value3);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateOldValueWhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE { _key: d._key, value1: d.value2, value2: d.value1, value3: d.value1 + 5 } IN @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual("test" + i, doc.value1);
assertEqual(i, doc.value2);
assertEqual(i + 5, doc.value3);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value1);
assertEqual(i, keyArray[doc._key].value2);
assertEqual(i + 5, keyArray[doc._key].value3);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateOldValueWhatOld : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE { _key: d._key, value1: d.value2, value2: d.value1, value3: d.value1 + 5 } IN @@cn LET old = OLD RETURN old", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual("test" + i, doc.value1);
assertEqual(i, doc.value2);
assertEqual(i + 5, doc.value3);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual(i, keyArray[doc._key].value1);
assertEqual("test" + i, keyArray[doc._key].value2);
assertFalse(keyArray[doc._key].hasOwnProperty("value3"));
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateWaitForSync : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR i IN 1..50 UPDATE { _key: CONCAT('test', TO_STRING(i)) } INTO @@cn OPTIONS { waitForSync: true }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateWaitForSyncWhatNew : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR i IN 1..50 UPDATE { _key: CONCAT('test', TO_STRING(i)) } INTO @@cn OPTIONS { waitForSync: true } LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(50, actual.json.length);
var keyArray = wrapToKeys(actual.json);
var count = 0;
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i, doc.value1);
assertEqual("test" + i, doc.value2);
/// only compare the updated documents
if (keyArray.hasOwnProperty(doc._key)){
assertEqual("test" + i, keyArray[doc._key].value2);
count++;
}
}
assertEqual(50, count);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullDefault : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertNull(doc.value1);
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertNull(doc.value9);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullDefaultWhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertNull(doc.value1);
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertNull(doc.value9);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value2);
assertEqual("foobar", keyArray[doc._key].value3);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullTrue : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn OPTIONS { keepNull: true }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertNull(doc.value1);
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertNull(doc.value9);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullTrueWhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn OPTIONS { keepNull: true } LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertNull(doc.value1);
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertNull(doc.value9);
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value2);
assertEqual("foobar", keyArray[doc._key].value3);
assertNull(keyArray[doc._key].value9);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullFalse : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn OPTIONS { keepNull: false }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertFalse(doc.hasOwnProperty("value9"));
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullFalseWhatNew : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn OPTIONS { keepNull: false } LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertFalse(doc.hasOwnProperty("value9"));
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual("test" + i, keyArray[doc._key].value2);
assertEqual("foobar", keyArray[doc._key].value3);
assertFalse(keyArray[doc._key].hasOwnProperty('value9'));
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateKeepNullFalseWhatOld : function () {
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d._key WITH { value1: null, value3: 'foobar', value9: null } INTO @@cn OPTIONS { keepNull: false } LET updated = OLD RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(100, actual.json.length);
var keyArray = wrapToKeys(actual.json);
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertEqual("test" + i, doc.value2);
assertEqual("foobar", doc.value3);
assertFalse(doc.hasOwnProperty("value9"));
assertTrue(keyArray.hasOwnProperty(doc._key));
assertEqual(i, keyArray[doc._key].value1);
assertEqual("test" + i, keyArray[doc._key].value2);
assertFalse(keyArray[doc._key].hasOwnProperty('value3'));
assertFalse(keyArray[doc._key].hasOwnProperty('value9'));
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsDefault : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
var doc = c1.document("something");
assertEqual({ foo: 1, bar: 42, baz: 3, bumm : 23 }, doc.values);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsDefaultWhatNew : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(1, actual.json.length);
var doc = c1.document("something");
assertEqual({ foo: 1, bar: 42, baz: 3, bumm : 23 }, doc.values);
assertTrue(isEqual(doc, actual.json[0]));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsTrue : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn OPTIONS { mergeObjects: true }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
var doc = c1.document("something");
assertEqual({ foo: 1, bar: 42, baz: 3, bumm : 23 }, doc.values);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsTrueWhatNew : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn OPTIONS { mergeObjects: true } LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(1, actual.json.length);
var doc = c1.document("something");
assertEqual({ foo: 1, bar: 42, baz: 3, bumm : 23 }, doc.values);
assertTrue(isEqual(doc, actual.json[0]));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsFalse : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn OPTIONS { mergeObjects: false }", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
var doc = c1.document("something");
assertEqual({ bar: 42, bumm: 23 }, doc.values);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update mergeObjects
////////////////////////////////////////////////////////////////////////////////
testUpdateMergeObjectsFalseWhatNew : function () {
c1.save({ _key: "something", values: { foo: 1, bar: 2, baz: 3 } });
var expected = { writesExecuted: 1, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d._key == 'something' UPDATE d._key WITH { values: { bar: 42, bumm: 23 } } INTO @@cn OPTIONS { mergeObjects: false } LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(1, actual.json.length);
var doc = c1.document("something");
assertEqual({ bar: 42, bumm: 23 }, doc.values);
assertTrue(isEqual(doc, actual.json[0]));
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateFilter : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResults("FOR d IN @@cn FILTER d.value1 % 2 == 0 UPDATE d._key WITH { value2: 100 } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
if (i % 2 === 0) {
assertEqual(100, doc.value2);
}
else {
assertEqual("test" + i, doc.value2);
}
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateFilterWhatNew : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d.value1 % 2 == 0 UPDATE d._key WITH { value2: 100 } INTO @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(50, actual.json.length);
var keyArray = wrapToKeys(actual.json);
var count = 0;
for (var i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
if (i % 2 === 0) {
assertEqual(100, doc.value2);
}
else {
assertEqual("test" + i, doc.value2);
}
if (keyArray.hasOwnProperty(doc._key)) {
count++;
assertTrue(isEqual(doc, keyArray[doc._key]));
}
}
assertEqual(50, count);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateFilterWhatOld : function () {
var expected = { writesExecuted: 50, writesIgnored: 0 };
var actual = getModifyQueryResultsRaw("FOR d IN @@cn FILTER d.value1 % 2 == 0 UPDATE d._key WITH { value2: 100 } INTO @@cn LET updated = OLD RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
assertEqual(50, actual.json.length);
var keyArray = wrapToKeys(actual.json);
var count = 0;
for (var i = 0; i < 100; i += 2) {
var doc = c1.document("test" + i);
assertEqual(100, doc.value2);
count++;
assertEqual(i, keyArray[doc._key].value1);
}
assertEqual(50, count);
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateUpdate : function () {
var i;
var expected = { writesExecuted: 100, writesIgnored: 0 };
for (i = 0; i < 5; ++i) {
var actual = getModifyQueryResults("FOR d IN @@cn UPDATE d._key WITH { counter: HAS(d, 'counter') ? d.counter + 1 : 1 } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(5, doc.counter);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test update
////////////////////////////////////////////////////////////////////////////////
testUpdateUpdateWhatNew : function () {
var i, j;
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual=[];
for (j = 0; j < 5; ++j) {
actual[j] = getModifyQueryResultsRaw("FOR d IN @@cn UPDATE d._key WITH { counter: HAS(d, 'counter') ? d.counter + 1 : 1 } INTO @@cn LET updated = NEW RETURN updated", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual[j].stats));
assertEqual(100, actual[j].json.length);
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(5, doc.counter);
}
for (j = 0; j < 5; ++j) {
for (i = 0; i < 100; ++i) {
assertEqual(j + 1, actual[j].json[i].counter);
}
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplace1 : function () {
var i;
var expected = { writesExecuted: 100, writesIgnored: 0 };
for (i = 0; i < 5; ++i) {
var actual = getModifyQueryResults("FOR d IN @@cn REPLACE d._key WITH { value4: 12 } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertFalse(doc.hasOwnProperty("value2"));
assertFalse(doc.hasOwnProperty("value3"));
assertEqual(12, doc.value4);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplace1WhatNew : function () {
var i, j;
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual=[];
for (j = 0; j < 5; ++j) {
actual[j] = getModifyQueryResultsRaw("FOR d IN @@cn REPLACE d._key WITH { value4: 12 } INTO @@cn LET replaced = NEW RETURN replaced", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual[j].stats));
assertEqual(100, actual[j].json.length);
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertFalse(doc.hasOwnProperty("value2"));
assertFalse(doc.hasOwnProperty("value3"));
assertEqual(12, doc.value4);
}
for (j = 0; j < 5; ++j) {
for (i = 0; i < 100; ++i) {
assertFalse(actual[j].json[i].hasOwnProperty("value1"));
assertFalse(actual[j].json[i].hasOwnProperty("value2"));
assertFalse(actual[j].json[i].hasOwnProperty("value3"));
assertEqual(12, actual[j].json[i].value4);
}
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplace2 : function () {
var i;
var expected = { writesExecuted: 100, writesIgnored: 0 };
for (i = 0; i < 5; ++i) {
var actual = getModifyQueryResults("FOR d IN @@cn REPLACE { _key: d._key, value4: 13 } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertFalse(doc.hasOwnProperty("value2"));
assertFalse(doc.hasOwnProperty("value3"));
assertEqual(13, doc.value4);
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplace2WhatNew : function () {
var i, j;
var expected = { writesExecuted: 100, writesIgnored: 0 };
var actual=[];
for (j = 0; j < 5; ++j) {
actual[j] = getModifyQueryResultsRaw("FOR d IN @@cn REPLACE { _key: d._key, value4: " + j + " } INTO @@cn LET replaced = NEW RETURN replaced", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual[j].stats));
assertEqual(100, actual[j].json.length);
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertFalse(doc.hasOwnProperty("value1"));
assertFalse(doc.hasOwnProperty("value2"));
assertFalse(doc.hasOwnProperty("value3"));
assertEqual(4, doc.value4);
}
for (j = 0; j < 5; ++j) {
for (i = 0; i < 100; ++i) {
assertFalse(actual[j].json[i].hasOwnProperty("value1"));
assertFalse(actual[j].json[i].hasOwnProperty("value2"));
assertFalse(actual[j].json[i].hasOwnProperty("value3"));
assertEqual(j, actual[j].json[i].value4);
}
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplaceReplace : function () {
var i;
var expected = { writesExecuted: 100, writesIgnored: 0 };
for (i = 0; i < 5; ++i) {
var actual = getModifyQueryResults("FOR d IN @@cn REPLACE d._key WITH { value1: d.value1 + 1 } INTO @@cn", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual));
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i + 5, doc.value1);
assertFalse(doc.hasOwnProperty("value2"));
}
},
////////////////////////////////////////////////////////////////////////////////
/// @brief test replace
////////////////////////////////////////////////////////////////////////////////
testReplaceReplaceWhatNew : function () {
var i;
var expected = { writesExecuted: 100, writesIgnored: 0 };
for (i = 0; i < 5; ++i) {
var actual = getModifyQueryResultsRaw("FOR d IN @@cn REPLACE d._key WITH { value1: d.value1 + 1 } INTO @@cn LET replaced = NEW RETURN replaced", { "@cn": cn1 });
assertEqual(expected, sanitizeStats(actual.stats));
}
for (i = 0; i < 100; ++i) {
var doc = c1.document("test" + i);
assertEqual(i + 5, doc.value1);
assertFalse(doc.hasOwnProperty("value2"));
}
}
};
}
////////////////////////////////////////////////////////////////////////////////
/// @brief executes the test suites
////////////////////////////////////////////////////////////////////////////////
jsunity.run(ahuacatlModifySuite);
jsunity.run(ahuacatlRemoveSuite);
jsunity.run(ahuacatlInsertSuite);
jsunity.run(ahuacatlUpdateSuite);
return jsunity.done();
// Local Variables:
// mode: outline-minor
// outline-regexp: "^\\(/// @brief\\|/// @addtogroup\\|// --SECTION--\\|/// @page\\|/// @}\\)"
// End: