Skip to content

Commit

Permalink
Merge pull request #4293 from Tyriar/4292
Browse files Browse the repository at this point in the history
Log a warning if task queues exceed deadline by 20ms
  • Loading branch information
Tyriar authored Dec 6, 2022
2 parents ad1f2ac + 650cda3 commit 497df06
Showing 1 changed file with 10 additions and 1 deletion.
11 changes: 10 additions & 1 deletion src/common/TaskQueue.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,17 +66,26 @@ abstract class TaskQueue implements ITaskQueue {
this._idleCallback = undefined;
let taskDuration = 0;
let longestTask = 0;
let lastDeadlineRemaining = deadline.timeRemaining();
let deadlineRemaining = 0;
while (this._i < this._tasks.length) {
taskDuration = performance.now();
this._tasks[this._i++]();
taskDuration = performance.now() - taskDuration;
longestTask = Math.max(taskDuration, longestTask);
// Guess the following task will take a similar time to the longest task in this batch, allow
// additional room to try avoid exceeding the deadline
if (longestTask * 1.5 > deadline.timeRemaining()) {
deadlineRemaining = deadline.timeRemaining();
if (longestTask * 1.5 > deadlineRemaining) {
// Warn when the time exceeding the deadline is over 20ms, if this happens in practice the
// task should be split into sub-tasks to ensure the UI remains responsive.
if (lastDeadlineRemaining - taskDuration < -20) {
console.warn(`task queue exceeded allotted deadline by ${Math.abs(Math.round(lastDeadlineRemaining - taskDuration))}ms`);
}
this._start();
return;
}
lastDeadlineRemaining = deadlineRemaining;
}
this.clear();
}
Expand Down

0 comments on commit 497df06

Please sign in to comment.