bestiejs/benchmark.js

Help handling errors in defer mode

Finesse opened this issue · 0 comments

Similar to #123

When an unexpected error happens in a deferred test case, the case doesn’t call deferred.resolve() and the whole benchmarking process hangs forever. There is nothing I can do with it without using monkey patches. This is in contrast to non-defer mode, and I find this difference illogical.

Benchmark.js is used in jsbench.me. It’s a public platform for making browser JS benchmarks. Since browsers are different, and benchmarks can be run by random people, unexpected errors will happen, and therefore benchmark.js should help handle them. I see a couple of ways for benchmark.js to help:

  1. Add a timeout for test cases. When a timeout happens, the benchmark will continue running other cases so that the user will know the results for other cases.
  2. Add a function like deferred.reject(error). I’ll be able to catch unexpected errors and let benchmark.js know that a test case has failed, and it will stop the case and continue running other cases.

You may object that a test case should never fail, therefore my issue isn’t an issue. But the reality is that some test cases will never succeed in some cases (sorry for the pun), for example when a test case uses an API that isn’t implemented in the browser. What should I do in this situation?

I’ve made a simile issue in the jsbench.me repository: psiho/jsbench-me#43