From 5f1951513d3eaa56c30431de177d8ecfe4b1f2b4 Mon Sep 17 00:00:00 2001 From: Liyun Xiu Date: Wed, 3 Apr 2024 23:31:26 +0800 Subject: [PATCH] Support request-params for bulk operation (#501) Adding "request-params" support for bulk operation. Signed-off-by: Liyun Xiu --- osbenchmark/worker_coordinator/runner.py | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/osbenchmark/worker_coordinator/runner.py b/osbenchmark/worker_coordinator/runner.py index e31deca83..9e03bfb8f 100644 --- a/osbenchmark/worker_coordinator/runner.py +++ b/osbenchmark/worker_coordinator/runner.py @@ -475,6 +475,7 @@ async def __call__(self, opensearch, params): The following keys are optional: * ``pipeline``: If present, runs the the specified ingest pipeline for this bulk. + * ``request-params``: If present, they will be passed as parameters of bulk. * ``detailed-results``: If ``True``, the runner will analyze the response and add detailed meta-data. Defaults to ``False``. Note that this has a very significant impact on performance and will very likely cause a bottleneck in the benchmark worker_coordinator so please @@ -486,12 +487,17 @@ async def __call__(self, opensearch, params): ``None`` and potentially falls back to the global timeout setting. """ detailed_results = params.get("detailed-results", False) - api_kwargs = self._default_kw_params(params) bulk_params = {} if "pipeline" in params: bulk_params["pipeline"] = params["pipeline"] + if "request-params" in params: + bulk_params.update(params["request-params"]) + params.pop( "request-params" ) + + api_kwargs = self._default_kw_params(params) + with_action_metadata = mandatory(params, "action-metadata-present", self) bulk_size = mandatory(params, "bulk-size", self) unit = mandatory(params, "unit", self)