This commit renders the platform admin page with the given start and end date query params.

Need to add a form to the page to take these params.
This commit is contained in:
Rebecca Law
2016-12-28 15:23:19 +00:00
parent df41da4860
commit 5572d0f25f
4 changed files with 41 additions and 55 deletions

View File

@@ -516,16 +516,3 @@ class Whitelist(Form):
max_entries=5,
label="Mobile numbers"
)
class DateFilterForm(Form):
start_date = DateField("Start Date", [validators.optional()])
end_date = StringField("End Date", [validators.optional()])
def validate(self):
print("****In validate")
if self.start_date.data and not self.end_date.data:
print("***** false {}".format(type(self.end_date.errors)))
raise ValidationError('Both required')
else:
return True

View File

@@ -5,62 +5,44 @@ from flask import (
request
)
from flask_login import login_required
from wtforms import ValidationError
from app import service_api_client
from app.main import main
from app.main.forms import DateFilterForm
from app.utils import user_has_permissions
from app.statistics_utils import get_formatted_percentage
@main.route("/platform-admin", methods=['GET', 'POST'])
@main.route("/platform-admin")
@login_required
@user_has_permissions(admin_override=True)
def platform_admin():
form = DateFilterForm()
include_from_test_key = request.args.get('include_from_test_key') != 'False'
start_date = request.args.get('start_date', None)
end_date = request.args.get('end_date', None)
# specifically DO get inactive services
api_args = {'detailed': True}
if not include_from_test_key:
api_args['include_from_test_key'] = False
if form.validate_on_submit():
start_date = form.start_date.data
end_date = form.end_date.data
if start_date:
print(start_date)
print(end_date)
api_args['start_date'] = start_date
if not end_date:
raise ValidationError(message='requires end date', field =form.end_date)
api_args['end_date'] = end_date
if start_date:
# For now the start and end date are only set as query params. The previous commit added a form
# but I could get the validation right, not did the page look good.
# This is just an intermediate pass at returning the data.
api_args['start_date'] = start_date
api_args['end_date'] = end_date
services = service_api_client.get_services(api_args)['data']
services = service_api_client.get_services(api_args)['data']
return render_template(
'views/platform-admin.html',
include_from_test_key=include_from_test_key,
form=form,
**get_statistics(sorted(
services,
key=lambda service: (service['active'], service['created_at']),
reverse=True
))
)
else:
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']),
reverse=True
))
)
return render_template(
'views/platform-admin.html',
include_from_test_key=include_from_test_key,
form=form,
**get_statistics(sorted(
services,
key=lambda service: (service['active'], service['created_at']),
reverse=True
))
)
def get_statistics(services):
return {

View File

@@ -96,11 +96,6 @@
{% else %}
Excluding test keys (<a href="{{ url_for('.platform_admin') }}">change</a>)
{% endif %}
<form autocomplete="off" method="post">
{{ textbox(form.start_date, hint="Enter start date in format YYYY-MM-DD") }}
{{ textbox(form.end_date, hint="Enter end date in format YYYY-MM-DD") }}
{{ page_footer('Apply filter') }}
</form>
</p>
<div class="grid-row bottom-gutter">

View File

@@ -121,6 +121,28 @@ def test_platform_admin_toggle_including_from_test_key(
mock_get_detailed_services.assert_called_once_with(api_args)
def test_platform_admin_with_date_filter(
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', start_date='2016-12-20', end_date='2012-12-28'))
assert response.status_code == 200
resp_data = response.get_data(as_text=True)
assert 'Platform admin' 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,
'start_date': '2016-12-20', 'end_date': '2012-12-28'})
def test_create_global_stats_sets_failure_rates(fake_uuid):
services = [
service_json(fake_uuid, 'a', []),