File: test_taskdef.py

package info (click to toggle)
cylc-flow 8.6.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 14,368 kB
  • sloc: python: 87,751; sh: 17,109; sql: 233; xml: 171; javascript: 78; lisp: 55; makefile: 11
file content (76 lines) | stat: -rw-r--r-- 2,726 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# THIS FILE IS PART OF THE CYLC WORKFLOW ENGINE.
# Copyright (C) NIWA & British Crown (Met Office) & Contributors.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.


from cylc.flow.config import WorkflowConfig
from cylc.flow.pathutil import get_workflow_run_dir
from cylc.flow.scheduler_cli import RunOptions
from cylc.flow.task_outputs import TASK_OUTPUT_SUCCEEDED
from cylc.flow.workflow_files import WorkflowFiles


async def test_almost_self_suicide(flow, scheduler, start):
    """Suicide triggers should not count as upstream tasks when looking
    to spawn parentless tasks.

    https://github.com/cylc/cylc-flow/issues/6594

    For the example under test, pre-requisites for ``!a`` should not be
    considered the same as pre-requisites for ``a``. If the are then then
    is parentless return false for all cases of ``a`` not in the inital cycle
    and subsequent cycles never run.
    """
    wid = flow({
        'scheduler': {'cycle point format': '%Y'},
        'scheduling': {
            'initial cycle point': 1990,
            'final cycle point': 1992,
            'graph': {
                'R1': 'install_cold',
                'P1Y': 'install_cold[^] => a? => b?\nb:fail? => !a?'
            }
        }
    })
    schd = scheduler(wid)
    async with start(schd):
        tasks = [str(t) for t in schd.pool.get_tasks()]
        for task in ['1990/a:waiting', '1991/a:waiting', '1992/a:waiting']:
            assert task in tasks


def test_graph_children(flow):
    """TaskDef.graph_children should not include duplicates.

    https://github.com/cylc/cylc-flow/issues/6619#issuecomment-2668932069
    """
    wid = flow({
        'scheduling': {
            'graph': {
                'R1': 'foo | bar<n> => fin',
            },
        },
        'task parameters': {
            'n': '1..3',
        },
    })
    config = WorkflowConfig(
        wid, get_workflow_run_dir(wid, WorkflowFiles.FLOW_FILE), RunOptions()
    )
    foo = config.taskdefs['foo']
    graph_children = list(foo.graph_children.values())[0]
    assert [name for name, _ in graph_children[TASK_OUTPUT_SUCCEEDED]] == [
        'fin'
    ]