From 5fcb4e5759913ddb3bb6e3029a08b2a5db7733b4 Mon Sep 17 00:00:00 2001 From: dblock Date: Mon, 25 Nov 2024 15:07:17 -0500 Subject: [PATCH] Fix: backwards compatible parameter order in cluster stats. Signed-off-by: dblock --- opensearchpy/_async/client/cluster.py | 8 +++++--- opensearchpy/client/cluster.py | 8 +++++--- test_opensearchpy/test_client/test_overrides.py | 10 ++++++++++ utils/templates/overrides/cluster/stats | 9 ++++++++- 4 files changed, 28 insertions(+), 7 deletions(-) diff --git a/opensearchpy/_async/client/cluster.py b/opensearchpy/_async/client/cluster.py index 9178c2b5d..8a6b881d5 100644 --- a/opensearchpy/_async/client/cluster.py +++ b/opensearchpy/_async/client/cluster.py @@ -267,11 +267,11 @@ async def state( ) async def stats( self, - metric: Any = None, - index_metric: Any = None, node_id: Any = None, params: Any = None, headers: Any = None, + metric: Any = None, + index_metric: Any = None, ) -> Any: """ Returns high-level overview of cluster statistics. @@ -308,7 +308,9 @@ async def stats( ( "/_cluster/stats" if node_id in SKIP_IN_PATH - else _make_path("_cluster", "stats", "nodes", node_id) + else _make_path( + "_cluster", "stats", metric, index_metric, "nodes", node_id + ) ), params=params, headers=headers, diff --git a/opensearchpy/client/cluster.py b/opensearchpy/client/cluster.py index a5e8dd7d5..7dc199767 100644 --- a/opensearchpy/client/cluster.py +++ b/opensearchpy/client/cluster.py @@ -267,11 +267,11 @@ def state( ) def stats( self, - metric: Any = None, - index_metric: Any = None, node_id: Any = None, params: Any = None, headers: Any = None, + metric: Any = None, + index_metric: Any = None, ) -> Any: """ Returns high-level overview of cluster statistics. @@ -308,7 +308,9 @@ def stats( ( "/_cluster/stats" if node_id in SKIP_IN_PATH - else _make_path("_cluster", "stats", "nodes", node_id) + else _make_path( + "_cluster", "stats", metric, index_metric, "nodes", node_id + ) ), params=params, headers=headers, diff --git a/test_opensearchpy/test_client/test_overrides.py b/test_opensearchpy/test_client/test_overrides.py index 160a8bdd5..d5555987f 100644 --- a/test_opensearchpy/test_client/test_overrides.py +++ b/test_opensearchpy/test_client/test_overrides.py @@ -98,6 +98,16 @@ def test_cluster_stats(self) -> None: self.client.cluster.stats(node_id="test-node") self.assert_url_called("GET", "/_cluster/stats/nodes/test-node") + self.client.cluster.stats(node_id="test-node", metric="indices") + self.assert_url_called("GET", "/_cluster/stats/indices/nodes/test-node") + + self.client.cluster.stats( + node_id="test-node", metric="indices", index_metric="analysis" + ) + self.assert_url_called( + "GET", "/_cluster/stats/indices/analysis/nodes/test-node" + ) + def test_indices_put_mapping(self) -> None: self.client.indices.put_mapping(body={}) self.assert_url_called("PUT", "/_all/_mapping") diff --git a/utils/templates/overrides/cluster/stats b/utils/templates/overrides/cluster/stats index 3223013a7..0db78ea1a 100644 --- a/utils/templates/overrides/cluster/stats +++ b/utils/templates/overrides/cluster/stats @@ -1,5 +1,12 @@ {% extends "base" %} +{% block func_params %} + node_id: Any = None, + params: Any = None, + headers: Any = None, + metric: Any = None, + index_metric: Any = None, +{% endblock %} {% block request %} - return await self.transport.perform_request("{{ api.method }}", "/_cluster/stats" if node_id in SKIP_IN_PATH else _make_path("_cluster", "stats", "nodes", node_id), params=params, headers=headers) + return await self.transport.perform_request("{{ api.method }}", "/_cluster/stats" if node_id in SKIP_IN_PATH else _make_path("_cluster", "stats", metric, index_metric, "nodes", node_id), params=params, headers=headers) {% endblock%}