fix(core): update
This commit is contained in:
parent
917e630554
commit
b2478d79f2
@ -11,7 +11,7 @@ let testSmartruleInstance: smartrule.SmartRule<ITestMessage>;
|
||||
tap.test('first test', async () => {
|
||||
testSmartruleInstance = new smartrule.SmartRule<ITestMessage>();
|
||||
testSmartruleInstance.createRule(
|
||||
0,
|
||||
2,
|
||||
async messageArg => {
|
||||
if (messageArg.body.startsWith('hello')) {
|
||||
return 'apply-stop';
|
||||
|
@ -26,8 +26,9 @@ export class SmartRule<T> {
|
||||
};
|
||||
|
||||
// lets run the checks
|
||||
const runNextBatch = async (startPriority: number): Promise<void> => {
|
||||
const nextBatch = getNextParallelBatch(0);
|
||||
const runNextBatch = async (startPriority: number, runRulesAmount: number): Promise<void> => {
|
||||
const nextBatch = getNextParallelBatch(startPriority);
|
||||
runRulesAmount = runRulesAmount + nextBatch.length;
|
||||
const outcomes: TTreeActionResult[] = [];
|
||||
for (const rule of nextBatch) {
|
||||
const checkResult = await rule.checkFunction(objectArg);
|
||||
@ -50,14 +51,14 @@ export class SmartRule<T> {
|
||||
}
|
||||
}
|
||||
|
||||
if (startPriority < this.rules[this.rules.length-1].priority) {
|
||||
await runNextBatch(startPriority++);
|
||||
if (runRulesAmount < this.rules.length) {
|
||||
await runNextBatch((startPriority + 1), runRulesAmount);
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
};
|
||||
|
||||
await runNextBatch(0);
|
||||
await runNextBatch(0,0);
|
||||
}
|
||||
|
||||
public createRule(priorityArg: number, checkFunctionArg: TCheckFunc<T>, actionFunctionArg: TActionFunc) {
|
||||
|
Loading…
Reference in New Issue
Block a user