Merge pull request #1045 from alphagov/stats-toggle-test-key

Add option to exclude test key usage in stats on platform admin page
This commit is contained in:
Jenny Duckett
2016-12-06 14:37:20 +00:00
committed by GitHub
4 changed files with 59 additions and 12 deletions

View File

@@ -1,6 +1,9 @@
import itertools
from flask import render_template
from flask import (
render_template,
request
)
from flask_login import login_required
from app import service_api_client
@@ -13,10 +16,15 @@ from app.statistics_utils import get_formatted_percentage
@login_required
@user_has_permissions(admin_override=True)
def platform_admin():
include_from_test_key = request.args.get('include_from_test_key') != 'False'
# specifically DO get inactive services
services = service_api_client.get_services({'detailed': True})['data']
api_args = {'detailed': True}
if not include_from_test_key:
api_args['include_from_test_key'] = False
services = service_api_client.get_services(api_args)['data']
return render_template(
'views/platform-admin.html',
include_from_test_key=include_from_test_key,
**get_statistics(sorted(
services,
key=lambda service: (service['active'], service['created_at']),

View File

@@ -47,6 +47,9 @@
<li>
<a href="{{ url_for('main.platform_admin') }}">Platform admin</a>
</li>
<li>
<a href="{{ url_for('main.view_providers') }}">Providers</a>
</li>
{% endif %}
<li>
<a href="{{ url_for('main.sign_out')}}">Sign out</a>

View File

@@ -1,7 +1,6 @@
{% extends "withoutnav_template.html" %}
{% from "components/big-number.html" import big_number, big_number_with_status %}
{% from "components/message-count-label.html" import message_count_label %}
{% from "components/browse-list.html" import browse_list %}
{% from "components/table.html" import mapping_table, field, stats_fields, row_group, row, right_aligned_field_heading, hidden_field_heading, text_field %}
{% macro stats_fields(channel, data) -%}
@@ -88,15 +87,15 @@
Platform admin
</h1>
{{ browse_list([
{
'title': 'View providers',
'link': url_for('.view_providers')
},
]) }}
<p class="bottom-gutter-2">
Showing stats for today&emsp;
{% if include_from_test_key %}
Including test keys (<a href="{{ url_for('.platform_admin', include_from_test_key=False) }}">change</a>)
{% else %}
Excluding test keys (<a href="{{ url_for('.platform_admin') }}">change</a>)
{% endif %}
</p>
<h2 class='heading-medium'>Today</h2>
<div class="grid-row bottom-gutter">
<div class="column-half">
{{ big_number_with_status(

View File

@@ -81,12 +81,49 @@ def test_should_render_platform_admin_page(
assert response.status_code == 200
resp_data = response.get_data(as_text=True)
assert 'Platform admin' in resp_data
assert 'Today' in resp_data
assert 'Showing stats for today' in resp_data
assert 'Live services' in resp_data
assert 'Trial mode services' in resp_data
mock_get_detailed_services.assert_called_once_with({'detailed': True})
@pytest.mark.parametrize('include_from_test_key, expected_text, unexpected_text, api_args', [
(True, 'Including test keys', 'Excluding test keys', {'detailed': True}),
(False, 'Excluding test keys', 'Including test keys', {'detailed': True, 'include_from_test_key': False})
])
def test_platform_admin_toggle_including_from_test_key(
include_from_test_key,
expected_text,
unexpected_text,
api_args,
app_,
platform_admin_user,
mocker,
mock_get_detailed_services
):
with app_.test_request_context():
with app_.test_client() as client:
mock_get_user(mocker, user=platform_admin_user)
client.login(platform_admin_user)
response = client.get(url_for('main.platform_admin', include_from_test_key=str(include_from_test_key)))
assert response.status_code == 200
resp_data = response.get_data(as_text=True)
assert expected_text in resp_data
assert unexpected_text not in resp_data
page = BeautifulSoup(response.data.decode('utf-8'), 'html.parser')
change_link = page.find('a', text='change')
assert change_link['href']
query_param = 'include_from_test_key=False'
if include_from_test_key:
assert query_param in change_link['href']
else:
assert query_param not in change_link['href']
mock_get_detailed_services.assert_called_once_with(api_args)
def test_create_global_stats_sets_failure_rates(fake_uuid):
services = [
service_json(fake_uuid, 'a', []),