From f235ae942df72f26e64287329e22461c94ed06e1 Mon Sep 17 00:00:00 2001 From: Adeel Ahmad Date: Sat, 6 Jul 2019 08:17:14 +0200 Subject: [PATCH] Remove aiohttp package for fetching tiles --- hips/draw/tests/test_paint.py | 4 +-- hips/draw/tests/test_ui.py | 2 +- hips/tiles/fetch.py | 58 ++++------------------------------ hips/tiles/tests/test_fetch.py | 11 ------- 4 files changed, 9 insertions(+), 66 deletions(-) diff --git a/hips/draw/tests/test_paint.py b/hips/draw/tests/test_paint.py index dfb2db8..89a8b2a 100644 --- a/hips/draw/tests/test_paint.py +++ b/hips/draw/tests/test_paint.py @@ -20,7 +20,7 @@ def setup_class(cls): width=2000, height=1000, fov="3 deg", coordsys='icrs', projection='AIT', ) - fetch_opts = dict(fetch_package='urllib', timeout=30, n_parallel=10) + fetch_opts = dict(timeout=30, n_parallel=10) cls.painter = HipsPainter(cls.geometry, cls.hips_survey, 'fits', fetch_opts=fetch_opts) def test_draw_hips_order(self): @@ -44,7 +44,7 @@ def test_compute_matching_hips_order(self, pars): coordsys='icrs', projection='AIT', ) - fetch_opts = dict(fetch_package='urllib', timeout=30, n_parallel=10) + fetch_opts = dict(timeout=30, n_parallel=10) simple_tile_painter = HipsPainter(geometry, self.hips_survey, 'fits', fetch_opts=fetch_opts) assert simple_tile_painter.draw_hips_order == pars['order'] diff --git a/hips/draw/tests/test_ui.py b/hips/draw/tests/test_ui.py index 786f3d2..a7dd254 100644 --- a/hips/draw/tests/test_ui.py +++ b/hips/draw/tests/test_ui.py @@ -61,7 +61,7 @@ def test_make_sky_image(tmpdir, pars): hips_survey = HipsSurveyProperties.fetch(url=pars['url']) geometry = make_test_wcs_geometry() - fetch_opts = dict(fetch_package='urllib', timeout=30, n_parallel=10) + fetch_opts = dict(timeout=30, n_parallel=10) result = make_sky_image(geometry=geometry, hips_survey=hips_survey, tile_format=pars['file_format'], precise=pars['precise'], fetch_opts=fetch_opts) diff --git a/hips/tiles/fetch.py b/hips/tiles/fetch.py index f3c63c5..c79fdde 100644 --- a/hips/tiles/fetch.py +++ b/hips/tiles/fetch.py @@ -17,7 +17,7 @@ def fetch_tiles(tile_metas: List[HipsTileMeta], hips_survey: HipsSurveyProperties, progress_bar: bool = True, n_parallel: int = 5, - timeout: float = 10, fetch_package: str = 'urllib') -> List[HipsTile]: + timeout: float = 10) -> List[HipsTile]: """Fetch a list of HiPS tiles. This function fetches a list of HiPS tiles based @@ -38,8 +38,6 @@ def fetch_tiles(tile_metas: List[HipsTileMeta], hips_survey: HipsSurveyPropertie Number of tile fetch web requests to make in parallel timeout : float Seconds to timeout for fetching a HiPS tile - fetch_package : {'urllib', 'aiohttp'} - Package to use for fetching HiPS tiles Examples -------- @@ -69,15 +67,8 @@ def fetch_tiles(tile_metas: List[HipsTileMeta], hips_survey: HipsSurveyPropertie tiles : list A Python list of `~hips.HipsTile` """ - if fetch_package == 'aiohttp': - fetch_fct = tiles_aiohttp - elif fetch_package == 'urllib': - fetch_fct = tiles_urllib - else: - raise ValueError(f'Invalid package name: {fetch_package}') - tile_urls = [hips_survey.tile_url(meta) for meta in tile_metas] - response_all = fetch_fct(tile_urls, hips_survey, progress_bar, n_parallel, timeout) + response_all = do_fetch_tiles(tile_urls, hips_survey, progress_bar, n_parallel, timeout) tiles = [] for idx, response in enumerate(response_all): @@ -90,7 +81,7 @@ def fetch_tiles(tile_metas: List[HipsTileMeta], hips_survey: HipsSurveyPropertie return tiles -def fetch_tile_urllib(url: str, timeout: float) -> dict: +def do_fetch_single_tile(url: str, timeout: float) -> dict: """Fetch a HiPS tile asynchronously.""" try: with urllib.request.urlopen(url, timeout=timeout) as conn: @@ -106,45 +97,8 @@ def fetch_tile_urllib(url: str, timeout: float) -> dict: return {'is_missing': True} -def tiles_urllib(tile_urls: List[str], hips_survey: HipsSurveyProperties, - progress_bar: bool, n_parallel, timeout: float) -> List[dict]: +def do_fetch_tiles(tile_urls: List[str], hips_survey: HipsSurveyProperties, + progress_bar: bool, n_parallel, timeout: float) -> List[dict]: """Generator function to fetch HiPS tiles from a remote URL.""" with concurrent.futures.ThreadPoolExecutor(max_workers=n_parallel) as executor: - return list(executor.map(fetch_tile_urllib, tile_urls, [timeout] * len(tile_urls))) - - -async def fetch_tile_aiohttp(url: str, session, timeout: float) -> dict: - """Fetch a HiPS tile asynchronously using aiohttp.""" - async with session.get(url, timeout=timeout) as response: - return {'raw_data': await response.read(), 'url': url} - - -async def fetch_all_tiles_aiohttp(tile_urls: List[str], hips_survey: HipsSurveyProperties, - progress_bar: bool, n_parallel: int, timeout: float) -> List[dict]: - """Generator function to fetch HiPS tiles from a remote URL using aiohttp.""" - import aiohttp - - connector = aiohttp.TCPConnector(limit=n_parallel) - async with aiohttp.ClientSession(connector=connector) as session: - futures = [] - for url in tile_urls: - future = asyncio.ensure_future(fetch_tile_aiohttp(url, session, timeout)) - futures.append(future) - - futures = asyncio.as_completed(futures) - if progress_bar: - from tqdm import tqdm - futures = tqdm(futures, total=len(tile_urls), desc='Fetching tiles') - - response_all = [] - for future in futures: - response_all.append(await future) - - return response_all - - -def tiles_aiohttp(tile_urls: List[str], hips_survey: HipsSurveyProperties, - progress_bar: bool, n_parallel: int, timeout: float) -> List[dict]: - return asyncio.get_event_loop().run_until_complete( - fetch_all_tiles_aiohttp(tile_urls, hips_survey, progress_bar, n_parallel, timeout) - ) + return list(executor.map(do_fetch_single_tile, tile_urls, [timeout] * len(tile_urls))) diff --git a/hips/tiles/tests/test_fetch.py b/hips/tiles/tests/test_fetch.py index 2b55f4d..aab47e4 100644 --- a/hips/tiles/tests/test_fetch.py +++ b/hips/tiles/tests/test_fetch.py @@ -14,16 +14,6 @@ url='http://alasky.unistra.fr/DSS/DSS2Merged/properties', progress_bar=True, data=[2101, 1945, 1828, 1871, 2079, 2336], - fetch_package='urllib', - ), - dict( - tile_indices=[69623, 69627, 69628, 69629, 69630, 69631], - tile_format='fits', - order=7, - url='http://alasky.unistra.fr/DSS/DSS2Merged/properties', - progress_bar=True, - data=[2101, 1945, 1828, 1871, 2079, 2336], - fetch_package='aiohttp', ), ] @@ -48,7 +38,6 @@ def test_fetch_tiles(pars): tiles = fetch_tiles( tile_metas, hips_survey, progress_bar=pars['progress_bar'], - fetch_package=pars['fetch_package'], ) for idx, val in enumerate(pars['data']):