-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjibrel.py
30 lines (27 loc) · 902 Bytes
/
jibrel.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
"""
Entry point file.
"""
import argparse
import log_analyzer
import log_parser
arg_parser = argparse.ArgumentParser(
description='Test assignment solution. Read the program documentation below.',
)
arg_parser.add_argument(
'filename',
help='Full path to logfile with extension',
nargs='?',
default='input.txt',
)
arg_parser.add_argument(
'--throw',
help='Turn on the throw mode: app throw out events with not required types for analyze.',
action='store_true',
)
args = arg_parser.parse_args()
with open(args.filename) as file_object:
events = log_parser.log_file(file_object, args.throw)
failed, percentile_time = log_analyzer.calculate(events)
with open('output.txt', 'w') as output_file:
output_file.write('Failed requests: {0}\n'.format(failed))
output_file.write('95% percentile request time {0} ms\n'.format(percentile_time / 1000))