mirror of https://gitee.com/bigwinds/arangodb
291 lines
8.3 KiB
JavaScript
291 lines
8.3 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 = {
|
|
'authentication': 'authentication tests',
|
|
'authentication_server': 'authentication server tests',
|
|
'authentication_parameters': 'authentication parameters tests'
|
|
};
|
|
const optionsDocumentation = [
|
|
' - `skipAuthentication : testing authentication and authentication_paramaters will be skipped.'
|
|
];
|
|
|
|
const fs = require('fs');
|
|
const pu = require('@arangodb/process-utils');
|
|
const tu = require('@arangodb/test-utils');
|
|
const yaml = require('js-yaml');
|
|
|
|
// const BLUE = require('internal').COLORS.COLOR_BLUE;
|
|
const CYAN = require('internal').COLORS.COLOR_CYAN;
|
|
// const GREEN = require('internal').COLORS.COLOR_GREEN;
|
|
const RED = require('internal').COLORS.COLOR_RED;
|
|
const RESET = require('internal').COLORS.COLOR_RESET;
|
|
// const YELLOW = require('internal').COLORS.COLOR_YELLOW;
|
|
|
|
const download = require('internal').download;
|
|
|
|
const testPaths = {
|
|
'authentication': [tu.pathForTesting('client/authentication')],
|
|
'authentication_server': [tu.pathForTesting('server/authentication')],
|
|
'authentication_parameters': []
|
|
};
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief TEST: authentication
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
function authenticationClient (options) {
|
|
if (options.skipAuthentication === true) {
|
|
print('skipping Authentication tests!');
|
|
return {
|
|
authentication: {
|
|
status: true,
|
|
skipped: true
|
|
}
|
|
};
|
|
}
|
|
|
|
print(CYAN + 'Client Authentication tests...' + RESET);
|
|
let testCases = tu.scanTestPaths(testPaths.authentication);
|
|
|
|
testCases = tu.splitBuckets(options, testCases);
|
|
|
|
return tu.performTests(options, testCases, 'authentication', tu.runInArangosh, {
|
|
'server.authentication': 'true',
|
|
'server.jwt-secret': 'haxxmann',
|
|
'cluster.create-waits-for-sync-replication': false
|
|
});
|
|
}
|
|
|
|
function authenticationServer (options) {
|
|
let testCases = tu.scanTestPaths(testPaths.authentication_server);
|
|
|
|
testCases = tu.splitBuckets(options, testCases);
|
|
|
|
if ((testCases.length === 0) || (options.skipAuthentication === true)) {
|
|
print('skipping Authentication tests!');
|
|
return {
|
|
authentication: {
|
|
status: true,
|
|
skipped: true
|
|
}
|
|
};
|
|
}
|
|
|
|
print(CYAN + 'Server Authentication tests...' + RESET);
|
|
return tu.performTests(options, testCases, 'authentication_server', tu.runThere, {
|
|
'server.authentication': 'true',
|
|
'server.jwt-secret': 'haxxmann',
|
|
'cluster.create-waits-for-sync-replication': false
|
|
});
|
|
}
|
|
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
// / @brief TEST: authentication parameters
|
|
// //////////////////////////////////////////////////////////////////////////////
|
|
|
|
const authTestExpectRC = [
|
|
[401, 401, 401, 401, 401, 401, 401],
|
|
[401, 401, 401, 401, 401, 404, 404],
|
|
[404, 404, 200, 301, 301, 404, 404]
|
|
];
|
|
|
|
const authTestUrls = [
|
|
'/_api/',
|
|
'/_api',
|
|
'/_api/version',
|
|
'/_admin/html',
|
|
'/_admin/html/',
|
|
'/test',
|
|
'/the-big-fat-fox'
|
|
];
|
|
|
|
const authTestNames = [
|
|
'Full',
|
|
'SystemAuth',
|
|
'None'
|
|
];
|
|
|
|
const authTestServerParams = [{
|
|
'server.authentication': 'true',
|
|
'server.authentication-system-only': 'false'
|
|
}, {
|
|
'server.authentication': 'true',
|
|
'server.authentication-system-only': 'true'
|
|
}, {
|
|
'server.authentication': 'false',
|
|
'server.authentication-system-only': 'true'
|
|
}];
|
|
|
|
function checkBodyForJsonToParse (request) {
|
|
if (request.hasOwnProperty('body')) {
|
|
request.body = JSON.parse(request.hasOwnProperty('body'));
|
|
}
|
|
}
|
|
|
|
function authenticationParameters (options) {
|
|
if (options.skipAuthentication === true) {
|
|
print(CYAN + 'skipping Authentication with parameters tests!' + RESET);
|
|
return {
|
|
authentication_parameters: {
|
|
status: true,
|
|
skipped: true
|
|
}
|
|
};
|
|
}
|
|
|
|
if (options.cluster) {
|
|
print('skipping Authentication with parameters tests on cluster!');
|
|
return {
|
|
authentication: {
|
|
status: true,
|
|
skipped: true
|
|
}
|
|
};
|
|
}
|
|
|
|
print(CYAN + 'Authentication with parameters tests...' + RESET);
|
|
|
|
let downloadOptions = {
|
|
followRedirects: false,
|
|
returnBodyOnError: true
|
|
};
|
|
|
|
if (options.valgrind) {
|
|
downloadOptions.timeout = 300;
|
|
}
|
|
|
|
let continueTesting = true;
|
|
let results = {};
|
|
// we append one cleanup directory for the invoking logic...
|
|
let dummyDir = fs.join(fs.getTempPath(), 'authentication_dummy');
|
|
fs.makeDirectory(dummyDir);
|
|
pu.cleanupDBDirectoriesAppend(dummyDir);
|
|
|
|
for (let test = 0; test < 3; test++) {
|
|
let cleanup = true;
|
|
|
|
let instanceInfo = pu.startInstance('tcp', options,
|
|
authTestServerParams[test],
|
|
'authentication_parameters_' + authTestNames[test]);
|
|
|
|
if (instanceInfo === false) {
|
|
return {
|
|
authentication_parameters: {
|
|
status: false,
|
|
total: 1,
|
|
failed: 1,
|
|
message: authTestNames[test] + ': failed to start server!'
|
|
}
|
|
};
|
|
}
|
|
|
|
print(CYAN + Date() + ' Starting ' + authTestNames[test] + ' test' + RESET);
|
|
|
|
const testName = 'auth_' + authTestNames[test];
|
|
results[testName] = {
|
|
failed: 0,
|
|
total: 0
|
|
};
|
|
|
|
for (let i = 0; i < authTestUrls.length; i++) {
|
|
const authTestUrl = authTestUrls[i];
|
|
|
|
++results[testName].total;
|
|
|
|
print(CYAN + ' URL: ' + instanceInfo.url + authTestUrl + RESET);
|
|
|
|
if (!continueTesting) {
|
|
print(RED + 'Skipping ' + authTestUrl + ', server is gone.' + RESET);
|
|
|
|
results[testName][authTestUrl] = {
|
|
status: false,
|
|
message: instanceInfo.exitStatus
|
|
};
|
|
|
|
results[testName].failed++;
|
|
instanceInfo.exitStatus = 'server is gone.';
|
|
cleanup = false;
|
|
break;
|
|
}
|
|
|
|
let reply = download(instanceInfo.url + authTestUrl, '', downloadOptions);
|
|
|
|
if (reply.code === authTestExpectRC[test][i]) {
|
|
results[testName][authTestUrl] = {
|
|
status: true
|
|
};
|
|
} else {
|
|
checkBodyForJsonToParse(reply);
|
|
|
|
++results[testName].failed;
|
|
|
|
results[testName][authTestUrl] = {
|
|
status: false,
|
|
message: 'we expected ' +
|
|
authTestExpectRC[test][i] +
|
|
' and we got ' + reply.code +
|
|
' Full Status: ' + yaml.safeDump(reply)
|
|
};
|
|
cleanup = false;
|
|
}
|
|
|
|
continueTesting = pu.arangod.check.instanceAlive(instanceInfo, options);
|
|
}
|
|
|
|
results[testName].status = results[testName].failed === 0;
|
|
|
|
print(CYAN + 'Shutting down ' + authTestNames[test] + ' test...' + RESET);
|
|
pu.shutdownInstance(instanceInfo, options);
|
|
print(CYAN + 'done with ' + authTestNames[test] + ' test.' + RESET);
|
|
|
|
if (cleanup) {
|
|
pu.cleanupLastDirectory(options);
|
|
}
|
|
}
|
|
|
|
print();
|
|
|
|
return results;
|
|
}
|
|
|
|
exports.setup = function (testFns, defaultFns, opts, fnDocs, optionsDoc, allTestPaths) {
|
|
Object.assign(allTestPaths, testPaths);
|
|
testFns['authentication'] = authenticationClient;
|
|
testFns['authentication_server'] = authenticationServer;
|
|
testFns['authentication_parameters'] = authenticationParameters;
|
|
|
|
opts['skipAuthentication'] = false;
|
|
|
|
defaultFns.push('authentication');
|
|
defaultFns.push('authentication_server');
|
|
defaultFns.push('authentication_parameters');
|
|
|
|
for (var attrname in functionsDocumentation) { fnDocs[attrname] = functionsDocumentation[attrname]; }
|
|
for (var i = 0; i < optionsDocumentation.length; i++) { optionsDoc.push(optionsDocumentation[i]); }
|
|
};
|