mirror of https://gitee.com/bigwinds/arangodb
208 lines
6.1 KiB
JavaScript
208 lines
6.1 KiB
JavaScript
/* jshint strict: false, sub: true */
|
|
/* global print */
|
|
'use strict';
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / DISCLAIMER
|
|
// /
|
|
// / Copyright 2016 ArangoDB GmbH, Cologne, Germany
|
|
// / Copyright 2014 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 ArangoDB GmbH, Cologne, Germany
|
|
// /
|
|
// / @author Max Neunhoeffer
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
const functionsDocumentation = {
|
|
'replication_ongoing': 'replication ongoing tests',
|
|
'replication_static': 'replication static tests',
|
|
'replication_sync': 'replication sync tests'
|
|
};
|
|
const optionsDocumentation = [
|
|
];
|
|
|
|
const pu = require('@arangodb/process-utils');
|
|
const tu = require('@arangodb/test-utils');
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief TEST: replication_ongoing
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
function replicationOngoing (options) {
|
|
let master = pu.startInstance('tcp', options, {}, 'master_ongoing');
|
|
const mr = tu.makeResults('replication', master);
|
|
|
|
if (master === false) {
|
|
return mr(false, 'failed to start master!');
|
|
}
|
|
|
|
let slave = pu.startInstance('tcp', options, {}, 'slave_ongoing');
|
|
|
|
if (slave === false) {
|
|
pu.shutdownInstance(master, options);
|
|
return mr(false, 'failed to start slave!');
|
|
}
|
|
|
|
let results = {};
|
|
let reply = tu.runInArangosh(
|
|
options,
|
|
master,
|
|
'./js/server/tests/replication/replication-ongoing.js',
|
|
{'flatCommands': slave.endpoint}
|
|
);
|
|
|
|
if (reply.hasOwnProperty('status')) {
|
|
results['replication_ongoing'] = reply;
|
|
} else {
|
|
results['replication_ongoing'] = {
|
|
status: false,
|
|
message: 'replication-ongoing.js failed: ' + JSON.stringify(reply)
|
|
};
|
|
}
|
|
|
|
print('Shutting down...');
|
|
pu.shutdownInstance(slave, options);
|
|
pu.shutdownInstance(master, options);
|
|
print('done.');
|
|
|
|
return results;
|
|
}
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief TEST: replication_static
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
function replicationStatic (options) {
|
|
let master = pu.startInstance('tcp', options, {
|
|
'server.authentication': 'true'
|
|
}, 'master_static');
|
|
|
|
const mr = tu.makeResults('replication', master);
|
|
|
|
if (master === false) {
|
|
return mr(false, 'failed to start master!');
|
|
}
|
|
|
|
let slave = pu.startInstance('tcp', options, {}, 'slave_static');
|
|
|
|
if (slave === false) {
|
|
pu.shutdownInstance(master, options);
|
|
return mr(false, 'failed to start slave!');
|
|
}
|
|
|
|
let res = pu.run.arangoshCmd(options, master, {}, [
|
|
'--javascript.execute-string',
|
|
'var users = require("@arangodb/users"); ' +
|
|
'users.save("replicator-user", "replicator-password", true); ' +
|
|
'users.grantDatabase("replicator-user", "_system"); ' +
|
|
'users.reload();'
|
|
]);
|
|
|
|
let results = {};
|
|
|
|
if (res.status) {
|
|
let reply = tu.runInArangosh(
|
|
options,
|
|
master,
|
|
'./js/server/tests/replication/replication-static.js',
|
|
{'flatCommands': slave.endpoint}
|
|
);
|
|
|
|
if (reply.hasOwnProperty('status')) {
|
|
results['replication_static'] = reply;
|
|
} else {
|
|
results['replication_static'] = {
|
|
status: false,
|
|
message: 'replication-static.js failed: ' + JSON.stringify(reply)
|
|
};
|
|
}
|
|
} else {
|
|
results = mr(false, 'cannot create users');
|
|
}
|
|
|
|
print('Shutting down...');
|
|
pu.shutdownInstance(slave, options);
|
|
pu.shutdownInstance(master, options);
|
|
print('done.');
|
|
|
|
return results;
|
|
}
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief TEST: replication_sync
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
function replicationSync (options) {
|
|
let master = pu.startInstance('tcp', options, {}, 'master_sync');
|
|
|
|
const mr = tu.makeResults('replication', master);
|
|
if (master === false) {
|
|
return mr(false, 'failed to start master!');
|
|
}
|
|
|
|
let slave = pu.startInstance('tcp', options, {}, 'slave_sync');
|
|
|
|
if (slave === false) {
|
|
pu.shutdownInstance(master, options);
|
|
return mr(false, 'failed to start slave!');
|
|
}
|
|
|
|
let res = pu.run.arangoshCmd(options, master, {}, [
|
|
'--javascript.execute-string',
|
|
'var users = require("@arangodb/users"); ' +
|
|
'users.save("replicator-user", "replicator-password", true); ' +
|
|
'users.reload();'
|
|
]);
|
|
|
|
let results = {};
|
|
|
|
if (res.status) {
|
|
let reply = tu.runInArangosh(
|
|
options,
|
|
master,
|
|
'./js/server/tests/replication/replication-sync.js',
|
|
{'flatCommands': slave.endpoint}
|
|
);
|
|
|
|
if (reply.hasOwnProperty('status')) {
|
|
results['replication_sync'] = reply;
|
|
} else {
|
|
results['replication_sync'] = {
|
|
status: false,
|
|
message: 'replication-sync.js failed: ' + JSON.stringify(reply)
|
|
};
|
|
}
|
|
} else {
|
|
results = mr(false, 'cannot create users');
|
|
}
|
|
|
|
print('Shutting down...');
|
|
pu.shutdownInstance(slave, options);
|
|
pu.shutdownInstance(master, options);
|
|
print('done.');
|
|
|
|
return results;
|
|
}
|
|
|
|
function setup (testFns, defaultFns, opts, fnDocs, optionsDoc) {
|
|
testFns['replication_ongoing'] = replicationOngoing;
|
|
testFns['replication_static'] = replicationStatic;
|
|
testFns['replication_sync'] = replicationSync;
|
|
for (var attrname in functionsDocumentation) { fnDocs[attrname] = functionsDocumentation[attrname]; }
|
|
for (var i = 0; i < optionsDocumentation.length; i++) { optionsDoc.push(optionsDocumentation[i]); }
|
|
}
|
|
|
|
exports.setup = setup;
|