mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
* 12510 move reports to use BaseScript * 12510 merge report into script view * 12510 add migration for job report to script * 12510 update templates * 12510 remove reports * 12510 cleanup * 12510 legacy jobs * 12510 legacy jobs * 12510 fixes * 12510 review changes * 12510 review changes * 12510 update docs * 12510 review changes * 12510 review changes * 12510 review changes * 12510 review changes * 12510 main log results to empty string * 12510 move migration * Introduce an internal log level for debug to simplify Script logging * Misc cleanup * Remove obsolete is_valid() method * Reformat script job data (log, output, tests) * Remove ScriptLogMessageSerializer * Fix formatting of script logs * Record a timestamp with script logs * Rename _current_method to _current_test * Clean up template * Remove obsolete runreport management command * Misc cleanup & refactoring * Clean up template * Clean up migration * Clean up docs --------- Co-authored-by: Jeremy Stretch <jstretch@netboxlabs.com>
127 lines
4.3 KiB
HTML
127 lines
4.3 KiB
HTML
{% load humanize %}
|
|
{% load helpers %}
|
|
{% load log_levels %}
|
|
{% load i18n %}
|
|
|
|
<p>
|
|
{% if job.started %}
|
|
{% trans "Started" %}: <strong>{{ job.started|annotated_date }}</strong>
|
|
{% elif job.scheduled %}
|
|
{% trans "Scheduled for" %}: <strong>{{ job.scheduled|annotated_date }}</strong> ({{ job.scheduled|naturaltime }})
|
|
{% else %}
|
|
{% trans "Created" %}: <strong>{{ job.created|annotated_date }}</strong>
|
|
{% endif %}
|
|
{% if job.completed %}
|
|
{% trans "Duration" %}: <strong>{{ job.duration }}</strong>
|
|
{% endif %}
|
|
<span id="pending-result-label">{% badge job.get_status_display job.get_status_color %}</span>
|
|
</p>
|
|
{% if job.completed %}
|
|
|
|
{# Script log. Legacy reports will not have this. #}
|
|
{% if 'log' in job.data %}
|
|
<div class="card mb-3">
|
|
<h5 class="card-header">{% trans "Log" %}</h5>
|
|
{% if job.data.log %}
|
|
<table class="table table-hover panel-body">
|
|
<tr>
|
|
<th>{% trans "Line" %}</th>
|
|
<th>{% trans "Time" %}</th>
|
|
<th>{% trans "Level" %}</th>
|
|
<th>{% trans "Message" %}</th>
|
|
</tr>
|
|
{% for log in job.data.log %}
|
|
<tr>
|
|
<td>{{ forloop.counter }}</td>
|
|
<td>{{ log.time|placeholder }}</td>
|
|
<td>{% log_level log.status %}</td>
|
|
<td>{{ log.message|markdown }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</table>
|
|
{% else %}
|
|
<div class="card-body text-muted">{% trans "None" %}</div>
|
|
{% endif %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
{# Script output. Legacy reports will not have this. #}
|
|
{% if 'output' in job.data %}
|
|
<div class="card mb-3">
|
|
<h5 class="card-header">{% trans "Output" %}</h5>
|
|
{% if job.data.output %}
|
|
<pre class="card-body font-monospace">{{ job.data.output }}</pre>
|
|
{% else %}
|
|
<div class="card-body text-muted">{% trans "None" %}</div>
|
|
{% endif %}
|
|
</div>
|
|
{% endif %}
|
|
|
|
{# Test method logs (for legacy Reports) #}
|
|
{% if tests %}
|
|
|
|
{# Summary of test methods #}
|
|
<div class="card">
|
|
<h5 class="card-header">{% trans "Test Summary" %}</h5>
|
|
<table class="table table-hover">
|
|
{% for test, data in tests.items %}
|
|
<tr>
|
|
<td class="font-monospace"><a href="#{{ test }}">{{ test }}</a></td>
|
|
<td class="text-end report-stats">
|
|
<span class="badge text-bg-success">{{ data.success }}</span>
|
|
<span class="badge text-bg-info">{{ data.info }}</span>
|
|
<span class="badge text-bg-warning">{{ data.warning }}</span>
|
|
<span class="badge text-bg-danger">{{ data.failure }}</span>
|
|
</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</table>
|
|
</div>
|
|
|
|
{# Detailed results for individual tests #}
|
|
<div class="card">
|
|
<h5 class="card-header">{% trans "Test Details" %}</h5>
|
|
<table class="table table-hover report">
|
|
<thead>
|
|
<tr class="table-headings">
|
|
<th>{% trans "Time" %}</th>
|
|
<th>{% trans "Level" %}</th>
|
|
<th>{% trans "Object" %}</th>
|
|
<th>{% trans "Message" %}</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for test, data in tests.items %}
|
|
<tr>
|
|
<th colspan="4" style="font-family: monospace">
|
|
<a name="{{ test }}"></a>{{ test }}
|
|
</th>
|
|
</tr>
|
|
{% for time, level, obj, url, message in data.log %}
|
|
<tr class="{% if level == 'failure' %}danger{% elif level %}{{ level }}{% endif %}">
|
|
<td>{{ time }}</td>
|
|
<td>
|
|
<label class="badge text-bg-{% if level == 'failure' %}danger{% else %}{{ level }}{% endif %}">{{ level|title }}</label>
|
|
</td>
|
|
<td>
|
|
{% if obj and url %}
|
|
<a href="{{ url }}">{{ obj }}</a>
|
|
{% elif obj %}
|
|
{{ obj }}
|
|
{% else %}
|
|
{{ ''|placeholder }}
|
|
{% endif %}
|
|
</td>
|
|
<td class="rendered-markdown">{{ message|markdown }}</td>
|
|
</tr>
|
|
{% endfor %}
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
|
|
{% endif %}
|
|
{% elif job.started %}
|
|
{% include 'extras/inc/result_pending.html' %}
|
|
{% endif %}
|