mirror of https://gitee.com/bigwinds/arangodb
test for broken indexes (#8103)
This commit is contained in:
parent
7127b6edb7
commit
581f9f362b
|
@ -182,6 +182,10 @@ static arangodb::Result fillIndex(RocksDBIndex& ridx, WriteBatchType& batch,
|
|||
THROW_ARANGO_EXCEPTION(res);
|
||||
}
|
||||
|
||||
TRI_IF_FAILURE("RocksDBBuilderIndex::fillIndex") {
|
||||
FATAL_ERROR_EXIT();
|
||||
}
|
||||
|
||||
uint64_t numDocsWritten = 0;
|
||||
auto state = RocksDBTransactionState::toState(&trx);
|
||||
RocksDBTransactionCollection* trxColl = trx.resolveTrxCollection();
|
||||
|
|
|
@ -0,0 +1,90 @@
|
|||
/* jshint globalstrict:false, strict:false, unused : false */
|
||||
/* global assertEqual, assertFalse, assertTrue */
|
||||
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
// / @brief tests for dump/reload
|
||||
// /
|
||||
// / @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 db = require('@arangodb').db;
|
||||
var internal = require('internal');
|
||||
var jsunity = require('jsunity');
|
||||
|
||||
function runSetup () {
|
||||
'use strict';
|
||||
internal.debugClearFailAt();
|
||||
|
||||
db._drop('UnitTestsRecovery1');
|
||||
var c = db._create('UnitTestsRecovery1'), i;
|
||||
|
||||
for (i = 0; i < 1000; ++i) {
|
||||
c.save({ value: i });
|
||||
}
|
||||
|
||||
internal.debugSetFailAt("RocksDBBuilderIndex::fillIndex");
|
||||
c.ensureSkiplist('value'); // should crash
|
||||
}
|
||||
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
// / @brief test suite
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
function recoverySuite () {
|
||||
'use strict';
|
||||
jsunity.jsUnity.attachAssertions();
|
||||
|
||||
return {
|
||||
setUp: function () {},
|
||||
tearDown: function () {},
|
||||
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
// / @brief test whether we can restore the trx data
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
testBrokenIndex: function () {
|
||||
const c = db._collection('UnitTestsRecovery1');
|
||||
const indexes = c.getIndexes();
|
||||
assertEqual(indexes.length, 1);
|
||||
assertEqual(indexes[0].type, 'primary');
|
||||
assertEqual(indexes[0].id, 'UnitTestsRecovery1/0');
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
// / @brief executes the test suite
|
||||
// //////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
function main (argv) {
|
||||
'use strict';
|
||||
if (argv[1] === 'setup') {
|
||||
runSetup();
|
||||
return 0;
|
||||
} else {
|
||||
jsunity.run(recoverySuite);
|
||||
return jsunity.writeDone().status ? 0 : 1;
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue