blob: 265ce47b13289a9271ae9fd0af3f0ddb00e67c4d [file] [log] [blame]
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +00001# osmo_ms_driver: Main test runner
2#
3# Copyright (C) 2018 by Holger Hans Peter Freyther
4#
5# This program is free software: you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as
7# published by the Free Software Foundation, either version 3 of the
8# License, or (at your option) any later version.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program. If not, see <http://www.gnu.org/licenses/>.
17
18# Local modules
19from .event_server import EventServer
20from .simple_loop import SimpleLoop
21from .location_update_test import MassUpdateLocationTest
Holger Hans Peter Freyther874b4b42018-06-23 21:55:41 +010022from .cdf import cdfs
Holger Hans Peter Freytherf658b832018-11-05 05:05:43 +000023from .starter import BinaryOptions
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000024from osmo_gsm_tester import log
25
26# System modules
Holger Hans Peter Freyther1dc9a042018-06-23 22:27:23 +010027from datetime import timedelta
28
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010029import argparse
Holger Hans Peter Freyther94da0452018-06-23 14:41:27 +010030import atexit
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000031import datetime
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000032import signal
33import tempfile
34import os.path
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010035import os
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000036
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010037def parser():
38 parser = argparse.ArgumentParser(epilog=__doc__, formatter_class=argparse.RawTextHelpFormatter)
39 parser.add_argument('-s', '--launch-duration', dest='launch_duration',
40 default=60, type=int,
41 help="Time launching applications should take in seconds")
42 parser.add_argument('-i', '--launch-interval', dest='launch_interval',
43 default=100, type=int,
44 help="Time between launching in milliseconds")
Holger Hans Peter Freyther1dc9a042018-06-23 22:27:23 +010045 parser.add_argument('-t', '--test-duration', dest="test_duration",
46 default=120, type=int,
47 help="Time of the test duration in seconds")
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010048 parser.add_argument('-d', '--distribution', dest="cdf_name",
49 choices=cdfs.keys(), default="ease_in_out",
50 help="Curve to use for starting within launch duration")
51 parser.add_argument('-m', '--number-ms', dest="num_ms",
52 default=10, type=int,
53 help="Number of MobileStations to simulate")
54 return parser
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000055
56def main():
57 # Create a default log to stdout
58 log.LogTarget().style(src=False)
59
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010060 args = parser().parse_args()
61
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000062 # We don't care what is happening to child processes we spawn!
63 signal.signal(signal.SIGCHLD, signal.SIG_IGN)
64
65 loop = SimpleLoop()
66
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000067 tmp_dir = tempfile.mkdtemp(suffix="osmo-ms-driver")
68 log.log("Going to store files in ", tmp_dir=tmp_dir)
69
70 # How long should starting all apps take
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010071 time_start=datetime.timedelta(seconds=args.launch_duration)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000072 # In which steps to start processes
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010073 time_step=datetime.timedelta(milliseconds=args.launch_interval)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000074
75 # Event server path
76 event_server_path = os.path.join(tmp_dir, "osmo_ms_driver.unix")
77
78 # The function that decides when to start something
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010079 cdf = cdfs[args.cdf_name](time_start, time_step)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000080
81 # Event server to handle MS->test events
82 ev_server = EventServer("ev_server", event_server_path)
83 ev_server.listen(loop)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000084
85 # Just a single test for now.
Holger Hans Peter Freytherf658b832018-11-05 05:05:43 +000086 options = BinaryOptions("virtphy", "mobile", None)
87 test = MassUpdateLocationTest("lu_test", options, args.num_ms, cdf, ev_server, tmp_dir)
Holger Hans Peter Freyther94da0452018-06-23 14:41:27 +010088 atexit.register(test.stop_all)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000089
90 # Run until everything has been launched
Holger Hans Peter Freyther1dc9a042018-06-23 22:27:23 +010091 test.run_test(loop, timedelta(seconds=args.test_duration))
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000092
93 # Print stats
94 test.print_stats()
95
96if __name__ == '__main__':
97 main()