From 4cab75987c1c3c893dd3161d4cd54636876cbfce Mon Sep 17 00:00:00 2001 From: Tom Lakesman Date: Tue, 14 Nov 2017 09:58:18 +0000 Subject: [PATCH] Allow passing additional args to locusts from the command line ref: #345 --- locust/core.py | 6 +++--- locust/main.py | 7 +++++++ locust/runners.py | 3 ++- 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/locust/core.py b/locust/core.py index a658e41f7c..8b40e77956 100644 --- a/locust/core.py +++ b/locust/core.py @@ -99,7 +99,7 @@ class Locust(object): client = NoClientWarningRaiser() _catch_exceptions = True - def __init__(self): + def __init__(self, *args, **kwargs): super(Locust, self).__init__() def run(self): @@ -128,8 +128,8 @@ class HttpLocust(Locust): The client support cookies, and therefore keeps the session between HTTP requests. """ - def __init__(self): - super(HttpLocust, self).__init__() + def __init__(self, *args, **kwargs): + super(HttpLocust, self).__init__(*args, **kwargs) if self.host is None: raise LocustError("You must specify the base host. Either in the host attribute in the Locust class, or on the command line using the --host option.") diff --git a/locust/main.py b/locust/main.py index 3cb893748c..0af413bf6d 100644 --- a/locust/main.py +++ b/locust/main.py @@ -263,6 +263,13 @@ def parse_options(): help="show program's version number and exit" ) + parser.add_option( + '--locust-arg', + action='append', + dest='locust_args', + help="additional args to pass to each locust" + ) + # Finalize # Return three-tuple of parser + the output from parse_args (opt obj, args) opts, args = parser.parse_args() diff --git a/locust/runners.py b/locust/runners.py index e40b018080..d6f90fc6ea 100644 --- a/locust/runners.py +++ b/locust/runners.py @@ -30,6 +30,7 @@ class LocustRunner(object): def __init__(self, locust_classes, options): self.options = options + self.locust_args = options.locust_args self.locust_classes = locust_classes self.hatch_rate = options.hatch_rate self.num_clients = options.num_clients @@ -111,7 +112,7 @@ def hatch(): occurence_count[locust.__name__] += 1 def start_locust(_): try: - locust().run() + locust(*self.locust_args).run() except GreenletExit: pass new_locust = self.locusts.spawn(start_locust, locust)