From 82ca20029210f452cbb590ae69a4dcbcce196dce Mon Sep 17 00:00:00 2001 From: "eduardo.serna" Date: Tue, 8 Oct 2024 08:39:45 +0200 Subject: [PATCH] test: pull out bad render test into its own function and add another case --- tests/test_annotations.py | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/tests/test_annotations.py b/tests/test_annotations.py index d1f5123e..1710242d 100644 --- a/tests/test_annotations.py +++ b/tests/test_annotations.py @@ -10,6 +10,8 @@ from ._lib.extra import increment, sum, try_nothing +from typing import Any + ARG1: AtRender[bool] = True ARG2: bool = False @@ -37,6 +39,12 @@ def to_int_bad(num: int, should_double: bool) -> int | float: return increment(num=num) if should_double else sum(left=num, right=num) +@workflow() +def to_int_bad_2(num: int, should_double: Any) -> int | float: + """A mock workflow that casts to an int with a wrong type for handling doubles.""" + return increment(num=num) if should_double else sum(left=num, right=num) + + @workflow() def to_int(num: int, should_double: AtRender[bool]) -> int | float: """A mock workflow that casts to an int with a right type for handling doubles.""" @@ -76,12 +84,18 @@ def test_can_analyze_annotations() -> None: assert analyser.argument_has("ARG1", AtRender) is False -def test_at_render() -> None: - """Test the rendering of workflows with `dewret.annotations.AtRender` and exceptions handling.""" +def test_at_render_bad() -> None: + """Test the rendering of workflows with exceptions handling.""" with pytest.raises(TaskException) as _: result = to_int_bad(num=increment(num=3), should_double=True) wkflw = construct(result, simplify_ids=True) + with pytest.raises(TaskException) as _: + result = to_int_bad_2(num=increment(num=3), should_double=True) + wkflw = construct(result, simplify_ids=True) + +def test_at_render() -> None: + """Test the rendering of workflows with `dewret.annotations.AtRender`.""" result = to_int(num=increment(num=3), should_double=True) wkflw = construct(result, simplify_ids=True) subworkflows = render(wkflw, allow_complex_types=True)