Skip to content

Commit

Permalink
Scan workflow name during install.
Browse files Browse the repository at this point in the history
  • Loading branch information
hjoliver committed Oct 10, 2022
1 parent 901fa06 commit f26ac09
Showing 1 changed file with 40 additions and 7 deletions.
47 changes: 40 additions & 7 deletions cylc/flow/scripts/install.py
Original file line number Diff line number Diff line change
Expand Up @@ -80,21 +80,26 @@
multiple workflow run directories that link to the same workflow definition.
"""

from ansimarkup import ansiprint as cprint
import asyncio
from optparse import Values
from pathlib import Path
from typing import Optional, TYPE_CHECKING, Dict, Any
from typing import Optional, Dict, Any

from cylc.flow.scripts.scan import (
get_pipe,
_format_plain,
)
from cylc.flow import iter_entry_points
from cylc.flow.exceptions import PluginError, InputError
from cylc.flow.loggingutil import CylcLogFormatter
from cylc.flow.option_parsers import CylcOptionParser as COP
from cylc.flow.pathutil import EXPLICIT_RELATIVE_PATH_REGEX, expand_path
from cylc.flow.workflow_files import (
install_workflow, search_install_source_dirs, parse_cli_sym_dirs
)
from cylc.flow.terminal import cli_function

if TYPE_CHECKING:
from optparse import Values


def get_option_parser() -> COP:
parser = COP(
Expand Down Expand Up @@ -171,14 +176,40 @@ def get_source_location(path: Optional[str]) -> Path:
return search_install_source_dirs(expanded_path)


async def scan(wf_name: str) -> None:
"""Print any instances of wf_name that are already active."""
opts = Values({
'name': [f'{wf_name}/*'],
'states': {'running', 'paused', 'stopping'},
'source': False,
'ping': False,
})
active = [
item async for item in get_pipe(opts, None, scan_dir=None)
]
if active:
print(
CylcLogFormatter.COLORS['WARNING'].format(
f'Instance(s) of "{wf_name} are already active:'
)
)
for item in active:
cprint(
_format_plain(item, opts)
)


@cli_function(get_option_parser)
def main(parser, opts, reg=None):
install(parser, opts, reg)
wf_name = install(parser, opts, reg)
asyncio.run(
scan(wf_name)
)


def install(
parser: COP, opts: 'Values', reg: Optional[str] = None
) -> None:
) -> str:
if opts.no_run_name and opts.run_name:
raise InputError(
"options --no-run-name and --run-name are mutually exclusive."
Expand All @@ -204,7 +235,7 @@ def install(
elif opts.symlink_dirs:
cli_symdirs = parse_cli_sym_dirs(opts.symlink_dirs)

source_dir, rundir, _workflow_name = install_workflow(
source_dir, rundir, workflow_name = install_workflow(
source=source,
workflow_name=opts.workflow_name,
run_name=opts.run_name,
Expand All @@ -229,3 +260,5 @@ def install(
entry_point.name,
exc
) from None

return workflow_name

0 comments on commit f26ac09

Please sign in to comment.