diff --git a/silk/models.py b/silk/models.py index 075c5e9a..61683b16 100644 --- a/silk/models.py +++ b/silk/models.py @@ -8,8 +8,10 @@ from django.conf import settings from django.db import models, transaction from django.db.models import ( + Avg, BooleanField, CharField, + Count, DateTimeField, FileField, FloatField, @@ -19,12 +21,15 @@ OneToOneField, TextField, ) +from django.shortcuts import render from django.utils import timezone from django.utils.safestring import mark_safe from silk.config import SilkyConfig from silk.utils.profile_parser import parse_profile +from .models import Request + try: # New in Django 4.2 from django.core.files.storage import storages @@ -203,6 +208,41 @@ def save(self, *args, **kwargs): super().save(*args, **kwargs) Request.garbage_collect(force=False) + def summary_view(request): + num_requests = Request.objects.count() + avg_overall_time = Request.objects.aggregate(Avg('time_taken'))['time_taken__avg'] or 0 + avg_num_queries = Request.objects.aggregate(Avg('meta_num_queries'))['meta_num_queries__avg'] or 0 + avg_time_spent_on_queries = Request.objects.aggregate(Avg('meta_time_spent_queries'))['meta_time_spent_queries__avg'] or 0 + + longest_queries_by_view = Request.objects.order_by('-time_taken')[:10] + most_time_spent_in_db = Request.objects.order_by('-meta_time_spent_queries')[:10] + most_queries = Request.objects.order_by('-meta_num_queries')[:10] + + options_view_style = [{'value': 'row', 'label': 'Row'}, {'value': 'grid', 'label': 'Grid'}] + options_show = [25, 50, 100] + options_order_by = [{'value': 'start_time', 'label': 'Start Time'}, {'value': 'time_taken', 'label': 'Time Taken'}] + options_order_dir = [{'value': 'asc', 'label': 'Ascending'}, {'value': 'desc', 'label': 'Descending'}] + + context = { + 'num_requests': num_requests, + 'avg_overall_time': avg_overall_time, + 'avg_num_queries': avg_num_queries, + 'avg_time_spent_on_queries': avg_time_spent_on_queries, + 'longest_queries_by_view': longest_queries_by_view, + 'most_time_spent_in_db': most_time_spent_in_db, + 'most_queries': most_queries, + 'view_style': request.GET.get('view_style', 'row'), + 'show': request.GET.get('show', 25), + 'order_by': request.GET.get('order_by', 'start_time'), + 'order_dir': request.GET.get('order_dir', 'asc'), + 'options_view_style': options_view_style, + 'options_show': options_show, + 'options_order_by': options_order_by, + 'options_order_dir': options_order_dir, + } + + return render(request, 'silk/summary.html', context) + class Response(models.Model): id = CharField(max_length=36, default=uuid4, primary_key=True) diff --git a/silk/templates/silk/summary.html b/silk/templates/silk/summary.html index c70c46f9..1cddba04 100644 --- a/silk/templates/silk/summary.html +++ b/silk/templates/silk/summary.html @@ -1,88 +1,127 @@ {% extends 'silk/base/root_base.html' %} {% load silk_inclusion %} {% load static %} -{% block menu %} - {% root_menu request %} -{% endblock %} {% block pagetitle %}Silky - Summary{% endblock %} {% block style %} {{ block.super }} - + + +{% endblock %} + +{% block menu %} + {% root_menu request %} {% endblock %} {% block js %} {{ block.super }} - + {% endblock %} + +{% block filter %} +
+ + + + + {{ block.super }} +{% endblock %} + {% block data %}- - - | -
-
- Using requests that executed
-
-
- seconds ago,
-
-
-
- before
-
- ,
-
-
-
- and after
-
- .
-
-
- |
-
No data
{% endif %} +No data
{% endif %} +No data
{% endif %} +No data
{% endif %}