Some checks failed
Main Confidence / confidence (push) Failing after 45s
## Summary - introduce surface-aware compressed governance outcomes and reuse the shared truth/explanation seams for operator-first summaries - apply the compressed outcome hierarchy across baseline, evidence, review, review-pack, canonical review/evidence, and artifact-oriented operation-run surfaces - expand spec 214 fixtures and Pest coverage, and fix tenant-panel route assertions by generating explicit tenant-panel URLs in the affected Filament tests ## Validation - `cd apps/platform && ./vendor/bin/sail bin pint --dirty --format agent` - focused governance compression suite from `specs/214-governance-outcome-compression/quickstart.md` passed (`68` tests, `445` assertions) - `cd apps/platform && ./vendor/bin/sail artisan test --compact tests/Feature/Filament/InventoryItemResourceTest.php tests/Feature/Filament/BackupSetUiEnforcementTest.php tests/Feature/Filament/RestoreRunUiEnforcementTest.php` passed (`18` tests, `81` assertions) Co-authored-by: Ahmed Darrazi <ahmed.darrazi@live.de> Reviewed-on: #253
76 lines
1.8 KiB
Plaintext
76 lines
1.8 KiB
Plaintext
var async = require('./async.js')
|
|
, abort = require('./abort.js')
|
|
;
|
|
|
|
// API
|
|
module.exports = iterate;
|
|
|
|
/**
|
|
* Iterates over each job object
|
|
*
|
|
* @param {array|object} list - array or object (named list) to iterate over
|
|
* @param {function} iterator - iterator to run
|
|
* @param {object} state - current job status
|
|
* @param {function} callback - invoked when all elements processed
|
|
*/
|
|
function iterate(list, iterator, state, callback)
|
|
{
|
|
// store current index
|
|
var key = state['keyedList'] ? state['keyedList'][state.index] : state.index;
|
|
|
|
state.jobs[key] = runJob(iterator, key, list[key], function(error, output)
|
|
{
|
|
// don't repeat yourself
|
|
// skip secondary callbacks
|
|
if (!(key in state.jobs))
|
|
{
|
|
return;
|
|
}
|
|
|
|
// clean up jobs
|
|
delete state.jobs[key];
|
|
|
|
if (error)
|
|
{
|
|
// don't process rest of the results
|
|
// stop still active jobs
|
|
// and reset the list
|
|
abort(state);
|
|
}
|
|
else
|
|
{
|
|
state.results[key] = output;
|
|
}
|
|
|
|
// return salvaged results
|
|
callback(error, state.results);
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Runs iterator over provided job element
|
|
*
|
|
* @param {function} iterator - iterator to invoke
|
|
* @param {string|number} key - key/index of the element in the list of jobs
|
|
* @param {mixed} item - job description
|
|
* @param {function} callback - invoked after iterator is done with the job
|
|
* @returns {function|mixed} - job abort function or something else
|
|
*/
|
|
function runJob(iterator, key, item, callback)
|
|
{
|
|
var aborter;
|
|
|
|
// allow shortcut if iterator expects only two arguments
|
|
if (iterator.length == 2)
|
|
{
|
|
aborter = iterator(item, async(callback));
|
|
}
|
|
// otherwise go with full three arguments
|
|
else
|
|
{
|
|
aborter = iterator(item, key, async(callback));
|
|
}
|
|
|
|
return aborter;
|
|
}
|