blob: 5314d712ab9512a05678f33b2a2eb94af2e009c8 [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 Freytherc490cde2018-02-25 21:24:30 +000023from osmo_gsm_tester import log
24
25# System modules
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010026import argparse
Holger Hans Peter Freyther94da0452018-06-23 14:41:27 +010027import atexit
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000028import datetime
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000029import signal
30import tempfile
31import os.path
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010032import os
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000033
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010034def parser():
35 parser = argparse.ArgumentParser(epilog=__doc__, formatter_class=argparse.RawTextHelpFormatter)
36 parser.add_argument('-s', '--launch-duration', dest='launch_duration',
37 default=60, type=int,
38 help="Time launching applications should take in seconds")
39 parser.add_argument('-i', '--launch-interval', dest='launch_interval',
40 default=100, type=int,
41 help="Time between launching in milliseconds")
42 parser.add_argument('-d', '--distribution', dest="cdf_name",
43 choices=cdfs.keys(), default="ease_in_out",
44 help="Curve to use for starting within launch duration")
45 parser.add_argument('-m', '--number-ms', dest="num_ms",
46 default=10, type=int,
47 help="Number of MobileStations to simulate")
48 return parser
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000049
50def main():
51 # Create a default log to stdout
52 log.LogTarget().style(src=False)
53
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010054 args = parser().parse_args()
55
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000056 # We don't care what is happening to child processes we spawn!
57 signal.signal(signal.SIGCHLD, signal.SIG_IGN)
58
59 loop = SimpleLoop()
60
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000061 tmp_dir = tempfile.mkdtemp(suffix="osmo-ms-driver")
62 log.log("Going to store files in ", tmp_dir=tmp_dir)
63
64 # How long should starting all apps take
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010065 time_start=datetime.timedelta(seconds=args.launch_duration)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000066 # In which steps to start processes
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010067 time_step=datetime.timedelta(milliseconds=args.launch_interval)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000068
69 # Event server path
70 event_server_path = os.path.join(tmp_dir, "osmo_ms_driver.unix")
71
72 # The function that decides when to start something
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010073 cdf = cdfs[args.cdf_name](time_start, time_step)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000074
75 # Event server to handle MS->test events
76 ev_server = EventServer("ev_server", event_server_path)
77 ev_server.listen(loop)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000078
79 # Just a single test for now.
Holger Hans Peter Freyther0f0ebd82018-06-23 14:40:42 +010080 test = MassUpdateLocationTest("lu_test", args.num_ms, cdf, ev_server, tmp_dir)
Holger Hans Peter Freyther94da0452018-06-23 14:41:27 +010081 atexit.register(test.stop_all)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000082
83 # Run until everything has been launched
Holger Hans Peter Freyther6926c572018-06-23 19:58:38 +010084 test.run_test(loop)
Holger Hans Peter Freytherc490cde2018-02-25 21:24:30 +000085
86 # Print stats
87 test.print_stats()
88
89if __name__ == '__main__':
90 main()