Skip to content

Commit

Permalink
[fix] ResultContainer: use self._lock and self._closed for all proper…
Browse files Browse the repository at this point in the history
…ties

Close searxng#3474
  • Loading branch information
dalf authored and return42 committed May 24, 2024
1 parent 68365c8 commit 75e4b65
Showing 1 changed file with 28 additions and 11 deletions.
39 changes: 28 additions & 11 deletions searx/results.py
Original file line number Diff line number Diff line change
Expand Up @@ -430,21 +430,38 @@ def number_of_results(self) -> int:
"""Returns the average of results number, returns zero if the average
result number is smaller than the actual result count."""

resultnum_sum = sum(self._number_of_results)
if not resultnum_sum or not self._number_of_results:
return 0
with self._lock:
if not self._closed:
logger.error("call to ResultContainer.number_of_results before ResultContainer.close")
return 0

resultnum_sum = sum(self._number_of_results)
if not resultnum_sum or not self._number_of_results:
return 0

average = int(resultnum_sum / len(self._number_of_results))
if average < self.results_length():
average = 0
return average
average = int(resultnum_sum / len(self._number_of_results))
if average < self.results_length():
average = 0
return average

def add_unresponsive_engine(self, engine_name: str, error_type: str, suspended: bool = False):
if engines[engine_name].display_error_messages:
self.unresponsive_engines.add(UnresponsiveEngine(engine_name, error_type, suspended))
with self._lock:
if self._closed:
logger.error("call to ResultContainer.add_unresponsive_engine after ResultContainer.close")
return
if engines[engine_name].display_error_messages:
self.unresponsive_engines.add(UnresponsiveEngine(engine_name, error_type, suspended))

def add_timing(self, engine_name: str, engine_time: float, page_load_time: float):
self.timings.append(Timing(engine_name, total=engine_time, load=page_load_time))
with self._lock:
if self._closed:
logger.error("call to ResultContainer.add_timing after ResultContainer.close")
return
self.timings.append(Timing(engine_name, total=engine_time, load=page_load_time))

def get_timings(self):
return self.timings
with self._lock:
if not self._closed:
logger.error("call to ResultContainer.get_timings before ResultContainer.close")
return []
return self.timings

0 comments on commit 75e4b65

Please sign in to comment.