Skip to content

Commit

Permalink
Merge 'upstream/master' into cylc-remove
Browse files Browse the repository at this point in the history
  • Loading branch information
MetRonnie committed Oct 16, 2024
2 parents 977b322 + fdbe1f1 commit 8f72cb4
Show file tree
Hide file tree
Showing 38 changed files with 559 additions and 237 deletions.
4 changes: 3 additions & 1 deletion .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,8 +18,10 @@ jobs:
strategy:
matrix:
os: ['ubuntu-latest']
python: ['3.7', '3.8', '3.9', '3.10', '3.11']
python: ['3.8', '3.9', '3.10', '3.11']
include:
- os: 'ubuntu-22.04'
python: '3.7'
- os: 'macos-latest'
python: '3.8'
steps:
Expand Down
5 changes: 3 additions & 2 deletions .github/workflows/test_fast.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,10 @@ jobs:
fail-fast: false # don't stop on first failure
matrix:
os: ['ubuntu-latest']
python-version: ['3.7', '3.8', '3.10', '3.11', '3']
python-version: ['3.8', '3.10', '3.11', '3']
include:
# mac os test
- os: 'ubuntu-22.04'
python-version: '3.7'
- os: 'macos-latest'
python-version: '3.9' # oldest supported version
# non-utc timezone test
Expand Down
8 changes: 4 additions & 4 deletions .github/workflows/test_functional.yml
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ jobs:
strategy:
fail-fast: false
matrix:
os: ['ubuntu-latest']
os: ['ubuntu-22.04']
python-version: ['3.7']
test-base: ['tests/f']
chunk: ['1/4', '2/4', '3/4', '4/4']
Expand All @@ -56,20 +56,20 @@ jobs:
platform: '_local_background*'
# tests/k
- name: 'flaky'
os: 'ubuntu-latest'
os: 'ubuntu-22.04'
python-version: '3.7'
test-base: 'tests/k'
chunk: '1/1'
platform: '_local_background* _local_at*'
# remote platforms
- name: '_remote_background_indep_poll'
os: 'ubuntu-latest'
os: 'ubuntu-22.04'
python-version: '3.7'
test-base: 'tests/f tests/k'
chunk: '1/1'
platform: '_remote_background_indep_poll _remote_at_indep_poll'
- name: '_remote_background_indep_tcp'
os: 'ubuntu-latest'
os: 'ubuntu-22.04'
test-base: 'tests/f tests/k'
python-version: '3.7'
chunk: '1/1'
Expand Down
8 changes: 6 additions & 2 deletions .github/workflows/test_tutorial_workflow.yml
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,12 @@ jobs:
test:
strategy:
matrix:
python-version: ['3.7', '3']
runs-on: ubuntu-latest
include:
- os: 'ubuntu-latest'
python-version: '3'
- os: 'ubuntu-22.04'
python-version: '3.7'
runs-on: ${{ matrix.os }}
timeout-minutes: 10
steps:
- name: configure python
Expand Down
12 changes: 12 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,18 @@ $ towncrier create <PR-number>.<break|feat|fix>.md --content "Short description"

<!-- towncrier release notes start -->

## __cylc-8.3.5 (Released 2024-10-15)__

### 🔧 Fixes

[#6316](https://github.com/cylc/cylc-flow/pull/6316) - Fixed bug in `cylc vr` where an initial cycle point of `now`/`next()`/`previous()` would result in an error.

[#6362](https://github.com/cylc/cylc-flow/pull/6362) - Fixed simulation mode bug where the task submit number would not increment

[#6367](https://github.com/cylc/cylc-flow/pull/6367) - Fix bug where `cylc trigger` and `cylc set` would assign active flows to existing tasks by default.

[#6397](https://github.com/cylc/cylc-flow/pull/6397) - Fix "dictionary changed size during iteration error" which could occur with broadcasts.

## __cylc-8.3.4 (Released 2024-09-12)__

### 🚀 Enhancements
Expand Down
1 change: 0 additions & 1 deletion changes.d/6362.fix.md

This file was deleted.

20 changes: 14 additions & 6 deletions cylc/flow/command_validation.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@
f"or '{FLOW_NONE}'"
)
ERR_OPT_FLOW_VAL_2 = f"Flow values must be an integer, or '{FLOW_ALL}'"
ERR_OPT_FLOW_INT = "Multiple flow options must all be integer valued"
ERR_OPT_FLOW_COMBINE = "Cannot combine --flow={0} with other flow values"
ERR_OPT_FLOW_WAIT = (
f"--wait is not compatible with --flow={FLOW_NEW} or --flow={FLOW_NONE}"
)
Expand All @@ -54,44 +54,52 @@ def flow_opts(
) -> None:
"""Check validity of flow-related CLI options.
Note the schema defaults flows to ["all"].
Note the schema defaults flows to [].
Examples:
Good:
>>> flow_opts([], False)
>>> flow_opts(["new"], False)
>>> flow_opts(["1", "2"], False)
>>> flow_opts(["1", "2"], True)
Bad:
>>> flow_opts(["none", "1"], False)
Traceback (most recent call last):
cylc.flow.exceptions.InputError: ... must all be integer valued
cylc.flow.exceptions.InputError: Cannot combine --flow=none with other
flow values
>>> flow_opts(["cheese", "2"], True)
Traceback (most recent call last):
cylc.flow.exceptions.InputError: ... or 'all', 'new', or 'none'
>>> flow_opts(["new"], True)
Traceback (most recent call last):
cylc.flow.exceptions.InputError: --wait is not compatible ...
cylc.flow.exceptions.InputError: --wait is not compatible with
--flow=new or --flow=none
>>> flow_opts(["new"], False, allow_new_or_none=False)
Traceback (most recent call last):
cylc.flow.exceptions.InputError: ... must be an integer, or 'all'
"""
if not flows:
return

flows = [val.strip() for val in flows]

for val in flows:
val = val.strip()
if val in {FLOW_NONE, FLOW_NEW, FLOW_ALL}:
if len(flows) != 1:
raise InputError(ERR_OPT_FLOW_INT)
raise InputError(ERR_OPT_FLOW_COMBINE.format(val))
if not allow_new_or_none and val in {FLOW_NEW, FLOW_NONE}:
raise InputError(ERR_OPT_FLOW_VAL_2)
else:
try:
int(val)
except ValueError:
raise InputError(ERR_OPT_FLOW_VAL.format(val)) from None
raise InputError(ERR_OPT_FLOW_VAL) from None

if flow_wait and flows[0] in {FLOW_NEW, FLOW_NONE}:
raise InputError(ERR_OPT_FLOW_WAIT)
Expand Down
7 changes: 4 additions & 3 deletions cylc/flow/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -690,7 +690,7 @@ def process_initial_cycle_point(self) -> None:
Sets:
self.initial_point
self.cfg['scheduling']['initial cycle point']
self.options.icp
self.evaluated_icp
Raises:
WorkflowConfigError - if it fails to validate
"""
Expand All @@ -710,10 +710,11 @@ def process_initial_cycle_point(self) -> None:
icp = ingest_time(orig_icp, get_current_time_string())
except IsodatetimeError as exc:
raise WorkflowConfigError(str(exc)) from None
if orig_icp != icp:
self.evaluated_icp = None
if icp != orig_icp:
# now/next()/previous() was used, need to store
# evaluated point in DB
self.options.icp = icp
self.evaluated_icp = icp
self.initial_point = get_point(icp).standardise()
self.cfg['scheduling']['initial cycle point'] = str(self.initial_point)

Expand Down
10 changes: 6 additions & 4 deletions cylc/flow/data_store_mgr.py
Original file line number Diff line number Diff line change
Expand Up @@ -948,7 +948,7 @@ def increment_graph_window(
)
for items in graph_children.values():
for child_name, child_point, _ in items:
if child_point > final_point:
if final_point and child_point > final_point:
continue
child_tokens = self.id_.duplicate(
cycle=str(child_point),
Expand Down Expand Up @@ -978,7 +978,7 @@ def increment_graph_window(
taskdefs
).values():
for parent_name, parent_point, _ in items:
if parent_point > final_point:
if final_point and parent_point > final_point:
continue
parent_tokens = self.id_.duplicate(
cycle=str(parent_point),
Expand Down Expand Up @@ -1419,7 +1419,7 @@ def apply_task_proxy_db_history(self):
itask, is_parent = self.db_load_task_proxies[relative_id]
itask.submit_num = submit_num
flow_nums = deserialise_set(flow_nums_str)
# Do not set states and outputs for future tasks in flow.
# Do not set states and outputs for inactive tasks in flow.
if (
itask.flow_nums and
flow_nums != itask.flow_nums and
Expand Down Expand Up @@ -2250,7 +2250,9 @@ def delta_broadcast(self):

def _generate_broadcast_node_deltas(self, node_data, node_type):
cfg = self.schd.config.cfg
for node_id, node in node_data.items():
# NOTE: node_data may change during operation so make a copy
# see https://github.com/cylc/cylc-flow/pull/6397
for node_id, node in list(node_data.items()):
tokens = Tokens(node_id)
new_runtime = runtime_from_config(
self._apply_broadcasts_to_runtime(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -282,13 +282,18 @@ def __call__(self, grid_x, grid_y):
return z_val


def parse_domain(domain):
bbox = list(map(float, domain.split(',')))
def parse_domain(domain: str):
lng1, lat1, lng2, lat2 = list(map(float, domain.split(',')))
msg = "Invalid domain '{}' ({} {} >= {})"
if lng1 >= lng2:
raise ValueError(msg.format(domain, 'longitude', lng1, lng2))
if lat1 >= lat2:
raise ValueError(msg.format(domain, 'latitude', lat1, lat2))
return {
'lng1': bbox[0],
'lat1': bbox[1],
'lng2': bbox[2],
'lat2': bbox[3]
'lng1': lng1,
'lat1': lat1,
'lng2': lng2,
'lat2': lat2,
}


Expand Down
23 changes: 13 additions & 10 deletions cylc/flow/network/schema.py
Original file line number Diff line number Diff line change
Expand Up @@ -2027,17 +2027,20 @@ class Arguments:
class FlowMutationArguments:
flow = graphene.List(
graphene.NonNull(Flow),
default_value=[FLOW_ALL],
default_value=[],
description=sstrip(f'''
The flow(s) to trigger these tasks in.
This should be a list of flow numbers OR a single-item list
containing one of the following three strings:
* {FLOW_ALL} - Triggered tasks belong to all active flows
(default).
* {FLOW_NEW} - Triggered tasks are assigned to a new flow.
* {FLOW_NONE} - Triggered tasks do not belong to any flow.
The flow(s) to trigger/set these tasks in.
By default:
* active tasks (n=0) keep their existing flow assignment
* inactive tasks (n>0) get assigned all active flows
Otherwise you can assign (inactive tasks) or add to (active tasks):
* a list of integer flow numbers
or one of the following strings:
* {FLOW_ALL} - all active flows
* {FLOW_NEW} - an automatically generated new flow number
* {FLOW_NONE} - (ignored for active tasks): no flow
''')
)
flow_wait = Boolean(
Expand Down
6 changes: 4 additions & 2 deletions cylc/flow/scripts/show.py
Original file line number Diff line number Diff line change
Expand Up @@ -387,8 +387,10 @@ async def prereqs_and_outputs_query(

if not task_proxies:
ansiprint(
f"<red>No matching active tasks found: {', '.join(ids_list)}",
file=sys.stderr)
"<red>No matching active tasks found: "
f"{', '.join(ids_list)}</red>",
file=sys.stderr,
)
return 1
return 0

Expand Down
24 changes: 16 additions & 8 deletions cylc/flow/scripts/trigger.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,19 +17,12 @@

"""cylc trigger [OPTIONS] ARGS
Force tasks to run despite unsatisfied prerequisites.
Force tasks to run regardless of prerequisites.
* Triggering an unqueued waiting task queues it, regardless of prerequisites.
* Triggering a queued task submits it, regardless of queue limiting.
* Triggering an active task has no effect (it already triggered).
Incomplete and active-waiting tasks in the n=0 window already belong to a flow.
Triggering them queues them to run (or rerun) in the same flow.
Beyond n=0, triggered tasks get all current active flow numbers by default, or
specified flow numbers via the --flow option. Those flows - if/when they catch
up - will see tasks that ran after triggering event as having run already.
Examples:
# trigger task foo in cycle 1234 in test
$ cylc trigger test//1234/foo
Expand All @@ -39,6 +32,21 @@
# start a new flow by triggering 1234/foo in test
$ cylc trigger --flow=new test//1234/foo
Flows:
Active tasks (in the n=0 window) already belong to a flow.
* by default, if triggered, they run in the same flow
* or with --flow=all, they are assigned all active flows
* or with --flow=INT or --flow=new, the original and new flows are merged
* (--flow=none is ignored for active tasks)
Inactive tasks (n>0) do not already belong to a flow.
* by default they are assigned all active flows
* otherwise, they are assigned the --flow value
Note --flow=new increments the global flow counter with each use. If it
takes multiple commands to start a new flow use the actual flow number
after the first command (you can read it from the scheduler log).
"""

from functools import partial
Expand Down
Loading

0 comments on commit 8f72cb4

Please sign in to comment.