forked from cylc/cylc-flow
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path04-switch.t
More file actions
65 lines (53 loc) · 2.05 KB
/
04-switch.t
File metadata and controls
65 lines (53 loc) · 2.05 KB
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
#!/usr/bin/env bash
# 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/>.
#-------------------------------------------------------------------------------
# "cylc set" proposal examples: 5 - Set and complete a future switch task with the "--wait" flag
# https://cylc.github.io/cylc-admin/proposal-cylc-set.html#5-set-switch-tasks-at-an-optional-branch-point-to-direct-the-future-flow
. "$(dirname "$0")/test_header"
set_test_number 5
install_and_validate
reftest_run
# The branch-point task foo should be recorded as succeeded.
sqlite3 ~/cylc-run/"${WORKFLOW_NAME}"/log/db \
"SELECT status FROM task_states WHERE name is 'foo'" > db-foo.2
cmp_ok "db-foo.2" - << __OUT__
succeeded
__OUT__
# the outputs of foo should be recorded as:
# a, succeeded
# and the implied outputs (of succeeded) as well:
# submitted, started
sqlite3 ~/cylc-run/"${WORKFLOW_NAME}"/log/db \
"SELECT outputs FROM task_outputs WHERE name is 'foo'" > db-foo.1
# Json string list of outputs from the db may not be ordered correctly.
python3 - << __END__ > db-foo.2
import json
with open("db-foo.1", 'r') as f:
print(
','.join(
sorted(
json.load(f)
)
)
)
__END__
cmp_ok "db-foo.2" - << __OUT__
a,started,submitted,succeeded
__OUT__
# Check the flow-wait worked
grep_workflow_log_ok check-wait "1/foo.* spawning outputs after flow-wait" -E
purge