This post is a peek behind the curtain of the next major update to Smoketest which I hope to have completed shortly: Performance Case visualisations.
Smoketest has always had two types of test case that you could implement by deriving from two distinct base classes:
TTestCase is the base class for correctness testing.
TPerformanceCase is the base class for performance testing.
The performance cases were what I used some years ago to compare the string handling performance of the RTL in different versions of Delphi around the time that the switch was made to Unicode.
I noted at the time that I was compiling the results manually to obtain the comparison data, but the raw data for those comparisons was coming from a Smoketest project that I put together to perform the actual tests.
I had always intended to implement improved data capture and visualisations and I am now finally getting around to it.
It is still very much a work in progress at this stage, but I have capture and comparisons implemented for running the same test project compiled with different Delphi versions and comparing the results in the Smoketest GUI itself:
You can’t run all the different Delphi versions of a set of tests from within the same EXE of course, so there are some mechanics behind this which will need to be explained later on.
There is also the facility to compare results between two different test cases in the same project:
As might be more noticeable in this example, currently all test results are “normalised” against the worst result in each case. i.e. the fact that the bars for the first three WIDE results (blue) in the above test are the exact same length as each other and as the green ANSI bars in the remaining five tests, does not mean that the performance is equal.
What it does tell us is that in the first three cases the WIDE test yielded the worst result but in the remaining cases it was the ANSI test that did least well.
I also have some other comparisons in mind but these may come later. It’s still early days yet and I shall blog about how performance cases and visualisations work in Smoketest in more detail when this work is nearer completion.