def test_fetch_count_of_complaints(sample_email_notification):
    create_complaint(
        service=sample_email_notification.service,
        notification=sample_email_notification,
        created_at=datetime(2018, 6, 6, 22, 00, 00),
    )
    create_complaint(
        service=sample_email_notification.service,
        notification=sample_email_notification,
        created_at=datetime(2018, 6, 6, 23, 00, 00),
    )
    create_complaint(
        service=sample_email_notification.service,
        notification=sample_email_notification,
        created_at=datetime(2018, 6, 7, 00, 00, 00),
    )
    create_complaint(
        service=sample_email_notification.service,
        notification=sample_email_notification,
        created_at=datetime(2018, 6, 7, 13, 00, 00),
    )
    create_complaint(
        service=sample_email_notification.service,
        notification=sample_email_notification,
        created_at=datetime(2018, 6, 7, 23),
    )

    count_of_complaints = fetch_count_of_complaints(start_date=datetime(2018, 6, 7), end_date=datetime(2018, 6, 7))
    assert count_of_complaints == 2
Beispiel #2
0
def get_complaint_count():
    if request.args:
        validate(request.args, complaint_count_request)

    # If start and end date are not set, we are expecting today's stats.
    today = str(datetime.utcnow().date())

    start_date = datetime.strptime(request.args.get('start_date', today),
                                   '%Y-%m-%d').date()
    end_date = datetime.strptime(request.args.get('end_date', today),
                                 '%Y-%m-%d').date()
    count_of_complaints = fetch_count_of_complaints(start_date=start_date,
                                                    end_date=end_date)

    return jsonify(count_of_complaints), 200
def test_fetch_count_of_complaints_returns_zero(notify_db):
    count_of_complaints = fetch_count_of_complaints(
        start_date=datetime(2018, 6, 7), end_date=datetime(2018, 6, 7))
    assert count_of_complaints == 0