This app provides monitoring and information features for the common freifunk user and the technical stuff of a freifunk community.
Code base is taken from a TUM Practical Course project and added here to see if Freifunk Altdorf can use it.
https://www.freifunk-altdorf.de
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
524 lines
18 KiB
524 lines
18 KiB
6 years ago
|
'use strict';
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
|
||
|
exports.default = function (j$) {
|
||
|
function Env(options) {
|
||
|
options = options || {};
|
||
|
|
||
|
const self = this;
|
||
|
|
||
|
let totalSpecsDefined = 0;
|
||
|
|
||
|
let catchExceptions = true;
|
||
|
|
||
|
const realSetTimeout = global.setTimeout;
|
||
|
const realClearTimeout = global.clearTimeout;
|
||
|
|
||
|
const runnableResources = {};
|
||
|
let currentSpec = null;
|
||
|
const currentlyExecutingSuites = [];
|
||
|
let currentDeclarationSuite = null;
|
||
|
let throwOnExpectationFailure = false;
|
||
|
let random = false;
|
||
|
let seed = null;
|
||
|
|
||
|
const currentSuite = function () {
|
||
|
return currentlyExecutingSuites[currentlyExecutingSuites.length - 1];
|
||
|
};
|
||
|
|
||
|
const currentRunnable = function () {
|
||
|
return currentSpec || currentSuite();
|
||
|
};
|
||
|
|
||
|
const reporter = new j$.ReportDispatcher(['jasmineStarted', 'jasmineDone', 'suiteStarted', 'suiteDone', 'specStarted', 'specDone']);
|
||
|
|
||
|
this.specFilter = function () {
|
||
|
return true;
|
||
|
};
|
||
|
|
||
|
let nextSpecId = 0;
|
||
|
const getNextSpecId = function () {
|
||
|
return 'spec' + nextSpecId++;
|
||
|
};
|
||
|
|
||
|
let nextSuiteId = 0;
|
||
|
const getNextSuiteId = function () {
|
||
|
return 'suite' + nextSuiteId++;
|
||
|
};
|
||
|
|
||
|
const defaultResourcesForRunnable = function (id, parentRunnableId) {
|
||
|
const resources = { spies: [] };
|
||
|
|
||
|
runnableResources[id] = resources;
|
||
|
};
|
||
|
|
||
|
const clearResourcesForRunnable = function (id) {
|
||
|
spyRegistry.clearSpies();
|
||
|
delete runnableResources[id];
|
||
|
};
|
||
|
|
||
|
const beforeAndAfterFns = function (suite) {
|
||
|
return function () {
|
||
|
let afters = [];
|
||
|
let befores = [];
|
||
|
|
||
|
while (suite) {
|
||
|
befores = befores.concat(suite.beforeFns);
|
||
|
afters = afters.concat(suite.afterFns);
|
||
|
|
||
|
suite = suite.parentSuite;
|
||
|
}
|
||
|
|
||
|
return {
|
||
|
befores: befores.reverse(),
|
||
|
afters
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
const getSpecName = function (spec, suite) {
|
||
|
const fullName = [spec.description];
|
||
|
const suiteFullName = suite.getFullName();
|
||
|
|
||
|
if (suiteFullName !== '') {
|
||
|
fullName.unshift(suiteFullName);
|
||
|
}
|
||
|
|
||
|
return fullName.join(' ');
|
||
|
};
|
||
|
|
||
|
this.catchExceptions = function (value) {
|
||
|
catchExceptions = !!value;
|
||
|
return catchExceptions;
|
||
|
};
|
||
|
|
||
|
this.catchingExceptions = function () {
|
||
|
return catchExceptions;
|
||
|
};
|
||
|
|
||
|
this.throwOnExpectationFailure = function (value) {
|
||
|
throwOnExpectationFailure = !!value;
|
||
|
};
|
||
|
|
||
|
this.throwingExpectationFailures = function () {
|
||
|
return throwOnExpectationFailure;
|
||
|
};
|
||
|
|
||
|
this.randomizeTests = function (value) {
|
||
|
random = !!value;
|
||
|
};
|
||
|
|
||
|
this.randomTests = function () {
|
||
|
return random;
|
||
|
};
|
||
|
|
||
|
this.seed = function (value) {
|
||
|
if (value) {
|
||
|
seed = value;
|
||
|
}
|
||
|
return seed;
|
||
|
};
|
||
|
|
||
|
function queueRunnerFactory(options) {
|
||
|
options.clearTimeout = realClearTimeout;
|
||
|
options.fail = self.fail;
|
||
|
options.setTimeout = realSetTimeout;
|
||
|
return (0, _queue_runner2.default)(options);
|
||
|
}
|
||
|
|
||
|
const topSuite = new j$.Suite({
|
||
|
id: getNextSuiteId(),
|
||
|
getTestPath() {
|
||
|
return j$.testPath;
|
||
|
}
|
||
|
});
|
||
|
defaultResourcesForRunnable(topSuite.id);
|
||
|
currentDeclarationSuite = topSuite;
|
||
|
|
||
|
this.topSuite = function () {
|
||
|
return topSuite;
|
||
|
};
|
||
|
|
||
|
this.execute = (() => {
|
||
|
var _ref = _asyncToGenerator(function* (runnablesToRun) {
|
||
|
if (!runnablesToRun) {
|
||
|
if (focusedRunnables.length) {
|
||
|
runnablesToRun = focusedRunnables;
|
||
|
} else {
|
||
|
runnablesToRun = [topSuite.id];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
const uncaught = function (err) {
|
||
|
if (currentSpec) {
|
||
|
currentSpec.onException(err);
|
||
|
currentSpec.cancel();
|
||
|
} else {
|
||
|
console.error('Unhandled error');
|
||
|
console.error(err.stack);
|
||
|
}
|
||
|
};
|
||
|
|
||
|
// Need to ensure we are the only ones handling these exceptions.
|
||
|
const oldListenersException = process.listeners('uncaughtException').slice();
|
||
|
const oldListenersRejection = process.listeners('unhandledRejection').slice();
|
||
|
|
||
|
j$.process.removeAllListeners('uncaughtException');
|
||
|
j$.process.removeAllListeners('unhandledRejection');
|
||
|
|
||
|
j$.process.on('uncaughtException', uncaught);
|
||
|
j$.process.on('unhandledRejection', uncaught);
|
||
|
|
||
|
reporter.jasmineStarted({ totalSpecsDefined });
|
||
|
|
||
|
currentlyExecutingSuites.push(topSuite);
|
||
|
|
||
|
yield (0, _tree_processor2.default)({
|
||
|
nodeComplete(suite) {
|
||
|
if (!suite.disabled) {
|
||
|
clearResourcesForRunnable(suite.id);
|
||
|
}
|
||
|
currentlyExecutingSuites.pop();
|
||
|
reporter.suiteDone(suite.getResult());
|
||
|
},
|
||
|
nodeStart(suite) {
|
||
|
currentlyExecutingSuites.push(suite);
|
||
|
defaultResourcesForRunnable(suite.id, suite.parentSuite.id);
|
||
|
reporter.suiteStarted(suite.result);
|
||
|
},
|
||
|
queueRunnerFactory,
|
||
|
runnableIds: runnablesToRun,
|
||
|
tree: topSuite
|
||
|
});
|
||
|
clearResourcesForRunnable(topSuite.id);
|
||
|
currentlyExecutingSuites.pop();
|
||
|
reporter.jasmineDone({
|
||
|
failedExpectations: topSuite.result.failedExpectations
|
||
|
});
|
||
|
|
||
|
j$.process.removeListener('uncaughtException', uncaught);
|
||
|
j$.process.removeListener('unhandledRejection', uncaught);
|
||
|
|
||
|
// restore previous exception handlers
|
||
|
oldListenersException.forEach(function (listener) {
|
||
|
j$.process.on('uncaughtException', listener);
|
||
|
});
|
||
|
|
||
|
oldListenersRejection.forEach(function (listener) {
|
||
|
j$.process.on('unhandledRejection', listener);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
return function (_x) {
|
||
|
return _ref.apply(this, arguments);
|
||
|
};
|
||
|
})();
|
||
|
|
||
|
this.addReporter = function (reporterToAdd) {
|
||
|
reporter.addReporter(reporterToAdd);
|
||
|
};
|
||
|
|
||
|
this.provideFallbackReporter = function (reporterToAdd) {
|
||
|
reporter.provideFallbackReporter(reporterToAdd);
|
||
|
};
|
||
|
|
||
|
this.clearReporters = function () {
|
||
|
reporter.clearReporters();
|
||
|
};
|
||
|
|
||
|
const spyRegistry = new j$.SpyRegistry({
|
||
|
currentSpies() {
|
||
|
if (!currentRunnable()) {
|
||
|
throw new Error('Spies must be created in a before function or a spec');
|
||
|
}
|
||
|
return runnableResources[currentRunnable().id].spies;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
this.allowRespy = function (allow) {
|
||
|
spyRegistry.allowRespy(allow);
|
||
|
};
|
||
|
|
||
|
this.spyOn = function () {
|
||
|
return spyRegistry.spyOn.apply(spyRegistry, arguments);
|
||
|
};
|
||
|
|
||
|
const suiteFactory = function (description) {
|
||
|
const suite = new j$.Suite({
|
||
|
id: getNextSuiteId(),
|
||
|
description,
|
||
|
parentSuite: currentDeclarationSuite,
|
||
|
throwOnExpectationFailure,
|
||
|
getTestPath() {
|
||
|
return j$.testPath;
|
||
|
}
|
||
|
});
|
||
|
|
||
|
return suite;
|
||
|
};
|
||
|
|
||
|
this.describe = function (description, specDefinitions) {
|
||
|
const suite = suiteFactory(description);
|
||
|
if (specDefinitions.length > 0) {
|
||
|
throw new Error('describe does not expect any arguments');
|
||
|
}
|
||
|
if (currentDeclarationSuite.markedPending) {
|
||
|
suite.pend();
|
||
|
}
|
||
|
addSpecsToSuite(suite, specDefinitions);
|
||
|
return suite;
|
||
|
};
|
||
|
|
||
|
this.xdescribe = function (description, specDefinitions) {
|
||
|
const suite = suiteFactory(description);
|
||
|
suite.pend();
|
||
|
addSpecsToSuite(suite, specDefinitions);
|
||
|
return suite;
|
||
|
};
|
||
|
|
||
|
const focusedRunnables = [];
|
||
|
|
||
|
this.fdescribe = function (description, specDefinitions) {
|
||
|
const suite = suiteFactory(description);
|
||
|
suite.isFocused = true;
|
||
|
|
||
|
focusedRunnables.push(suite.id);
|
||
|
unfocusAncestor();
|
||
|
addSpecsToSuite(suite, specDefinitions);
|
||
|
|
||
|
return suite;
|
||
|
};
|
||
|
|
||
|
function addSpecsToSuite(suite, specDefinitions) {
|
||
|
const parentSuite = currentDeclarationSuite;
|
||
|
parentSuite.addChild(suite);
|
||
|
currentDeclarationSuite = suite;
|
||
|
|
||
|
let declarationError = null;
|
||
|
try {
|
||
|
specDefinitions.call(suite);
|
||
|
} catch (e) {
|
||
|
declarationError = e;
|
||
|
}
|
||
|
|
||
|
if (declarationError) {
|
||
|
self.it('encountered a declaration exception', () => {
|
||
|
throw declarationError;
|
||
|
});
|
||
|
}
|
||
|
|
||
|
currentDeclarationSuite = parentSuite;
|
||
|
}
|
||
|
|
||
|
function findFocusedAncestor(suite) {
|
||
|
while (suite) {
|
||
|
if (suite.isFocused) {
|
||
|
return suite.id;
|
||
|
}
|
||
|
suite = suite.parentSuite;
|
||
|
}
|
||
|
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
function unfocusAncestor() {
|
||
|
const focusedAncestor = findFocusedAncestor(currentDeclarationSuite);
|
||
|
if (focusedAncestor) {
|
||
|
for (let i = 0; i < focusedRunnables.length; i++) {
|
||
|
if (focusedRunnables[i] === focusedAncestor) {
|
||
|
focusedRunnables.splice(i, 1);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
const specFactory = function (description, fn, suite, timeout) {
|
||
|
totalSpecsDefined++;
|
||
|
const spec = new j$.Spec({
|
||
|
id: getNextSpecId(),
|
||
|
beforeAndAfterFns: beforeAndAfterFns(suite),
|
||
|
resultCallback: specResultCallback,
|
||
|
getSpecName(spec) {
|
||
|
return getSpecName(spec, suite);
|
||
|
},
|
||
|
getTestPath() {
|
||
|
return j$.testPath;
|
||
|
},
|
||
|
onStart: specStarted,
|
||
|
description,
|
||
|
queueRunnerFactory,
|
||
|
userContext() {
|
||
|
return suite.clonedSharedUserContext();
|
||
|
},
|
||
|
queueableFn: {
|
||
|
fn,
|
||
|
timeout() {
|
||
|
return timeout || j$.DEFAULT_TIMEOUT_INTERVAL;
|
||
|
}
|
||
|
},
|
||
|
throwOnExpectationFailure
|
||
|
});
|
||
|
|
||
|
if (!self.specFilter(spec)) {
|
||
|
spec.disable();
|
||
|
}
|
||
|
|
||
|
return spec;
|
||
|
|
||
|
function specResultCallback(result) {
|
||
|
clearResourcesForRunnable(spec.id);
|
||
|
currentSpec = null;
|
||
|
reporter.specDone(result);
|
||
|
}
|
||
|
|
||
|
function specStarted(spec) {
|
||
|
currentSpec = spec;
|
||
|
defaultResourcesForRunnable(spec.id, suite.id);
|
||
|
reporter.specStarted(spec.result);
|
||
|
}
|
||
|
};
|
||
|
|
||
|
this.it = function (description, fn, timeout) {
|
||
|
const spec = specFactory(description, fn, currentDeclarationSuite, timeout);
|
||
|
if (currentDeclarationSuite.markedPending) {
|
||
|
spec.pend();
|
||
|
}
|
||
|
|
||
|
// When a test is defined inside another, jasmine will not run it.
|
||
|
// This check throws an error to warn the user about the edge-case.
|
||
|
if (currentSpec !== null) {
|
||
|
throw new Error('Tests cannot be nested. Test `' + spec.description + '` cannot run because it is nested within `' + currentSpec.description + '`.');
|
||
|
}
|
||
|
currentDeclarationSuite.addChild(spec);
|
||
|
return spec;
|
||
|
};
|
||
|
|
||
|
this.xit = function () {
|
||
|
const spec = this.it.apply(this, arguments);
|
||
|
spec.pend('Temporarily disabled with xit');
|
||
|
return spec;
|
||
|
};
|
||
|
|
||
|
this.fit = function (description, fn, timeout) {
|
||
|
const spec = specFactory(description, fn, currentDeclarationSuite, timeout);
|
||
|
currentDeclarationSuite.addChild(spec);
|
||
|
focusedRunnables.push(spec.id);
|
||
|
unfocusAncestor();
|
||
|
return spec;
|
||
|
};
|
||
|
|
||
|
this.beforeEach = function (beforeEachFunction, timeout) {
|
||
|
currentDeclarationSuite.beforeEach({
|
||
|
fn: beforeEachFunction,
|
||
|
timeout() {
|
||
|
return timeout || j$.DEFAULT_TIMEOUT_INTERVAL;
|
||
|
}
|
||
|
});
|
||
|
};
|
||
|
|
||
|
this.beforeAll = function (beforeAllFunction, timeout) {
|
||
|
currentDeclarationSuite.beforeAll({
|
||
|
fn: beforeAllFunction,
|
||
|
timeout() {
|
||
|
return timeout || j$.DEFAULT_TIMEOUT_INTERVAL;
|
||
|
}
|
||
|
});
|
||
|
};
|
||
|
|
||
|
this.afterEach = function (afterEachFunction, timeout) {
|
||
|
currentDeclarationSuite.afterEach({
|
||
|
fn: afterEachFunction,
|
||
|
timeout() {
|
||
|
return timeout || j$.DEFAULT_TIMEOUT_INTERVAL;
|
||
|
}
|
||
|
});
|
||
|
};
|
||
|
|
||
|
this.afterAll = function (afterAllFunction, timeout) {
|
||
|
currentDeclarationSuite.afterAll({
|
||
|
fn: afterAllFunction,
|
||
|
timeout() {
|
||
|
return timeout || j$.DEFAULT_TIMEOUT_INTERVAL;
|
||
|
}
|
||
|
});
|
||
|
};
|
||
|
|
||
|
this.pending = function (message) {
|
||
|
let fullMessage = j$.Spec.pendingSpecExceptionMessage;
|
||
|
if (message) {
|
||
|
fullMessage += message;
|
||
|
}
|
||
|
throw fullMessage;
|
||
|
};
|
||
|
|
||
|
this.fail = function (error) {
|
||
|
let message = 'Failed';
|
||
|
if (error) {
|
||
|
message += ': ';
|
||
|
message += error.message || error;
|
||
|
}
|
||
|
|
||
|
currentRunnable().addExpectationResult(false, {
|
||
|
matcherName: '',
|
||
|
passed: false,
|
||
|
expected: '',
|
||
|
actual: '',
|
||
|
message,
|
||
|
error: error && error.message ? error : null
|
||
|
});
|
||
|
};
|
||
|
}
|
||
|
|
||
|
return Env;
|
||
|
};
|
||
|
|
||
|
var _queue_runner = require('../queue_runner');
|
||
|
|
||
|
var _queue_runner2 = _interopRequireDefault(_queue_runner);
|
||
|
|
||
|
var _tree_processor = require('../tree_processor');
|
||
|
|
||
|
var _tree_processor2 = _interopRequireDefault(_tree_processor);
|
||
|
|
||
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
|
||
|
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; } /**
|
||
|
* Copyright (c) 2014-present, Facebook, Inc. All rights reserved.
|
||
|
*
|
||
|
* This source code is licensed under the MIT license found in the
|
||
|
* LICENSE file in the root directory of this source tree.
|
||
|
*
|
||
|
*/
|
||
|
// This file is a heavily modified fork of Jasmine. Original license:
|
||
|
/*
|
||
|
Copyright (c) 2008-2016 Pivotal Labs
|
||
|
|
||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||
|
a copy of this software and associated documentation files (the
|
||
|
"Software"), to deal in the Software without restriction, including
|
||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||
|
permit persons to whom the Software is furnished to do so, subject to
|
||
|
the following conditions:
|
||
|
|
||
|
The above copyright notice and this permission notice shall be
|
||
|
included in all copies or substantial portions of the Software.
|
||
|
|
||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
*/
|
||
|
/* eslint-disable sort-keys */
|
||
|
|
||
|
// Try getting the real promise object from the context, if available. Someone
|
||
|
// could have overridden it in a test. Async functions return it implicitly.
|
||
|
// eslint-disable-next-line no-unused-vars
|
||
|
const Promise = global[Symbol.for('jest-native-promise')] || global.Promise;
|