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
45 lines
1.7 KiB
Plaintext
45 lines
1.7 KiB
Plaintext
import { AsyncAction } from './AsyncAction';
|
|
import { Subscription } from '../Subscription';
|
|
import { QueueScheduler } from './QueueScheduler';
|
|
import { SchedulerAction } from '../types';
|
|
import { TimerHandle } from './timerHandle';
|
|
|
|
export class QueueAction<T> extends AsyncAction<T> {
|
|
constructor(protected scheduler: QueueScheduler, protected work: (this: SchedulerAction<T>, state?: T) => void) {
|
|
super(scheduler, work);
|
|
}
|
|
|
|
public schedule(state?: T, delay: number = 0): Subscription {
|
|
if (delay > 0) {
|
|
return super.schedule(state, delay);
|
|
}
|
|
this.delay = delay;
|
|
this.state = state;
|
|
this.scheduler.flush(this);
|
|
return this;
|
|
}
|
|
|
|
public execute(state: T, delay: number): any {
|
|
return delay > 0 || this.closed ? super.execute(state, delay) : this._execute(state, delay);
|
|
}
|
|
|
|
protected requestAsyncId(scheduler: QueueScheduler, id?: TimerHandle, delay: number = 0): TimerHandle {
|
|
// If delay exists and is greater than 0, or if the delay is null (the
|
|
// action wasn't rescheduled) but was originally scheduled as an async
|
|
// action, then recycle as an async action.
|
|
|
|
if ((delay != null && delay > 0) || (delay == null && this.delay > 0)) {
|
|
return super.requestAsyncId(scheduler, id, delay);
|
|
}
|
|
|
|
// Otherwise flush the scheduler starting with this action.
|
|
scheduler.flush(this);
|
|
|
|
// HACK: In the past, this was returning `void`. However, `void` isn't a valid
|
|
// `TimerHandle`, and generally the return value here isn't really used. So the
|
|
// compromise is to return `0` which is both "falsy" and a valid `TimerHandle`,
|
|
// as opposed to refactoring every other instanceo of `requestAsyncId`.
|
|
return 0;
|
|
}
|
|
}
|