From 0323d4284e2804a16127908a597cfe630a11add4 Mon Sep 17 00:00:00 2001 From: "Daniel (dB.) Doubrovkine" Date: Thu, 15 Aug 2024 10:15:13 -0400 Subject: [PATCH] Remove HEAD-handling hack. (#794) * remove HEAD -> GET workaround Signed-off-by: dblock * Removed remaining HEAD-handling code. Signed-off-by: dblock * Fixed remaining references to admin:admin. Signed-off-by: dblock --------- Signed-off-by: dblock Co-authored-by: Vincent Castaneda --- CHANGELOG.md | 1 + benchmarks/bench_async.py | 3 ++- benchmarks/bench_info_sync.py | 3 ++- benchmarks/bench_sync.py | 3 ++- opensearchpy/_async/helpers/test.py | 2 +- opensearchpy/_async/http_aiohttp.py | 14 +------------- opensearchpy/connection/http_async.py | 14 +------------- opensearchpy/helpers/test.py | 11 ++++++----- samples/logging/log_collection_sample.py | 2 +- .../test_server/test_helpers/conftest.py | 6 +++++- .../test_server/test_helpers/conftest.py | 6 +++++- 11 files changed, 27 insertions(+), 38 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 950e9ba81..5c0c27db4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ Inspired from [Keep a Changelog](https://keepachangelog.com/en/1.0.0/) ### Added ### Changed - Removed deprecated `numpy.float_` and update NumPy/Pandas imports ([#762](https://github.com/opensearch-project/opensearch-py/pull/762)) +- Removed workaround for [aiohttp#1769](https://github.com/aio-libs/aiohttp/issues/1769) ([#794](https://github.com/opensearch-project/opensearch-py/pull/794)) ### Deprecated ### Removed - Removed redundant dependency on six ([#781](https://github.com/opensearch-project/opensearch-py/pull/781)) diff --git a/benchmarks/bench_async.py b/benchmarks/bench_async.py index 251b0b990..66fc3ddcb 100644 --- a/benchmarks/bench_async.py +++ b/benchmarks/bench_async.py @@ -10,6 +10,7 @@ # GitHub history for details. import asyncio +import os import uuid from typing import Any @@ -42,7 +43,7 @@ async def test_async(client_count: int = 1, item_count: int = 1) -> None: """ host = "localhost" port = 9200 - auth = ("admin", "admin") + auth = ("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")) index_name = "test-index-async" clients = [] diff --git a/benchmarks/bench_info_sync.py b/benchmarks/bench_info_sync.py index 5d0729d9d..78dce1826 100644 --- a/benchmarks/bench_info_sync.py +++ b/benchmarks/bench_info_sync.py @@ -11,6 +11,7 @@ import logging +import os import sys import time from typing import Any @@ -34,7 +35,7 @@ def test(thread_count: int = 1, request_count: int = 1, client_count: int = 1) - """test to index with thread_count threads, item_count records and run client_count clients""" host = "localhost" port = 9200 - auth = ("admin", "admin") + auth = ("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")) root = logging.getLogger() # root.setLevel(logging.DEBUG) diff --git a/benchmarks/bench_sync.py b/benchmarks/bench_sync.py index e9c30c53b..e9e2479a6 100644 --- a/benchmarks/bench_sync.py +++ b/benchmarks/bench_sync.py @@ -11,6 +11,7 @@ import json import logging +import os import sys import time import uuid @@ -52,7 +53,7 @@ def test(thread_count: int = 1, item_count: int = 1, client_count: int = 1) -> N """test to index with thread_count threads, item_count records and run client_count clients""" host = "localhost" port = 9200 - auth = ("admin", "admin") + auth = ("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")) index_name = "test-index-sync" root = logging.getLogger() diff --git a/opensearchpy/_async/helpers/test.py b/opensearchpy/_async/helpers/test.py index 455a2781e..9f9cbc4d3 100644 --- a/opensearchpy/_async/helpers/test.py +++ b/opensearchpy/_async/helpers/test.py @@ -15,7 +15,7 @@ from opensearchpy import AsyncOpenSearch from opensearchpy.exceptions import ConnectionError -OPENSEARCH_URL = os.environ.get("OPENSEARCH_URL", "https://admin:admin@localhost:9200") +OPENSEARCH_URL = os.environ.get("OPENSEARCH_URL", "https://localhost:9200") async def get_test_client(nowait: bool = False, **kwargs: Any) -> Any: diff --git a/opensearchpy/_async/http_aiohttp.py b/opensearchpy/_async/http_aiohttp.py index 4c3839146..1e3da465c 100644 --- a/opensearchpy/_async/http_aiohttp.py +++ b/opensearchpy/_async/http_aiohttp.py @@ -246,14 +246,6 @@ async def perform_request( else: query_string = "" - # There is a bug in aiohttp that disables the re-use - # of the connection in the pool when method=HEAD. - # See: aio-libs/aiohttp#1769 - is_head = False - if method == "HEAD": - method = "GET" - is_head = True - # Top-tier tip-toeing happening here. Basically # because Pip's old resolver is bad and wipes out # strict pins in favor of non-strict pins of extras @@ -301,11 +293,7 @@ async def perform_request( timeout=timeout, fingerprint=self.ssl_assert_fingerprint, ) as response: - if is_head: # We actually called 'GET' so throw away the data. - await response.release() - raw_data = "" - else: - raw_data = await response.text() + raw_data = await response.text() duration = self.loop.time() - start # We want to reraise a cancellation or recursion error. diff --git a/opensearchpy/connection/http_async.py b/opensearchpy/connection/http_async.py index ea4af4779..d04908788 100644 --- a/opensearchpy/connection/http_async.py +++ b/opensearchpy/connection/http_async.py @@ -167,14 +167,6 @@ async def perform_request( else: query_string = "" - # There is a bug in aiohttp that disables the re-use - # of the connection in the pool when method=HEAD. - # See: https://github.com/aio-libs/aiohttp/issues/1769 - is_head = False - if method == "HEAD": - method = "GET" - is_head = True - # Top-tier tip-toeing happening here. Basically # because Pip's old resolver is bad and wipes out # strict pins in favor of non-strict pins of extras @@ -221,11 +213,7 @@ async def perform_request( timeout=timeout, fingerprint=self.ssl_assert_fingerprint, ) as response: - if is_head: # We actually called 'GET' so throw away the data. - await response.release() - raw_data = "" - else: - raw_data = await response.text() + raw_data = await response.text() duration = self.loop.time() - start # We want to reraise a cancellation or recursion error. diff --git a/opensearchpy/helpers/test.py b/opensearchpy/helpers/test.py index 6ad34b66d..f799bd7d8 100644 --- a/opensearchpy/helpers/test.py +++ b/opensearchpy/helpers/test.py @@ -34,7 +34,7 @@ from opensearchpy import OpenSearch from opensearchpy.exceptions import ConnectionError -OPENSEARCH_URL = os.environ.get("OPENSEARCH_URL", "https://admin:admin@localhost:9200") +OPENSEARCH_URL = os.environ.get("OPENSEARCH_URL", "https://localhost:9200") def get_test_client(nowait: bool = False, **kwargs: Any) -> OpenSearch: @@ -105,10 +105,11 @@ def opensearch_version(client: opensearchpy.client.OpenSearch) -> Any: if "OPENSEARCH_VERSION" in os.environ: OPENSEARCH_VERSION = _get_version(os.environ["OPENSEARCH_VERSION"]) else: - client = OpenSearch( - OPENSEARCH_URL, - verify_certs=False, + OPENSEARCH_VERSION = opensearch_version( + get_test_client( + verify_certs=False, + http_auth=("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")), + ) ) - OPENSEARCH_VERSION = opensearch_version(client) __all__ = ["OpenSearchTestCase"] diff --git a/samples/logging/log_collection_sample.py b/samples/logging/log_collection_sample.py index 7722a20b7..bb3d704b3 100644 --- a/samples/logging/log_collection_sample.py +++ b/samples/logging/log_collection_sample.py @@ -38,7 +38,7 @@ def main() -> None: # Setup connection with the OpenSearch cluster print("Setting up connection with OpenSearch cluster...") opensearch_client: Any = OpenSearch( - "https://admin:admin@localhost:9200", + "https://localhost:9200", use_ssl=True, verify_certs=False, ssl_show_warn=False, diff --git a/test_opensearchpy/test_async/test_server/test_helpers/conftest.py b/test_opensearchpy/test_async/test_server/test_helpers/conftest.py index 983ae711d..66932402d 100644 --- a/test_opensearchpy/test_async/test_server/test_helpers/conftest.py +++ b/test_opensearchpy/test_async/test_server/test_helpers/conftest.py @@ -7,6 +7,7 @@ # Modifications Copyright OpenSearch Contributors. See # GitHub history for details. +import os import re from datetime import datetime from typing import Any @@ -36,7 +37,10 @@ @fixture(scope="function") # type: ignore async def client() -> Any: - client = await get_test_client(verify_certs=False, http_auth=("admin", "admin")) + client = await get_test_client( + verify_certs=False, + http_auth=("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")), + ) await add_connection("default", client) return client diff --git a/test_opensearchpy/test_server/test_helpers/conftest.py b/test_opensearchpy/test_server/test_helpers/conftest.py index 4f9a8d6fc..f7b0815d5 100644 --- a/test_opensearchpy/test_server/test_helpers/conftest.py +++ b/test_opensearchpy/test_server/test_helpers/conftest.py @@ -24,6 +24,7 @@ # specific language governing permissions and limitations # under the License. +import os import re from datetime import datetime from typing import Any @@ -46,7 +47,10 @@ @fixture(scope="session") # type: ignore def client() -> Any: - client = get_test_client(verify_certs=False, http_auth=("admin", "admin")) + client = get_test_client( + verify_certs=False, + http_auth=("admin", os.getenv("OPENSEARCH_PASSWORD", "admin")), + ) add_connection("default", client) return client