Version 1 (modified by cotto, 5 years ago)

create a page to document the difficulties in testing the profiling runcore

The profiling runcore requires an unusual testing strategy for a number of reasons. This page exists to list those reasons and to serve as a way to ensure that any the eventual testing framework addresses all concerns.

Issues

randomness from timing information

A profile will contain a randomness in the form of timing information. It does not make sense to test for absolute values since tests must be able to succeed on slow machines as well as fast. It may make sense to test relative timing information, but even this is questionable. The best approach may be to enable the runcore to emit constant dummy timing information where all values are 1. This would also allow testing that times were added correctly and would simplify sanity checking.

data volume

The profile for even a short PIR program will be non-trivial in size. It must be easy for the testing code to specify which part of a profile it wants to test. Ideally the testing code would also avoid using PGE so that profiling tests could be run as part of coretest.