Source code for jobflow_remote.testing.cli

from __future__ import annotations

import re
from typing import IO, TYPE_CHECKING, Any

from typer.testing import CliRunner, Result

from jobflow_remote.cli.jf import app

if TYPE_CHECKING:
    from collections.abc import Mapping, Sequence


[docs] def run_check_cli( cli_args: str | Sequence[str] | None = None, cli_input: bytes | str | IO[Any] | None = None, cli_env: Mapping[str, str] | None = None, catch_exceptions: bool = False, required_out: str | Sequence[str] | None = None, excluded_out: str | Sequence[str] | None = None, error: bool = False, terminal_width: int = 1000, ) -> Result: if isinstance(required_out, str): required_out = [required_out] if isinstance(excluded_out, str): excluded_out = [excluded_out] cli_runner = CliRunner() result = cli_runner.invoke( app, args=cli_args, input=cli_input, env=cli_env, catch_exceptions=catch_exceptions, terminal_width=terminal_width, ) # note that stderr is not captured separately assert ( error == (result.exit_code != 0) ), f"cli should have {'' if error else 'not '}failed. exit code: {result.exit_code}. stdout: {result.stdout}" # the print of the output in the console during the tests may result in newlines added # that prevent the output to be matched. replace all spaces with a single space. single_space_output = re.sub(r"[\n\t\s]*", " ", result.stdout) if required_out: for ro in required_out: assert ( re.sub(r"[\n\t\s]*", " ", ro) in single_space_output ), f"{ro} missing from stdout: {result.stdout}" if excluded_out: for eo in excluded_out: assert ( re.sub(r"[\n\t\s]*", " ", eo) not in single_space_output ), f"{eo} present in stdout: {result.stdout}" return result