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.
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:
View the source code for the default test report template.