()
| 66 | let rendersConsumed = output.writeCount; |
| 67 | |
| 68 | function nextRender(): Promise<void> { |
| 69 | const waitForRender = |
| 70 | output.writeCount > rendersConsumed |
| 71 | ? Promise.resolve() |
| 72 | : new Promise<void>((resolve) => output.once('render', resolve)); |
| 73 | |
| 74 | // After detecting a render, let the event loop settle so that multiple |
| 75 | // synchronous-ish renders (e.g. validation: loading → error) are coalesced. |
| 76 | return waitForRender.then( |
| 77 | () => |
| 78 | new Promise<void>((resolve) => { |
| 79 | setImmediate(() => { |
| 80 | rendersConsumed = output.writeCount; |
| 81 | resolve(); |
| 82 | }); |
| 83 | }), |
| 84 | ); |
| 85 | } |
| 86 | |
| 87 | return { |
| 88 | answer, |
no outgoing calls
no test coverage detected