Wednesday, 28 August 2013

Collecting error reports from Visual Studio load tests

Generally Visual Studio load tests that call web performance tests are written to follow a happy path through the application. The goal is to have tests that are expected to pass so any errors are due to faults in the system under test. When the tests are data driven the data should be screened to exclude any values that always cause failures. Unfortunately that cannot always be achieved. On a recent project the data could not be screened before use. We had many discussions about attempting database resets between test executions but in the end we had to accept that some data records might be invalid.

Given that some tests might fail the project manager wanted the test results to include details of which tests failed, at what time, with what values from the data source, and with what error code. At first sight that data is readily available because a load test keeps logs for up to 200 (the default number) failing tests. These 200 logs could be studied to extract the details, but there is no easy way. Each log file must be opened by clicking on a link and then clicking through the various parts of the web test log to find the information. To analyze all 200 logs would require opening 200 log files, exploring 200 files and closing 200 files. That is much too much mouse clicking and mouse waving. It involves too much manual activity making it very error prone.

Trying to extract the log file details by program appears possible. The log files are stored in the SQL table 'LoadTestTestLog' within the load test results database. Using SQL the results can be exported to a CSV file where one field of each record contains a hexadecimal dump of the log file. Converting the hex to bytes is easy and viewing the results in a simple text editor shows encoded data with lots of embedded ASCII text. Some of that text appears to be parts of the log file. Using a "strings" command leaves the useful text hidden by a mass of other text.

The record appears to be a serialized class. My attempts to deserialize the data have been unsuccessful. The initial error is that the DLL required to decode the file cannot be found. So this approach does not work. Of course, even if it did work this approach would only show details of the first 200 failing tests. The number of saved logs could be increased but as each log file record is large that might mean filling up the database if several test runs were wanted.

Another approach is wanted and that will be the subject of another blog entry.

3 comments:

  1. *"each record contains a hexadecimal dump of the log file. Converting the hex to bytes is easy"*

    Can you elaborate how to do that please? Thanks for the article BTW.

    ReplyDelete
  2. Hello Ygro,

    The hex dump is a list of hexadecimal digits. Each pair of digits gives the value of a byte. For example, given the hex dump "41647269616E", we consider the digits in their pairs which are 41, 64, 72, 69, 61 and 6E. Each pair represents a number in the range 0 to (decimal)255. Just look up (or convert) that number to its character in the normal Ascii character set. So (hex)41==(decima)65=='A'; (hex)64==(decimal)100=='d', etc. The whole hex dump thus spells "Adrian".

    Doing the conversion is a simple programming exercise and there are probably library routines readily available in your favourite programming language.

    The method attempted in this post for getting log file data was an interesting exercise, but it was unsuccessful.

    ReplyDelete
  3. "The record appears to be a serialized class. My attempts to deserialize the data have been unsuccessful". Got you, Thanks.

    ReplyDelete