Skip to content

Commit

Permalink
Test explicit enrichment failure for routine not found
Browse files Browse the repository at this point in the history
  • Loading branch information
reuterbal committed Nov 23, 2023
1 parent e4cad64 commit be09a3f
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 1 deletion.
3 changes: 2 additions & 1 deletion loki/bulk/scheduler.py
Original file line number Diff line number Diff line change
Expand Up @@ -418,7 +418,8 @@ def find_routine(self, routine):
warning(f'Scheduler could not find routine {routine}')
if self.config.default['strict']:
raise RuntimeError(f'Scheduler could not find routine {routine}')
elif len(candidates) != 1:
return None
if len(candidates) != 1:
warning(f'Scheduler found multiple candidates for routine {routine}: {candidates}')
if self.config.default['strict']:
raise RuntimeError(f'Scheduler found multiple candidates for routine {routine}: {candidates}')
Expand Down
53 changes: 53 additions & 0 deletions tests/test_scheduler.py
Original file line number Diff line number Diff line change
Expand Up @@ -630,6 +630,59 @@ def test_scheduler_graph_multiple_separate(here, config, frontend):
cg_path.with_suffix('.pdf').unlink()


@pytest.mark.parametrize('strict', [True, False])
def test_scheduler_graph_multiple_separate_enrich_fail(here, config, frontend, strict):
"""
Tests that explicit enrichment in "strict" mode will fail because it can't
find ext_driver
projA: driverB -> kernelB -> compute_l1<replicated> -> compute_l2
|
<ext_driver>
projB: ext_driver -> ext_kernelfail
"""
projA = here/'sources/projA'

configA = config.copy()
configA['default']['strict'] = strict
configA['routine'] = [
{
'name': 'kernelB',
'role': 'kernel',
'ignore': ['ext_driver'],
'enrich': ['ext_driver'],
},
]

if strict:
with pytest.raises(FileNotFoundError):
Scheduler(
paths=[projA], includes=projA/'include', config=configA,
seed_routines=['driverB'], frontend=frontend
)
else:
schedulerA = Scheduler(
paths=[projA], includes=projA/'include', config=configA,
seed_routines=['driverB'], frontend=frontend
)

expected_itemsA = [
'driverB_mod#driverB', 'kernelB_mod#kernelB',
'compute_l1_mod#compute_l1', 'compute_l2_mod#compute_l2',
]
expected_dependenciesA = [
('driverB_mod#driverB', 'kernelB_mod#kernelB'),
('kernelB_mod#kernelB', 'compute_l1_mod#compute_l1'),
('compute_l1_mod#compute_l1', 'compute_l2_mod#compute_l2'),
]

assert all(n in schedulerA.items for n in expected_itemsA)
assert all(e in schedulerA.dependencies for e in expected_dependenciesA)
assert 'ext_driver' not in schedulerA.items
assert 'ext_kernel' not in schedulerA.items


def test_scheduler_module_dependency(here, config, frontend):
"""
Ensure dependency chasing is done correctly, even with surboutines
Expand Down

0 comments on commit be09a3f

Please sign in to comment.