From 574663c514c8ccb8f356114ca5418960ef889598 Mon Sep 17 00:00:00 2001 From: Jacob Callahan Date: Wed, 10 Jan 2024 10:23:38 -0500 Subject: [PATCH] Removing changes associated with Bugbear rule B019 This PR reverts the change from lru_cache to cachedmethod. The primary goal of the original change was to avoid memory leaks, due to lru_cache holding instances of a class alive longer than they should be. However, for our test framework, the workaround to avoid these memory leaks really aren't worth it. I also added an lru_cache to cli_factory.__getattr__, improving its recurring lookup time substantially. Finally, I corrected a type check that was erroneously converted in the initial pass. (cherry picked from commit 8f7fe941d1f474328d6862692b20f9ed5d2f1b14) --- pyproject.toml | 1 + robottelo/host_helpers/cli_factory.py | 6 +++--- robottelo/host_helpers/satellite_mixins.py | 4 ++-- robottelo/hosts.py | 5 ++--- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 61982c48c0..4f5c8af613 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -32,6 +32,7 @@ select = [ ] ignore = [ + "B019", # lru_cache can lead to memory leaks - acceptable tradeoff "E501", # line too long - handled by black "PT004", # pytest underscrore prefix for non-return fixtures "PT005", # pytest no underscrore prefix for return fixtures diff --git a/robottelo/host_helpers/cli_factory.py b/robottelo/host_helpers/cli_factory.py index 575de2256a..290fc7a85b 100644 --- a/robottelo/host_helpers/cli_factory.py +++ b/robottelo/host_helpers/cli_factory.py @@ -4,7 +4,7 @@ example: my_satellite.cli_factory.make_org() """ import datetime -from functools import partial +from functools import lru_cache, partial import inspect import os from os import chmod @@ -14,7 +14,6 @@ from time import sleep from box import Box -from cachetools import cachedmethod from fauxfactory import ( gen_alpha, gen_alphanumeric, @@ -250,6 +249,7 @@ def __init__(self, satellite): self._satellite = satellite self.__dict__.update(initiate_repo_helpers(self._satellite)) + @lru_cache def __getattr__(self, name): """We intercept the usual attribute behavior on this class to emulate make_entity methods The keys in the dictionary above correspond to potential make_ methods @@ -295,7 +295,7 @@ def _evaluate_functions(self, iterable): if not key.startswith('_') } - @cachedmethod + @lru_cache def _find_entity_class(self, entity_name): entity_name = entity_name.replace('_', '').lower() for name, class_obj in self._satellite.cli.__dict__.items(): diff --git a/robottelo/host_helpers/satellite_mixins.py b/robottelo/host_helpers/satellite_mixins.py index 6c47228c14..4b56326f8c 100644 --- a/robottelo/host_helpers/satellite_mixins.py +++ b/robottelo/host_helpers/satellite_mixins.py @@ -1,10 +1,10 @@ import contextlib +from functools import lru_cache import io import os import random import re -from cachetools import cachedmethod import requests from robottelo.cli.proxy import CapsuleTunnelError @@ -358,6 +358,6 @@ def api_factory(self): self._api_factory = APIFactory(self) return self._api_factory - @cachedmethod + @lru_cache def ui_factory(self, session): return UIFactory(self, session=session) diff --git a/robottelo/hosts.py b/robottelo/hosts.py index 37dab609a2..a60d937a2c 100644 --- a/robottelo/hosts.py +++ b/robottelo/hosts.py @@ -16,7 +16,6 @@ from box import Box from broker import Broker from broker.hosts import Host -from cachetools import cachedmethod from dynaconf.vendor.box.exceptions import BoxKeyError from fauxfactory import gen_alpha, gen_string from manifester import Manifester @@ -2296,7 +2295,7 @@ def get_rhsso_client_id(self): break return client_id - @cachedmethod + @lru_cache def get_rhsso_user_details(self, username): """Getter method to receive the user id""" result = self.execute( @@ -2305,7 +2304,7 @@ def get_rhsso_user_details(self, username): result_json = json.loads(result.stdout) return result_json[0] - @cachedmethod + @lru_cache def get_rhsso_groups_details(self, group_name): """Getter method to receive the group id""" result = self.execute(f"{KEY_CLOAK_CLI} get groups -r {settings.rhsso.realm}")