From 5a67a6735526fce3e7e9abafdf20d313b65555b1 Mon Sep 17 00:00:00 2001 From: Anmol Shrivastava Date: Tue, 19 Apr 2022 19:04:13 +0530 Subject: [PATCH] Report disk usage during fuzzer runs Signed-off-by: Anmol Shrivastava --- fuzzers/run_fuzzer.py | 26 +++++++++++++++++++++++++- 1 file changed, 25 insertions(+), 1 deletion(-) diff --git a/fuzzers/run_fuzzer.py b/fuzzers/run_fuzzer.py index d8ca8aa47..11705fc48 100755 --- a/fuzzers/run_fuzzer.py +++ b/fuzzers/run_fuzzer.py @@ -319,6 +319,27 @@ def mem_convert(s): return v +def get_diskspace(diskstr=None): + """ + Return the free and used space on the disk + associated with the current directory. + + >>> import pprint + >>> pprint.pprint(get_diskspace()) + {'free': '760G', 'used': '109G'} + """ + + if diskstr is None: + diskstr = subprocess.check_output( + 'df -h .', shell=True).decode("utf-8") + + lines = [x.split() for x in diskstr.strip().splitlines()] + + disk = {'used': lines[1][2], 'free': lines[1][3]} + + return disk + + def get_memory(memstr=None): r""" >>> import pprint @@ -568,12 +589,15 @@ def log(msg, *a, **k): if retcode is not None: break mem = get_memory()['mem'] + disk = get_diskspace() log( - "Still running (1m:{:0.2f}%, 5m:{:0.2f}%, 15m:{:0.2f}% Mem:{:0.1f}Gi used, {:0.1f}Gi free).\n{}", + "Still running (1m:{:0.2f}%, 5m:{:0.2f}%, 15m:{:0.2f}% Mem:{:0.1f}Gi used, {:0.1f}Gi free Disk:{}i used, {}i free).\n{}", *get_load(), mem['used'] / 1e9, mem['available'] / 1e9, # Using available so the numbers add up. + disk['used'], + disk['free'], PsTree.get(p.pid), ) except (Exception, KeyboardInterrupt, SystemExit):