This clearly is a WIP. We know have the reporter granularity to capture
per mutation test outputs + per mutation test selections.
This adds all infrastructure to address:
* #185 we know which tests are run in reporter
* #180 fine grained information available for the reporter
* #178 minitest project integration only needs to return an enumerable
with metadata
* #174 We can now "see" all test, allowing to generate a default
matcher.
* #158 Ability to steer test selection centralized for all integrations
* #125 We have the required objects in graph
* #96 We have finer granularity in reporter graph
Because we know signal more complex state from killforks to parent I
need to bring back killfork partent signalling, but this time with
sending complex data around (Test::Report). Should be easy with
Marshal.{dump,load} but my OSS time budget is exhausted for now.
* Use the real time temporarily to be consistent with the other
places in the code that measure time. When those other areas can
be wrapped in a Benchmark.measure block all the benchmarks will be
updated to use cpu time, not real (elapsed) time like now.
* Currently broken (sorry) but do have to push to fix some nasty
transitive dependency stuff (do not ask).
* Fix fix it tomorrow (hopefully I find the time)
* Expand attr_reader :name, to def name; @name; end
As attr_reader defined methods do not have a valid source location.
* Expose more internal state to allow the generation of nice match
identifications. Needs to be cleaned up.