Skip to content

Test Reports

Test Report

InvenTree provides test result tracking functionality which allows the users to keep track of any tests which have been performed on a given stock item.

Custom test reports may be generated against any given stock item. All testing data is made available to the template for custom rendering as required.

For example, an "Acceptance Test" report template may be customized to the particular device, with the results for certain tests rendering in a particular part of the page, with any tests which have not passed highlighted.

Stock Item Filters

A TestReport template may define a set of filters against which stock items are sorted. Any StockItem objects which match the provided filters can use the given TestReport.

This allows each TestReport to easily be assigned to a particular StockItem, or even multiple items.

In the example below, a test report template is uploaded and available to any stock items linked to a part with the name "My Widget". Any combination of fields relevant to the StockItem model can be used here.

Test report filters Test report filters

Context Variables

In addition to the default report context variables, the following context variables are made available to the TestReport template for rendering:

Variable Description
stock_item The individual Stock Item object for which this test report is being generated
serial The serial number of the linked Stock Item
part The Part object of which the stock_item is an instance
parameters A dict object representing the parameters of the referenced part
test_keys A list of the available 'keys' for the test results recorded against the stock item
test_template_list A list of the available test templates for the referenced part
test_template_map A map / dict of the available test templates
results A dict of test result objects, where the 'key' for each test result is a shortened version of the test name (see below)
result_list A list of each test result object
installed_items A flattened list representing all Stock Item objects which are installed inside the referenced Stock Item object

Results

The results context variable provides a very convenient method of callout out a particular test result by name.

Example

Say for example that a Part "Electronic Widget" has a stock item with serial number #123, and has a test result uploaded called "Firmware Checksum". The templated file can reference this data as follows:

<h3>Part: {{ part.name }}</h3>
<b>Serial Number: {{ stock_item.serial }}</b>
<hr>
<p>
Firmware Checksum: {{ results.firmwarechecksum.value }}.
Uploaded by {{ results.firmwarechecksum.user }}
</p>

Installed Items

The installed_items context variable is a list of all StockItem instances which are installed inside the StockItem referenced by the report template. Each StockItem can be dereferenced as follows:

<table>
    {% for sub_item in installed_items %}
    <tr>
        <td>{{ sub_item.full_name }}</td>
        <td>Serial Number: {{ sub_item.serial }}</td>
        <td>Pass: {{ sub_item.passedAllRequiredTests }}</td>
    </tr>
    {% endfor %}
</table>

Default Report Template

A default Test Report template is provided out of the box, which is useful for generating simple test reports. Furthermore, it may be used as a starting point for developing custom test reports:

Example Test Report Example Test Report

View the source code for the default test report template.