Skip to content

Commit

Permalink
BUG: fix missing progress bar when running CLI on a single CPU
Browse files Browse the repository at this point in the history
  • Loading branch information
neutrinoceros committed Nov 24, 2024
1 parent d353a11 commit 4ce96fc
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 20 deletions.
34 changes: 15 additions & 19 deletions nonos/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -531,17 +531,6 @@ def main(argv: Optional[list[str]] = None) -> int:
f"Requested {args['ncpu']}, but the runner only has access to {ncpu}."
)

if args["progressBar"]:
from rich.progress import track

def mytrack(iterable, *args, **kwargs):
return track(iterable, *args, **kwargs)

else:
# replace rich.progress.track with a no-op dummy
def mytrack(iterable, *args, **kwargs): # noqa: ARG001
return iterable

planet_file: Optional[str]
if not is_set(args["corotate"]):
planet_file = None
Expand Down Expand Up @@ -576,21 +565,28 @@ def mytrack(iterable, *args, **kwargs): # noqa: ARG001
log_level=level,
)

if args["progressBar"]:
from rich.progress import track
else:
# replace rich.progress.track with a no-op dummy
def track(it, *_args, **_kwargs): # type: ignore [misc]
return it

progress = functools.partial(
track,
description="Processing snapshots",
total=len(args["on"]),
)

logger.info("Starting main loop")
tstart = time.time()
if ncpu == 1:
for on in args["on"]:
for on in progress(args["on"]):
process_field(on, **func_kwargs)
else:
func = functools.partial(process_field, **func_kwargs)
with Pool(ncpu) as pool:
list(
mytrack(
pool.imap(func, args["on"]),
description="Processing snapshots",
total=len(args["on"]),
)
)
list(progress(pool.imap(func, args["on"])))
if not show:
logger.info("Operation took {:.2f}s", time.time() - tstart)

Expand Down
2 changes: 1 addition & 1 deletion tests/test_plotting.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,7 +175,7 @@ def test_pbar(simulation_dir, capsys, tmp_path):

out, err = capsys.readouterr()
assert err == ""
assert out == ""
assert "Processing snapshots" in out
assert ret == 0


Expand Down

0 comments on commit 4ce96fc

Please sign in to comment.