From 6eec0065df3de489fab32f3fa786f69b0a39d44a Mon Sep 17 00:00:00 2001 From: JhonnyBn Date: Fri, 19 Jun 2020 21:27:39 -0300 Subject: [PATCH] Truncate job args/kwargs to a reasonable length (#1277) * Truncate job args/kwargs to a reasonable length * fix --- rq/job.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/rq/job.py b/rq/job.py index 688929a..3d129ef 100644 --- a/rq/job.py +++ b/rq/job.py @@ -39,6 +39,11 @@ JobStatus = enum( UNEVALUATED = object() +def truncate_long_string(data, maxlen=75): + """ Truncates strings longer than maxlen + """ + return (data[:maxlen] + '...') if len(data) > maxlen else data + def cancel_job(job_id, connection=None): """Cancels the job with the given job ID, preventing execution. Discards any job info (i.e. it can't be requeued later). @@ -672,9 +677,9 @@ class Job(object): if self.func_name is None: return None - arg_list = [as_text(repr(arg)) for arg in self.args] + arg_list = [as_text(truncate_long_string(repr(arg))) for arg in self.args] - kwargs = ['{0}={1}'.format(k, as_text(repr(v))) for k, v in self.kwargs.items()] + kwargs = ['{0}={1}'.format(k, as_text(truncate_long_string(repr(v)))) for k, v in self.kwargs.items()] # Sort here because python 3.3 & 3.4 makes different call_string arg_list += sorted(kwargs) args = ', '.join(arg_list)