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.
76 lines
2.5 KiB
76 lines
2.5 KiB
6 years ago
|
'use strict';
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.default = treeProcessor;
|
||
|
|
||
|
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"); }); }; }
|
||
|
|
||
|
// 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
|
||
|
/**
|
||
|
* 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.
|
||
|
*
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
const Promise = global[Symbol.for('jest-native-promise')] || global.Promise;
|
||
|
|
||
|
function treeProcessor(options) {
|
||
|
const nodeComplete = options.nodeComplete,
|
||
|
nodeStart = options.nodeStart,
|
||
|
queueRunnerFactory = options.queueRunnerFactory,
|
||
|
runnableIds = options.runnableIds,
|
||
|
tree = options.tree;
|
||
|
|
||
|
|
||
|
function isEnabled(node, parentEnabled) {
|
||
|
return parentEnabled || runnableIds.indexOf(node.id) !== -1;
|
||
|
}
|
||
|
|
||
|
return queueRunnerFactory({
|
||
|
onException: error => tree.onException(error),
|
||
|
queueableFns: wrapChildren(tree, isEnabled(tree, false)),
|
||
|
userContext: tree.sharedUserContext()
|
||
|
});
|
||
|
|
||
|
function executeNode(node, parentEnabled) {
|
||
|
const enabled = isEnabled(node, parentEnabled);
|
||
|
if (!node.children) {
|
||
|
return {
|
||
|
fn(done) {
|
||
|
node.execute(done, enabled);
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
return {
|
||
|
fn(done) {
|
||
|
return _asyncToGenerator(function* () {
|
||
|
nodeStart(node);
|
||
|
yield queueRunnerFactory({
|
||
|
onException: function (error) {
|
||
|
return node.onException(error);
|
||
|
},
|
||
|
queueableFns: wrapChildren(node, enabled),
|
||
|
userContext: node.sharedUserContext()
|
||
|
});
|
||
|
nodeComplete(node);
|
||
|
done();
|
||
|
})();
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
function wrapChildren(node, enabled) {
|
||
|
if (!node.children) {
|
||
|
throw new Error('`node.children` is not defined.');
|
||
|
}
|
||
|
const children = node.children.map(child => executeNode(child, enabled));
|
||
|
return node.beforeAllFns.concat(children).concat(node.afterAllFns);
|
||
|
}
|
||
|
}
|